Skip to main content

Python bindings for Endless Sky C++ code

Project description

Endless Sky bindings for Python

$ pip install endless-sky-bindings

This library does not include the Endless Sky data, so you'll need to find that on your system or clone the Endless Sky repo to get it. The code samples below assume a checkout of endless-sky at ~/endless-sky.

Command line use

Loading data files:

% echo -e 'ship Rocket\n\tattributes\n\t\tdrag 10' > myData.txt
$ python -m endless_sky load --empty-resources myData.txt  # only prints ships atm
'Rocket': {'drag': 10.0, 'gun ports': 0.0, 'turret mounts': 0.0},
$ python -m endless_sky load -- --resources ~/endless-sky
{'Aerie': {'bunks': 28.0,
           'capture attack': 1.8000000000000003,
           'capture defense': 2.4000000000000004,
           'cargo space': 50.0,
...
$ # In order to parse a file with vanilla outfits defined, use --resources
$ python -m endless_sky load --resources ~/endless-sky myData.txt
{'Aerie': {'bunks': 28.0,
...
<'Rocket' is somewhere in here>
...

Runing the game and a Python interpreter at the same time:

$ python -m endless_sky run --resources ~/endless-sky --default-config

Library

Once you get a handle on the endless_sky.bindings module (bound to 'es' variable here), C++ classes are exposed to Python pretty directly; for documentation, see the header files in Endless Sky.

>>> from endless_sky.loader import load_data
>>> es = load_data(resources="/Users/tomb/endless-sky")
>>> ships = es.GameData.Ships() # these objects correspond to 
>>> ships.<tab><tab>
ships.Find(  ships.Has(   ships.size(
>>> shuttle = ships.Find("Shuttle")
<endless_sky.bindings.Ship object at 0x1087391b0>
>>> ship = es.Ship(shuttle)  # make a copy to avoid modifying the template
>>> ship.<tab><tab>
ship.Acceleration(          ship.Hull(                  ship.Mass(
ship.AddCrew(               ship.HyperdriveFuel(        ship.MaxReverseVelocity(
ship.Attributes(            ship.IdleHeat(              ship.MaxVelocity(
ship.BaseAttributes(        ship.IsBoarding(            ship.MaximumHeat(
... and many more, see header files for documentation
>>> ship.Attributes().Attributes()
<endless_sky.bindings.Dictionary object at 0x1087392f0>
>>> dict(ship.Attributes().Attributes())
{'bunks': 6.0, 'cargo space': 20.0, 'drag': 1.7000000000000002, ...}
>>> ship.SetName("Summer Breeze")
>>> x.Name()
'Summer Breeze'

Warning: endless_sky.bindings contains non-resetable singletons like GameData, so once you load some data (directly with GameData.BeginLoad(), with a load_data, or indirectly with a parser function) you can't unload that data without exiting Python.

Installation

Mac

brew install libmad libpng SDL2
pip install endless-sky-bindings

Linux

sudo apt-get install libsdl2-dev libpng-dev libjpeg-turbo8-dev libopenal-dev libmad0-dev libglew-dev libgl1-mesa-dev libegl1-mesa-dev libgles2-mesa-dev uuid-dev
pip install endless-sky-bindings

Windows

pip install endless-sky-bindings

Building from source

git clone git@github.com:thomasballinger/endless-sky-bindings-python.git
cd endless-sky-bindings-python

Mac

brew install libmad libpng jpeg-turbo SDL2 openal-soft

Linux

sudo apt-get install libsdl2-dev libpng-dev libjpeg-turbo8-dev libopenal-dev libmad0-dev libglew-dev libgl1-mesa-dev libegl1-mesa-dev libgles2-mesa-dev uuid-dev

Windows

Invoke-WebRequest https://endless-sky.github.io/win64-dev.zip -OutFile win64-dev.zip
Expand-Archive win64-dev.zip -DestinationPath . -Force
Remove-Item win64-dev.zip

cd endless_sky/endless-sky
patch -p1 < ../../patch.diff
cd ../..
pip install 

Dev notes

Updating the Endless Sky patch

These bindings use a patched version of Endless Sky to patch out threads and make a few other changes.

To update the patch:

  • make changes in the submodule at endless_sky/endless-sky
  • with that directory as the working directory, run git diff > ../../patch.diff

This is likely to be necessary after updating the version of Endless Sky used.

This patch is intended to be the minimum to make Python bindings work; if this repo is combined with Emscripten-compiled JavaScript bindings at a later date it will need to be expanded.

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

endless-sky-bindings-0.0.8.tar.gz (683.2 kB view details)

Uploaded Source

Built Distributions

endless_sky_bindings-0.0.8-cp39-cp39-win_amd64.whl (4.1 MB view details)

Uploaded CPython 3.9 Windows x86-64

endless_sky_bindings-0.0.8-cp39-cp39-macosx_10_15_x86_64.whl (2.1 MB view details)

Uploaded CPython 3.9 macOS 10.15+ x86-64

endless_sky_bindings-0.0.8-cp38-cp38-win_amd64.whl (4.1 MB view details)

Uploaded CPython 3.8 Windows x86-64

endless_sky_bindings-0.0.8-cp38-cp38-macosx_10_15_x86_64.whl (2.1 MB view details)

Uploaded CPython 3.8 macOS 10.15+ x86-64

File details

Details for the file endless-sky-bindings-0.0.8.tar.gz.

File metadata

  • Download URL: endless-sky-bindings-0.0.8.tar.gz
  • Upload date:
  • Size: 683.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for endless-sky-bindings-0.0.8.tar.gz
Algorithm Hash digest
SHA256 e3dd8ee264863bb61f1f0d6c4ecebfd5f592c901061e2708c1b8a57817a4ca33
MD5 8c1bdc541a3df3236a312f4ffc8bcbe0
BLAKE2b-256 ad300f5a9962bd683633b5aa9ce929c51ae41e245788fd2fd097fa78eb853840

See more details on using hashes here.

File details

Details for the file endless_sky_bindings-0.0.8-cp39-cp39-win_amd64.whl.

File metadata

  • Download URL: endless_sky_bindings-0.0.8-cp39-cp39-win_amd64.whl
  • Upload date:
  • Size: 4.1 MB
  • Tags: CPython 3.9, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for endless_sky_bindings-0.0.8-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 eee387a5893731bdd07fec230bdf158d4f0119cab3e0134475fa79f2963d320b
MD5 f8ccad377877213e9e4588f1dc710e99
BLAKE2b-256 be142f7ed82edbde7ac19de372dd2889b552035433ca12015fd43a802f2e1c73

See more details on using hashes here.

File details

Details for the file endless_sky_bindings-0.0.8-cp39-cp39-macosx_10_15_x86_64.whl.

File metadata

  • Download URL: endless_sky_bindings-0.0.8-cp39-cp39-macosx_10_15_x86_64.whl
  • Upload date:
  • Size: 2.1 MB
  • Tags: CPython 3.9, macOS 10.15+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for endless_sky_bindings-0.0.8-cp39-cp39-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 ec4298dc61987e9ea954d2ff5cfab9d66ba43fccd7269ad0ace46408dbcadc93
MD5 3fdf1875761eb5d0b3dc81a230895864
BLAKE2b-256 3af3575d276cb1a7f5e72d59a0e41f33c2b7e1b4cc5403c0adf2128978a5ade6

See more details on using hashes here.

File details

Details for the file endless_sky_bindings-0.0.8-cp38-cp38-win_amd64.whl.

File metadata

  • Download URL: endless_sky_bindings-0.0.8-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 4.1 MB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for endless_sky_bindings-0.0.8-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 6d86e1fd20e9a5c917c1d4eae0d6e49b1f126bdf28f0eb7bb1e74295f196acfc
MD5 b3f3f1e68ac5cf6b5d7c5bcad313ec0a
BLAKE2b-256 1c1fa60dc084808a504da84bc174abcb4f3a5577d5f8e160e0518e4ce0de905c

See more details on using hashes here.

File details

Details for the file endless_sky_bindings-0.0.8-cp38-cp38-macosx_10_15_x86_64.whl.

File metadata

  • Download URL: endless_sky_bindings-0.0.8-cp38-cp38-macosx_10_15_x86_64.whl
  • Upload date:
  • Size: 2.1 MB
  • Tags: CPython 3.8, macOS 10.15+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for endless_sky_bindings-0.0.8-cp38-cp38-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 e9dd08505fbc8bad343ba4e5c69cc805df5a03bfa35bf79cfe998ae94be84c99
MD5 925b628b4dadb4ac642327337170b510
BLAKE2b-256 8bda6273fbf8650f8a4f15fdbc0c6ed5a64f0a6d8db2c1fead8b4561ed74c701

See more details on using hashes here.

Supported by

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