blueloveTH cdc2d23b2c ...
2023-09-30 15:21:25 +08:00
2023-09-25 10:46:43 +08:00
...
2023-09-27 20:34:28 +08:00
...
2023-04-17 16:43:30 +08:00
2023-09-28 22:10:22 +08:00
...
2023-09-30 15:21:25 +08:00
...
2023-08-13 17:10:18 +08:00
...
2023-09-29 21:05:37 +08:00
2023-07-18 17:48:39 +08:00
...
2023-09-29 18:43:59 +08:00
...
2023-09-22 20:30:52 +08:00
...
2023-09-29 20:40:41 +08:00
...
2023-09-28 03:18:32 +08:00
...
2023-09-29 18:43:59 +08:00
...
2023-05-04 16:44:45 +08:00
...
2023-08-13 17:10:18 +08:00
2022-11-06 12:16:57 +08:00
...
2023-09-18 21:53:45 +08:00
...
2023-08-03 12:53:10 +08:00
2023-07-18 17:48:39 +08:00
2023-07-18 17:48:39 +08:00
2023-09-28 16:03:39 +08:00
...
2023-09-18 00:03:56 +08:00
...
2023-07-02 03:52:44 +08:00
...
2023-07-15 13:35:52 +08:00
2023-07-18 17:48:39 +08:00
2023-08-10 15:12:35 +08:00

pocketpy: python interpreter in 1 file

C++17 GitHub GitHub release Website

English | 简体中文

pkpy is a lightweight(~14K LOC) Python interpreter for game scripting, built on C++17 with STL.

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.

Please see https://pocketpy.dev for details or try Live Demo.

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 64-bit

Quick Start

Download the pocketpy.h on our GitHub Release page. And #include it in your project.

You can also use cmake to build it from source. See CMakeLists.txt for details. These variables can be set to control the build process:

  • PK_BUILD_STATIC_LIB - Build the static library
  • PK_BUILD_SHARED_LIB - Build the shared library

Compile Flags

To compile it with your project, these flags must be set:

  • --std=c++17 flag must be set
  • Exception must be enabled

Example

#include "pocketpy.h"

using namespace pkpy;

int main(){
    // Create a virtual machine
    VM* vm = new VM();

    // Hello world!
    vm->exec("print('Hello world!')");

    // Create a list
    vm->exec("a = [1, 2, 3]");

    // Eval the sum of the list
    PyObject* result = vm->eval("sum(a)");
    std::cout << py_cast<int>(vm, result);   // 6

    // Bindings
    vm->bind(vm->_main, "add(a: int, b: int)",
      [](VM* vm, ArgsView args){
        int a = py_cast<int>(vm, args[0]);
        int b = py_cast<int>(vm, args[1]);
        return py_var(vm, a + b);
      });

    // Call the function
    PyObject* f_add = vm->_main->attr("add");
    result = vm->call(f_add, py_var(vm, 3), py_var(vm, 7));
    std::cout << py_cast<int>(vm, result);   // 10

    // Dispose the virtual machine
    delete vm;
    return 0;
}

Features

Check this Cheatsheet for a quick overview of the supported features.

Name Example Supported
If Else if..else..elif YES
Loop for/while/break/continue YES
Function def f(x,*args,y=1): YES
Subclass class A(B): YES
List [1, 2, 'a'] YES
ListComp [i for i in range(5)] YES
Slice a[1:2], a[:2], a[1:] YES
Tuple (1, 2, 'a') YES
Dict {'a': 1, 'b': 2} YES
F-String f'value is {x}' YES
Unpacking a, b = 1, 2 YES
Star Unpacking a, *b = [1, 2, 3] YES
Exception raise/try..catch YES
Dynamic Code eval()/exec() YES
Reflection hasattr()/getattr()/setattr() YES
Import import/from..import YES
Context Block with <expr> as <id>: YES
Type Annotation def f(a:int, b:float=1) YES
Generator yield i YES
Decorator @cache YES

Contribution

All kinds of contributions are welcome.

  • Submit a Pull Request
    • fix a bug
    • add a new feature
  • Open an Issue
    • any suggestions
    • any questions

Check our Coding Style Guide if you want to contribute C++ code.

Reference

  • cpython

    The official implementation of Python programming language.

  • byterun

    An excellent learning material. It illustrates how Python's virtual machine works.

  • box2d

    The world's best 2D physics engine, written by Erin Catto. box2d now becomes a built-in module in pkpy v1.1.3 and later.

Star History

Star History Chart

License

MIT License

Description
No description provided
Readme 33 MiB
Languages
C 52.5%
Python 35.5%
C++ 6.1%
CMake 4.6%
JavaScript 0.4%
Other 0.9%