Skip to main content

Native SDL2 backend for mini-arcade-core using SDL2 + pybind11.

Project description

mini-arcade-native-backend

Native SDL2 backend for mini-arcade-core, implemented in C++ with SDL2 + pybind11 and exposed to Python as a backend that plugs into your mini-arcade game framework.

The goal of this repo is to provide a native window + input + drawing layer while keeping all game logic in Python (via mini-arcade-core).

  • C++ (SDL2 + pybind11) ⇒ _native extension module
  • Python adapter ⇒ NativeBackend implementing mini_arcade_core.backend.Backend

Features (current)

  • Opens an SDL window from Python
  • Basic event polling (Quit, KeyDown, KeyUp) mapped to Event / EventType in mini-core
  • Simple rendering:
    • begin_frame() / end_frame()
    • draw_rect(x, y, w, h) (filled rectangle)
  • Example script that shows a moving rectangle and exits on ESC or window close

This is intentionally minimal and intended as a foundation for adding sprites, textures, audio, etc.


Repository layout

mini-arcade-native-backend/
├─ cpp/
│  ├─ engine.h                        # C++ Engine class (SDL wrapper)
│  ├─ engine.cpp
│  └─ bindings.cpp                    # pybind11 bindings for Engine / Event / EventType
├─ src/
│  └─ mini_arcade_native_backend/
│     ├─ __init__.py                  # Python adapter (NativeBackend)
│     └─ ...                          # (future helpers)
├─ examples/
│  └─ native_backend_demo.py          # example using NativeBackend directly
├─ CMakeLists.txt                     # C++ build (pybind11 + SDL2)
└─ pyproject.toml                     # Python package & build config (scikit-build-core)

Install modes

There are two ways to consume this backend:

  1. From PyPI (recommended for players / game users)
    Prebuilt wheels for your platform (no C++ toolchain or vcpkg needed).
  2. From source (for contributors / engine dev)
    Build the C++ extension locally using CMake + vcpkg.

1. Using the backend from PyPI (no C++ build)

Once wheels are published, you can simply do:

pip install mini-arcade-core
pip install mini-arcade-native-backend

And in your game:

from mini_arcade_core import Game, GameConfig, Scene
from mini_arcade_core.backend import EventType
from mini_arcade_native_backend import NativeBackend

class MyScene(Scene):
    def handle_event(self, event):
        if event.type == EventType.KEYDOWN and event.key == 27:  # ESC
            self.game.quit()

    def update(self, dt: float):
        ...

    def draw(self, backend):
        backend.draw_rect(100, 100, 200, 150)

config = GameConfig(
    width=800,
    height=600,
    title="Mini Arcade + Native SDL2",
    backend_factory=lambda: NativeBackend(),
)

game = Game(config)
scene = MyScene(game)
game.run(scene)

For normal users of your games, this is the ideal path: no vcpkg, no CMake, no compiler.


2. Developing / building from source

If you want to work on the native backend itself (C++ + Python), you’ll build the extension locally. For that, you need a C++ toolchain, CMake, and vcpkg.

2.1. System requirements

  • OS: Windows 10 or later (current dev setup)
  • Compiler: MSVC via Visual Studio Build Tools or Visual Studio 2022
    • Install the “Desktop development with C++” workload
  • CMake: 3.16+
  • Python: 3.9–3.11 (matching your mini-arcade-core version)
  • vcpkg: for SDL2 and pybind11
  • (Optional but nice) virtual environment / Poetry for Python deps

2.2. vcpkg + C++ libraries

This project uses vcpkg to manage C++ dependencies.

Clone and bootstrap vcpkg

cd C:\Users\<your_user>\work

git clone https://github.com/microsoft/vcpkg.git
cd vcpkg
.\bootstrap-vcpkg.bat

Install dependencies via vcpkg

# From the vcpkg folder:
.\vcpkg.exe install sdl2 pybind11

You only need to do this once per machine (unless you wipe vcpkg or add new libraries).

2.3. Linking CMake to vcpkg

For builds in this repo, set the toolchain environment variable once per shell:

$env:CMAKE_TOOLCHAIN_FILE = "C:/Users/<your_user>/work/vcpkg/scripts/buildsystems/vcpkg.cmake"

(Adjust the path if you cloned vcpkg somewhere else.)


3. Building & installing the package from source

This project uses scikit-build-core as the build backend, which lets pip drive CMake for you.

From the repo root (mini-arcade-native-backend/):

3.1. Editable install (dev mode)

# Activate your virtualenv (or use Poetry's venv)
# Then, with CMAKE_TOOLCHAIN_FILE set:

pip install -e .

What this does:

  • Runs CMake via scikit-build-core
  • Builds the _native extension
  • Installs the package in editable mode, so changes to src/ are picked up immediately

After this, you can test in Python:

>>> from mini_arcade_native_backend import NativeBackend
>>> backend = NativeBackend()
>>> backend.init(800, 600, "Hello from native backend")

3.2. Building wheels / sdist

To build distributable artifacts:

python -m build

This will produce:

dist/
  mini-arcade-native-backend-0.1.0-*.whl
  mini-arcade-native-backend-0.1.0.tar.gz

Those wheels can be uploaded to PyPI (e.g. via twine) and installed by anyone with:

pip install mini-arcade-native-backend

End users installing the wheel do not need vcpkg or a compiler.


4. Python usage & example

The package exposes a NativeBackend that implements the Backend protocol from mini-arcade-core and wraps the C++ Engine underneath.

from mini_arcade_native_backend import NativeBackend
from mini_arcade_core.backend import EventType

A small standalone demo is provided under examples/:

python examples/native_backend_demo.py

That demo:

  • opens an 800×600 window,
  • moves a rectangle horizontally,
  • exits on ESC or window close.

(When installed via pip install -e ., you can run this from the repo root.)


5. How it fits into mini-arcade-core

On the C++ side (cpp/engine.h / cpp/engine.cpp):

  • mini::Engine wraps SDL:
    • init(width, height, title)
    • begin_frame() / end_frame()
    • draw_rect(x, y, w, h)
    • poll_events()std::vector<Event>
  • EventType and Event are simple types mapping SDL events to something Python-friendly.

On the Python side (src/mini_arcade_native_backend/__init__.py):

  • The compiled C++ module is imported as ._native (installed into the same package)
  • NativeBackend implements mini_arcade_core.backend.Backend:
    • init(width, height, title)_native.Engine.init(...)
    • poll_events() → converts _native.Event to core Event
    • begin_frame() / end_frame() → pass-through
    • draw_rect(x, y, w, h) → pass-through

A minimal integration with mini-arcade-core:

from mini_arcade_core import Game, GameConfig, Scene
from mini_arcade_core.backend import Backend, Event, EventType
from mini_arcade_native_backend import NativeBackend

class MyScene(Scene):
    def handle_event(self, event: Event):
        if event.type == EventType.KEYDOWN and event.key == 27:  # ESC
            self.game.quit()

    def update(self, dt: float):
        ...

    def draw(self, backend: Backend):
        backend.draw_rect(100, 100, 200, 150)

config = GameConfig(
    width=800,
    height=600,
    title="Mini Arcade + Native SDL2",
    backend_factory=lambda: NativeBackend(),
)

game = Game(config)
scene = MyScene(game)
game.run(scene)

6. Troubleshooting

  • ModuleNotFoundError: No module named '_native'

    • Ensure pip install -e . (or python -m build) completed successfully.
    • Confirm that the wheel contains mini_arcade_native_backend/_native.*.pyd.
  • DLL load error / Python version mismatch

    • Make sure you are building and running with the same Python version.
    • If you have multiple Python versions installed, ensure the one used by pip install -e . is the one used to run your game.
  • CMake can’t find SDL2 or pybind11

    • Confirm vcpkg is installed and sdl2 + pybind11 are installed via vcpkg.
    • Make sure CMAKE_TOOLCHAIN_FILE is set correctly in your shell.

7. Roadmap

  • Configurable clear color (per scene / per game)
  • Basic texture / sprite support
  • Simple audio playback
  • CI that builds wheels for Windows and uploads to PyPI
  • A mini-arcade-core example project that uses this backend as the default renderer

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mini_arcade_native_backend-1.0.0.tar.gz (66.3 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

mini_arcade_native_backend-1.0.0-cp311-cp311-win_amd64.whl (146.7 kB view details)

Uploaded CPython 3.11Windows x86-64

mini_arcade_native_backend-1.0.0-cp310-cp310-win_amd64.whl (146.0 kB view details)

Uploaded CPython 3.10Windows x86-64

mini_arcade_native_backend-1.0.0-cp39-cp39-win_amd64.whl (155.6 kB view details)

Uploaded CPython 3.9Windows x86-64

File details

Details for the file mini_arcade_native_backend-1.0.0.tar.gz.

File metadata

File hashes

Hashes for mini_arcade_native_backend-1.0.0.tar.gz
Algorithm Hash digest
SHA256 7d7a49bd0e7f61e95c3e9517de85da893bd9aba12534ca8eeac51d415faf61e5
MD5 2ab001a4f30f99e2244412deaffe5acc
BLAKE2b-256 202c3e3b552199dc47b64f2e53849e8e47e8ec0cdb8f6c83153b6d09b7b20755

See more details on using hashes here.

File details

Details for the file mini_arcade_native_backend-1.0.0-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for mini_arcade_native_backend-1.0.0-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 8a8ed0c43f34523cb03cd8305992dae32e8d7d9db37653ae81e2f8f7ba35cc9b
MD5 5b4478bf5c99ce5b7fdbb6c2a57a4724
BLAKE2b-256 a5a6b026f9b1d35e195948661ff47b40cd46a6f83d64c42a39ff64a74ed9a5c0

See more details on using hashes here.

File details

Details for the file mini_arcade_native_backend-1.0.0-cp310-cp310-win_amd64.whl.

File metadata

File hashes

Hashes for mini_arcade_native_backend-1.0.0-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 8259ae9f28b1677d3b7b2596c2ce8f03f41ea8fa9b57bec0c362e82a6c40da68
MD5 fcefecfc0ac5266d0c01c472ee5d4a40
BLAKE2b-256 2f5f3f8f317e49fe65eabf2ea9c70c54d0d4c7a28f56e3d5f4df94473f0d6f3a

See more details on using hashes here.

File details

Details for the file mini_arcade_native_backend-1.0.0-cp39-cp39-win_amd64.whl.

File metadata

File hashes

Hashes for mini_arcade_native_backend-1.0.0-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 355c16b885b8b5fc275c148f672b49c4f267198157eaf0de5e771c8e6a54d36c
MD5 b4a68d55b9fed6181758a114a05bb96a
BLAKE2b-256 01930ef788be04b070559370abb488c1b6fde685b2c85e3147964b19a806cbc6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page