Skip to main content

No Man's Sky python modding API

Project description

NMS.py

NMS.py is a python library to expose interal game functions for No Man's Sky.

NOTE: This library is missing a lot of info which will gradually get added over time. It should also be noted that Game updates can very easily break mods utilising NMS.py, so care should be taken when using mods. Any responsibility for broken saves is entirely on the users of this library.

Also note that this library will never contain functions relating to online functionality to avoid any abuse. The author of this library does not condone any use of this code for any purpose that is directly detrimental to other players.

Installation

Note: It is recommended that you download python from the official site as the windows store version may have issues, as well as the managed python which uv installs.

Note: Python 3.14 is not yet supported. This will come in time but requires some changes to a dependency in pyMHF.

The recommended way to install NMS.py is to simply run python -m pip install nmspy. This will install NMS.py and its' dependency pyMHF into your system python. You can of course install it in a venv or as a dependency using uv if you prefer.

Usage

To run NMS.py, enter the following command into a terminal:

pymhf run nmspy

This will display some config options to complete. The only option to consider is the location of the mods folder. It is recommended that you specify the MODS folder inside the GAMEDATA folder as your mod directory (ie. the same one you put normal mods in). All mods will be placed in either this folder, or in a chcild folder of this. You can essentially think of any mod using NMS.py being able to be "installed" in the same way you would any other normal mod.

If NMS.py starts up successfully you should see two extra windows; an auto-created GUI from pyMHF, and a terminal window which will show the logs for pyMHF.

If you want to stop NMS, you can press ctrl + C in the window you started the process in to kill it.

Writing mods

Currently the best way to see how to write a mod is to look at the example_mods folder, as well as looking at the pyMHF docs which has comprehensive details on how to use pyMHF.

Contributing

NMS.py can always be better! If you are interested in improving it, the best way to do so is to either make mods using it, or, if you have reverse engineering skills, you can contribute either new functions or new field offsets.

Adding new functions to hook

To add a new function to hook you need to add the details to tools/data.json as well as the nmspy/data/types.py file. The data for these can generally be found by comparing the structure of the function in the latest exe to either the mac binary or the 4.13 binary. It is recommended to use either IDA Fusion or SigmakerEX for IDA or some other plugin for any other disassembler to get the unique byte pattern for the function you are providing.

Adding new struct fields

This is a bit trickier and will often involve a good amount of reverse engineering of the exe, comparing the data to the 4.13 binary as well as potentially the mac binary. It is best if a comment is made above the added field so that it's possible to find it again when the game updates so that it's possible to check if the offset has changed.

Credits

Thanks to the developers of minhook, cyminhook and pymem, all of which are instrumental in making this framework possible.

Big thanks to vitalised for their constant RE discussions, and gurren3 for the same as well as the initial work done on NMS.API which heavily inspired the creation of this.

Thanks also to the many people I have discussed various NMS details with, both big and small.

Thanks to RaYRoD for initially discovering the pdb as well as regular insightful discussions regarding all things reverse engineering NMS.

Thanks also to anyone who has contributed function definitions or patterns. Any and all help is always appreciated!

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

nmspy-161765.1.tar.gz (682.6 kB view details)

Uploaded Source

Built Distribution

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

nmspy-161765.1-py3-none-any.whl (402.6 kB view details)

Uploaded Python 3

File details

Details for the file nmspy-161765.1.tar.gz.

File metadata

  • Download URL: nmspy-161765.1.tar.gz
  • Upload date:
  • Size: 682.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nmspy-161765.1.tar.gz
Algorithm Hash digest
SHA256 bef134a53af113b4ccd72ed4946f8d2b6726beec06fbd6f07c14b108b2cdad7c
MD5 a064b20fe0535574079cc46bedb0c391
BLAKE2b-256 3b48efecadc90ae8e928f101cad725b245042805d49e8960ce3b747fe85e4c52

See more details on using hashes here.

Provenance

The following attestation bundles were made for nmspy-161765.1.tar.gz:

Publisher: pipeline.yml on monkeyman192/NMS.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nmspy-161765.1-py3-none-any.whl.

File metadata

  • Download URL: nmspy-161765.1-py3-none-any.whl
  • Upload date:
  • Size: 402.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nmspy-161765.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d65e0572aab7fe4bf37a542327f6121c10b4f75435b905ed872064b297ffb3a8
MD5 a7c494fc57da34e1a453d9c81adf1b33
BLAKE2b-256 da78b3b4c7cbc1afd13363f04a008382d601edcec3c1c50d5919e5e1d3b76f73

See more details on using hashes here.

Provenance

The following attestation bundles were made for nmspy-161765.1-py3-none-any.whl:

Publisher: pipeline.yml on monkeyman192/NMS.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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