mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-26 06:20:16 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| icon: home
 | |
| label: Welcome
 | |
| ---
 | |
| 
 | |
| # Welcome to pocketpy
 | |
| 
 | |
| pkpy is a lightweight(~15K LOC) Python 3.x interpreter for game scripting, written in C11.
 | |
| 
 | |
| It aims to be an alternative to lua for game scripting, with elegant syntax, powerful features and competitive performance.
 | |
| pkpy is extremely easy to embed via a single header file `pocketpy.h`, without external dependencies.
 | |
| 
 | |
| 
 | |
| ## What it looks like
 | |
| 
 | |
| ```python
 | |
| def is_prime(x):
 | |
|   if x < 2:
 | |
|     return False
 | |
|   for i in range(2, x):
 | |
|     if x % i == 0:
 | |
|       return False
 | |
|   return True
 | |
| 
 | |
| primes = [i for i in range(2, 20) if is_prime(i)]
 | |
| print(primes)
 | |
| # [2, 3, 5, 7, 11, 13, 17, 19]
 | |
| ```
 | |
| 
 | |
| ## Supported platforms
 | |
| 
 | |
| pkpy should work on any platform with a C++17 compiler.
 | |
| These platforms are officially tested.
 | |
| 
 | |
| + Windows 64-bit
 | |
| + Linux 64-bit / 32-bit
 | |
| + macOS 64-bit
 | |
| + Android 64-bit / 32-bit
 | |
| + iOS 64-bit
 | |
| + Emscripten 32-bit
 | |
| + Raspberry Pi OS 64-bit
 | |
| 
 | |
| ## Star the repo
 | |
| 
 | |
| If you find pkpy useful, consider [star this repository](https://github.com/blueloveth/pocketpy) (●'◡'●)
 | |
| 
 | |
| ## Sponsor this project
 | |
| 
 | |
| You can sponsor this project via these ways.
 | |
| 
 | |
| + [Github Sponsors](https://github.com/sponsors/blueloveTH)
 | |
| + [Buy me a coffee](https://www.buymeacoffee.com/blueloveth)
 | |
| 
 | |
| Your sponsorship will help us develop pkpy continuously.
 | |
| 
 | |
| ## Upgrade to v2.0
 | |
| 
 | |
| pkpy v2.0 is a C11 project instead of C++17. All your existing code for v1.x won't work anymore.
 | |
| 
 | |
| We provide two API sets for v2.0, C-API and pybind11 API (C\+\+17). If you are a C user, use the C-API. If you are a C\+\+ user, use the pybind11 API.
 | |
| 
 |