A Python library for reading/writing Minecraft's various save formats.
Project description
Amulet Core
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
Documentation
Our online documentation can be found here: https://amulet-core.readthedocs.io
Installing
- 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.
Dependencies
This library uses a number of other libraries. These will be automatically installed when running the command above.
- Numpy
- Amulet_NBT
- PyMCTranslate
Contributing
For Development
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
Code Formatting
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.
Building the Documentation
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
Branch Naming
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>
Pull Requests
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.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file amulet_core-1.9.26.tar.gz
.
File metadata
- Download URL: amulet_core-1.9.26.tar.gz
- Upload date:
- Size: 201.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d487b0eca011f232d27fd98e2b28311e8d70ab69ce2a9d3139961ee2e59a0542 |
|
MD5 | 3ff0dfdb79d811fbb9ae5f77d46451b0 |
|
BLAKE2b-256 | 1cafb449479560685f65c3f422aebe35040e764c26af863ba9cf46aaa64fccdd |
File details
Details for the file amulet_core-1.9.26-py3-none-any.whl
.
File metadata
- Download URL: amulet_core-1.9.26-py3-none-any.whl
- Upload date:
- Size: 274.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ff52dadf39d8ef531d612df1e7efbfbd09ee5306188e84390860323536a48b56 |
|
MD5 | 4686fccf7cef7463235a08af8d072d89 |
|
BLAKE2b-256 | ec767b7165a403420685cfa3d046fe7cbb5a1f0717ee1725f6876045dc23be34 |