A Python 3 library to read and write data from Minecraft's various save formats.
This library provides the main world editing functionality for Amulet Map Editor
If you are looking for the actual editor it can be found at Amulet Map Editor
Our online documentation can be found here: https://amulet-core.readthedocs.io
- Install Python 3.7
- We recommend setting up a python virtual environment so you don't run into issues with dependency conflicts.
- run
pip install amulet-core
to install the library and all its dependencies.
This library uses a number of other libraries. These will be automatically installed when running the command above.
- Numpy
- Amulet_NBT
- PyMCTranslate
Download the code to your computer, install python and run the following command from the root directory.
run pip install -e .[dev]
This command will install the library in development mode with the libraries required for development.
- Black (Required for formatting)
- Must be run before pushing a Pull Request
For information about contributing to this project, please see the contribution section below
For code formatting, we use the formatting utility black.
To run it, run the following command from your favorite terminal after installing: black amulet tests
In order for your pull request to be accepted, this command must be run to format every file.
To build the documentation locally, run the following command: make html
and then navigate to the
generated directory docs_build/html
in your favorite web browser
Branches should be created when a certain bug or feature may take multiple attempts to fix. Naming them should follow the following convention (even for forked repositories when a pull request is being made):
- For features, use:
impl-<feature name>
- For bug fixes, use:
bug-<bug tracker ID>
- For improvements/rewrites, use:
improv-<feature name>
- For prototyping, use:
proto-<feature name>
We ask that submitted Pull Requests give moderately detailed notes about the changes and explain any changes that were made to the program outside of those directly related to the feature/bug-fix. Make sure to run all tests and formatting otherwise we cannot accept your pull request.
Note: We will also re-run all tests before reviewing, this is to mitigate additional changes/commits needed to pass all tests.
Once a Pull Request is submitted, we will mark the request for review, once that is done, we will review the changes and provide any notes/things to change. Once all additional changes have been made, we will merge the request.