Python utilities for downloading and processing Minecraft's generated data.
- Python 3.8+
- Java 11+ (for invoking the Minecraft server's data generator)
pip install mcgen
python -m mcgen --help
mcgen [-h] [--jarpath JARPATH] [--rawpath RAWPATH] [--outpath OUTPATH] [--version VERSION] [--manifest MANIFEST] [--processors [PROCESSORS [PROCESSORS ...]]] [--log LOG]
Download the Minecraft server jar for the specified version, invoke the data generator, and process the output.
optional arguments:
-h, --help show this help message and exit
--jarpath JARPATH Where to download and store the server jar. Default: temp/jars/minecraft_server.{version}.jar
--rawpath RAWPATH Where to store the raw server-generated files. Default: temp/raw/{version}
--outpath OUTPATH Where to write the final processed output. Default: temp/out/{version}
--version VERSION The server version to download and process. Defaults to latest snapshot.
--manifest MANIFEST Where to fetch the version manifest from. Defaults to Mojang's online copy.
--processors [PROCESSORS [PROCESSORS ...]]
Which processors to use in processing the raw server-generated files. Defaults to a set of built-in processors.
--log LOG The level of verbosity at which to print log messages.
Processors are used to process the raw server-generated data and produce output. They are invoked one after the other, in the order they are defined.
To provide a custom set of processors, use the --processors
option like so:
python -m mcgen --processors mcgen.processors.split_registries mcgen.processors.summarize_data
Several built-in processors are provided in mcgen.processors
:
write_version_file
- Write the game version to a file.convert_json_files
- Convert json files into another form.simplify_blocks
- Create an optimized summary of blocks.split_registries
- Splitregistries.json
into separate files.summarize_data
- Create a summary of each vanilla registry.summarize_worldgen
- Create a summary of worldgen reports.create_all_tags_data_pack
- Generate a data pack with "all" tags.
Processors are Python modules containing a function with the following signature:
def process(ctx: Context, **options):
...
ctx
contains information about the processing contextoptions
is a key-value mapping of arbitrary data
Note that in snapshot 21w39a the java
command used to invoke the server generator changed:
# Prior to 21w39a:
java -cp {jar_path} net.minecraft.data.Main --server --reports
# From 21w39a onward:
java -DbundlerMainClass=net.minecraft.data.Main -jar {jar_path} --server --reports
If you need to generate data for versions prior to 21w39a, use the --cmd
option with the older java
command.