bin-patch-gen is a tool designed to generate SpigotMC binary patches for all SpigotMC-supported Minecraft versions.
./bin-patch-gen
This runs the program in its default mode. It retrieves a list of all versions that Spigot's BuildTools can build, iterates through them, and builds each version. After building, it generates a bsdiff
/bspatch
compatible patch file that can convert a vanilla server jar into a Spigot server jar.
./bin-patch-gen --version x.xx.x
This runs the program to generate a binary patch for a specific Minecraft version. Replace x.xx.x
with the desired version.
For example:
./bin-patch-gen --version 1.21.3
Generates a patch for version 1.21.3.
./bin-patch-gen --force
Builds all versions regardless of whether they have already been built.
./bin-patch-gen --clean
Removes all contents of the run
directory. If the current working directory is named run
, it will be cleared. This ensures a clean environment before starting the process.
Note: This may result in the deletion of important files, so use this option with caution.
./bin-patch-gen patch oldfile newfile patchfile
This mode applies a patch to transform one file into another.
oldfile
: The original file to be patched.patchfile
: The binary patch file.newfile
: The output file resulting from applying the patch.
There is a provided docker-compose.yml
file which you can use. Our CI runs a cronjob with the provided update.sh
script, which
just runs the docker container and pushes the patches to Git.
Important
You need to create an empty config.toml
before being able to run the app in docker. This config looks like such:
java_8_home = ""
java_16_home = ""
java_17_home = ""
java_21_home = ""
For each version the program builds, three files are generated:
1.10.2.patch
: Thebsdiff
binary patch file generated by the tool. This patch can transform a vanilla Minecraft server jar into a Spigot server jar for version1.10.2
.1.10.2.json
: Metadata for the patch file, including information about the patch and the software it applies to. For reference, see the1.10.2.json
file.1.10.2.libs
: A file containing Maven coordinates of libraries required on the classpath for the patched program to run. This may include libraries present in the patch itself. For reference, see the1.10.2.libs
file.
For example, if you build version 1.10.2
, the output directory will contain:
1.10.2.patch
1.10.2.json
1.10.2.libs
To build this project, you need Cargo and a recent version of Rust from the nightly channel. Building is straightforward, like any other Rust program:
cargo build
Any pull requests and issues are welcome.
All contributions should be:
- made to the dev branch.
- formatted using rustfmt.
- tested.
CI Contributions should only be done by maintainers.
This project is licensed under the MIT license.