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-161436.0.tar.gz (669.3 kB view details)

Uploaded Source

Built Distribution

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

nmspy-161436.0-py3-none-any.whl (391.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for nmspy-161436.0.tar.gz
Algorithm Hash digest
SHA256 1ea5153a085085b6ef83e8e55609c3c42f24b4bb10bdc7c25d960af1608d2794
MD5 380864d95009ec437f86f2eb2b3a1c36
BLAKE2b-256 6d8ec8ddb15255cdb3cc9cb231254375d2b130e2d0fadf00b4c6043a45d1804d

See more details on using hashes here.

Provenance

The following attestation bundles were made for nmspy-161436.0.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-161436.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for nmspy-161436.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1848cf0cfbc6a0ad300b43ab985773047fcbfb0c5e2fc7dcdfaa44d838b7dc06
MD5 07a066b825a9fb40a7ee5af9bf401349
BLAKE2b-256 7eb6722afb81f67a6b5da901ac4e597f6a7262e01e2e835cc0be36cae8b64eef

See more details on using hashes here.

Provenance

The following attestation bundles were made for nmspy-161436.0-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