mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-25 14:00:18 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.5 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/pocketpy/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__`, `__setattr__` and `__delattr__` can only be set in cpp.
 | |
| 
 | |
| ### Make `next()` compatible with cpython
 | |
| 
 | |
| You can use the following code to make `next()` compatible with cpython temporarily.
 | |
| 
 | |
| ```python
 | |
| import builtins
 | |
| 
 | |
| def next(obj):
 | |
|     res = builtins.next(obj)
 | |
|     if res is StopIteration:
 | |
|         raise StopIteration
 | |
|     return res
 | |
|     
 | |
| a = iter([1])
 | |
| assert next(a) == 1
 | |
| 
 | |
| try:
 | |
|     next(a)
 | |
|     exit(1)
 | |
| except StopIteration:
 | |
|     pass
 | |
| ```
 | |
| 
 | |
| !!!
 | |
| Do not change `builtins.next`. It will break some internal functions which rely on `StopIteration` as return value.
 | |
| !!! |