The SpongeAPI implementation targeting vanilla Minecraft and 3rd party platforms. It is licensed under the MIT License.
#sponge
The following steps will ensure your project is cloned properly.
git clone --recursive https://github.com/SpongePowered/Sponge.git
cd Sponge
cp scripts/pre-commit .git/hooks
Note: Sponge uses Gradle as its build system. The repo includes the Gradle wrapper that will automatically download the correct Gradle
version. Local installations of Gradle may work (as long as they are using Gradle 6.8+) but are untested. To execute the Gradle wrapper, run the
./gradlew
script on Unix systems or only gradlew
on Windows systems.
To have browsable sources for use in-IDE, run ./gradlew :decompile
. This command will need to be re-ran after any change to
Minecraft version or to .accesswidener
files. If sources are not appearing properly, an IDE refresh should fix things.
For Eclipse
While we do our best to support any IDE, most of our developers use IntelliJ, so issues may pop up with Eclipse from time to time. We'll be happy to work to resolve those issues if reported via our issues page or fixed via PR.
For IntelliJ
For both Eclipse and IntelliJ, a variety of run configurations will be generated which allow running the client and server in development. These run configurations will be re-generated on each project import, so any desired modifications should be done on copies of the configurations.
While these run configurations have Java versions attached to them, be aware that IntelliJ ignores that information entirely, and Eclipse will only be able to align those java versions with whatever JREs it is aware of.
In order to build Sponge you simply need to run the gradlew build
command. On Windows systems you should run gradlew build
instead
of ./gradlew build
to invoke the Gradle wrapper. You can find the compiled JAR files in ./build/libs
and ./vanilla/build/libs
.
The following steps will update your clone with the official repo.
git pull
git submodule update --recursive
./gradlew build --refresh-dependencies
Are you a talented programmer looking to contribute some code? We'd love the help!