mirror of
https://github.com/pocketpy/pocketpy
synced 2025-10-24 13:30:18 +00:00
44 lines
2.0 KiB
Markdown
44 lines
2.0 KiB
Markdown
---
|
|
icon: dot
|
|
title: Comparison with CPython
|
|
order: 99
|
|
---
|
|
|
|
[cpython](https://github.com/python/cpython) is the reference implementation of the Python programming language. It is written in C and is the most widely used implementation of Python.
|
|
|
|
## The design goal
|
|
|
|
**pkpy aims to be an alternative to lua for
|
|
game scripting, not cpython for general purpose programming.**
|
|
|
|
+ For syntax and semantics, pkpy is designed to be as close to cpython as possible.
|
|
+ For ecosystem and others, pkpy is not compatible with cpython.
|
|
|
|
pkpy supports most of the syntax and semantics of python.
|
|
For performance and simplicity, some features are not implemented, or behave differently.
|
|
The easiest way to test a feature is to [try it on your browser](https://pocketpy.dev/static/web/).
|
|
|
|
## Unimplemented features
|
|
|
|
1. Descriptor protocol `__get__` and `__set__`. However, `@property` is implemented.
|
|
2. `__slots__` in class definition.
|
|
3. `else` clause in try..except.
|
|
4. Inplace methods like `__iadd__` and `__imul__`.
|
|
5. `__del__` in class definition.
|
|
6. Multiple inheritance.
|
|
|
|
## Different behaviors
|
|
|
|
1. positional and keyword arguments are strictly evaluated.
|
|
2. When a generator is exhausted, `StopIteration` is returned instead of raised.
|
|
3. `++i` and `--j` is an increment/decrement statement, not an expression.
|
|
4. `int` does not derive from `bool`.
|
|
5. `int` is 64-bit. You can use `long` type explicitly for arbitrary sized integers.
|
|
6. `__ne__` is not required. Define `__eq__` is enough.
|
|
7. Raw string cannot have boundary quotes in it, even escaped. See [#55](https://github.com/blueloveTH/pocketpy/issues/55).
|
|
8. In a starred unpacked assignment, e.g. `a, b, *c = x`, the starred variable can only be presented in the last position. `a, *b, c = x` is not supported.
|
|
9. A `Tab` is equivalent to 4 spaces. You can mix `Tab` and spaces in indentation, but it is not recommended.
|
|
10. `%`, `&`, `//`, `^` and `|` for `int` behave the same as C, not python.
|
|
11. `str.split` and `str.splitlines` will remove all empty entries.
|
|
12. `__getattr__` and `__setattr__` can only be set in cpp.
|