- Have a look through the Botania FAQ, to see if your issue has been solved already
- Issues regarding "Bukkit+Forge" servers that are not reproducible with Forge only are not accepted
- Issues regarding outdated versions of the mod, especially for older versions of Minecraft, are not accepted
- Duplicate issues or issues that have been solved already (use the search feature!) will be closed without warning.
- Do not tag your issues' names. "Something Broke" is prefered to "[Bug] Something Broke" because there's a proper label system in place.
- Suggestions are not accepted. In general, new features are added to Botania on a must-have basis. The bar for new features is quite high.
- Run scripts/gitconfig.sh from the repo root to set some useful git defaults locally
- Run the
checkSyntax
Gradle task to make sure your changes pass our style guidelines - The
spotlessJavaApply
Gradle task can fix most violations for you. - Target the default branch of the repository in all PR's (unless it's a hotfix that only applies to an older version). The maintainers will cherry pick things back ourselves when creating hotfixes.
- Keep PR's small. The smaller it is, the faster we will review it. Only fix one thing per PR instead of piling everything into one massive PR.
- Consider the patch workflow to help keep your changes small. If you hate GitHub's PR
model like some of the maintainers
do, feel free to email patches to
~williewillus/[email protected]
. See https://git-send-email.io to set up your Git environment for mailing patches and https://git-rebase.io for help with the rebase-oriented workflow. Advanced users might like the branchless workflow which pairs particularly well with the patch workflow. - Please write descriptive commit messages with proper separation between the title and summary of the message. Do not write commit messages consisting only of "Fix #123", that means nothing to e.g. someone reading the logs offline without access to GitHub.
- If you fix a gameplay bug or add a new gameplay feature, consider adding a GameTest for it (see below)
- If applicable, add an entry to the changelog in
web/changelog.md
under the "Upcoming" section.
Each major Minecraft version has a dedicated Git branch, the primary support version is marked as the default on web UI's. All new changes should be targeted to the primary support branch, and backported as necessary to older branches via cherry-picking.
As much as possible, we do not use merge commits. They clutter the log and make
bisecting very annoying. When obtaining remote changes, use git pull origin <branch> --rebase
. When merging PR's, use the "Rebase and Merge " or "Squash and Merge"
options. For the latter, GitHub will usually generate a commit message concatenating all
the individual commit messages together, you will likely want to consider writing a better
message.
- Pull from remote, test all changes, and commit everything.
- Make sure the changelog in
web/changelog.md
is up to date, then change the "Upcoming" version of the section to the version to be released, and start a new "Upcoming" section. Commit this. - Run
git tag -a release-<VERSION>
. All Botania versions must follow the version format<MC-VER>-INT
, so it'll probably look likegit tag -a release-1.16.3-407
. If you don't remember which version is next, look at thebuild_number
ingradle.properties
. - Increment the
build_number
ingradle.properties
to the next version (one greater than the version you just tagged). Commit this. - Push the branch and the tag you just made:
git push origin <branch> <release tag>
- Go to Jenkins and wait for the tag you just pushed to be compiled and built
- Download the JAR and submit it to CurseForge and Modrinth
- Push the website:
scripts/syncweb.sh <remote username>
. If you don't provide a remote username to ssh into the webserver, it'll take your current login name. - Send an announcement email to
~williewillus/[email protected]
. Check the list archives for examples of how to format the email. Post a link to the email in the #mod_updates Discord channel.
- Create a structure if wanted:
- Run
/test create <size>
to generate a test platform of the desired size. IMPORTANT: All tests should size themselves appropriately to ensure they don't interfere with other tests. E.g. a test testing a block with max radius 8 should leave at least 8 blocks of room on all sides. - Build the test setup then save the structure, without a namespace. Then run
/test export <thename>
. - The command will print the location of the saved
.snbt
file inrun/gameteststructures
. - Copy the file to
src/main/resources/data/botania/gametest/structures
.
- Run
- Create a class in
src/main/java/vazkii/botania/test
. Fill it with methods annotated with@GameTest
, see the other tests for examples. - List the class in the
fabric-gametest
entrypoint in Botania'sfabric.mod.json
.
Tips:
- The @GameTest annotation takes a
batch
argument. Any tests in the same batch run in parallel. Tests in different batches will not run together. - Please keep 5 blocks of padding in the N/S/E/W directions of all tests that have mana pools, spreaders, or flowers in them. This prevents them interfering with the tests about seeing whether flowers bind to the closest spreader, if Gametest happens to put them next to each other.
- If your test has a lot of air blocks in it, use structure voids to keep the filesize
down. If you forget, run a regex find-and-replace on the
snbt
file, replacing.*minecraft:air.*\n
with the empty string.
To run tests in-game: open the game normally, make sure you're not standing near anything
you care about, and use /test runall
. (Gametest uses a default superflat with Generate
Structures, doMobSpawning, and doWeatherCycle all disabled as its testing environment.)
To run tests headlessly (all of these do the same thing):
- Use the
Minecraft Game Test
run configuration in your IDE. - Launch the server with the argument
-Dfabric-api.gametest=1
. - Use
./gradlew runGameTest
. (Github Actions does this)
After running tests headlessly, the testing world will be saved to run/world
. Copy this
directory into run/saves
and it will appear as a save file in singleplayer.