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.
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.
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.
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.
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.
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.
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.
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!