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.2.tar.gz (687.7 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.2-py3-none-any.whl (404.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for nmspy-161765.2.tar.gz
Algorithm Hash digest
SHA256 93d20033756225dc9f2e1b6bc7823102e240cf88115025c7558cd690ad40fac4
MD5 2b6a1d3bb7f5fbab67b2e965eb06863f
BLAKE2b-256 e1e31a6a8b69cf2cf042ac7b860b1cbb003874a822042a7fbc2535f691d9644e

See more details on using hashes here.

Provenance

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

File metadata

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

File hashes

Hashes for nmspy-161765.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e5ad0ade9a8e6c0e3332d4a490ac239e0ce3c71223d15e5ac6b3c68acf472281
MD5 7e964e0400effd87c84d9d5675703af9
BLAKE2b-256 adb49afb46cc9908c32048ef218d6fe5d227b661c4f99b67850df681e4041568

See more details on using hashes here.

Provenance

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