mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-22 20:40:18 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			45 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			2.2 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. `__getattr__` and `__setattr__`.
 | |
| 2. Descriptor protocol `__get__` and `__set__`. However, `@property` is implemented.
 | |
| 3. `__slots__` in class definition.
 | |
| 4. Unpacking in `list` and `dict` literals, e.g. `[1, 2, *a]`.
 | |
| 5. Access the exception object in try..except.
 | |
| 6.  `else` clause in try..except.
 | |
| 7.  Inplace methods like `__iadd__` and `__imul__`.
 | |
| 8. `__del__` in class definition.
 | |
| 9. 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 not of unlimited precision. In 32 bit system, `int` and `float` is 30 bit; in 64 bit system, they are both 62 bit.
 | |
| 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. `int` is of limited precision. For arbitrary sized integers, you may use `long` type explicitly. |