mirror of
https://github.com/pocketpy/pocketpy
synced 2025-10-24 13:30:18 +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.
|
|
|