The master branch is for the latest version of minecraft.
Support | Documentation | Git
Building Iris is fairly simple, though you will need to setup a few things if your system has never been used for java development.
Consider supporting our development by buying Iris on spigot! We work hard to make Iris the best it can be for everyone.
Preface: if you need help compiling and you are a developer / intend to help out in the community or with development we would love to help you regardless in the discord! however do not come to the discord asking for free copies, or a tutorial on how to compile.
- Install Java JDK 17
- Set the JDK installation path to
JAVA_HOME
as an environment variable.- Windows
- Start > Type
env
and press Enter - Advanced > Environment Variables
- Under System Variables, click
New...
- Variable Name:
JAVA_HOME
- Variable Value:
C:\Program Files\Java\jdk-17.0.1
(verify this exists after installing java don't just copy the example text)
- Start > Type
- MacOS
- Run
/usr/libexec/java_home -V
and look for Java 17 - Run
sudo nano ~/.zshenv
- Add
export JAVA_HOME=$(/usr/libexec/java_home)
as a new line - Use
CTRL + X
, then PressY
, ThenENTER
- Quit & Reopen Terminal and verify with
echo $JAVA_HOME
. It should print a directory
- Run
- Windows
- Once the project has setup, run
gradlew iris
- The Iris jar will be placed in
Iris/build/Iris-XXX-XXX.jar
Enjoy! Consider supporting us by buying it on spigot!
- Configure ITJ Gradle to use JDK 17 (in settings, search for gradle)
- Add a build line in the build.gradle for your own build task to directly compile Iris into your plugins folder if you prefer.
- Resync the project & run your newly created task (under the development folder in gradle tasks!)
Everyone needs a tool-belt.
package com.volmit.iris.core.tools;
// Get IrisDataManager from a world
IrisToolbelt.access(anyWorld).getCompound().getData();
// Get Default Engine from world
IrisToolbelt.access(anyWorld).getCompound().getDefaultEngine();
// Get the engine at the given height
IrisToolbelt.access(anyWorld).getCompound().getEngineForHeight(68);
// IS THIS THING ON?
boolean yes=IrisToolbelt.isIrisWorld(world);
// GTFO for worlds (moves players to any other world, just not this one)
IrisToolbelt.evacuate(world);
IrisAccess access=IrisToolbelt.createWorld() // If you like builders...
.name("myWorld") // The world name
.dimension("terrifyinghands")
.seed(69133742) // The world seed
.pregen(PregenTask // Define a pregen job to run
.builder()
.center(new Position2(0,0)) // REGION coords (1 region = 32x32 chunks)
.radius(4) // Radius in REGIONS. Rad of 4 means a 9x9 Region map.
.build())
.create();