diff --git a/pom.xml b/pom.xml
index e39e2e206..40931e247 100644
--- a/pom.xml
+++ b/pom.xml
@@ -4,7 +4,7 @@
4.0.0
bytecode.ninja
Iris
- 1.0.3
+ 1.0.5
Iris
false
diff --git a/src/main/java/com/volmit/iris/IrisSettings.java b/src/main/java/com/volmit/iris/IrisSettings.java
index f68b760a9..3b10a50b6 100644
--- a/src/main/java/com/volmit/iris/IrisSettings.java
+++ b/src/main/java/com/volmit/iris/IrisSettings.java
@@ -7,6 +7,7 @@ import com.google.gson.Gson;
import com.volmit.iris.util.Desc;
import com.volmit.iris.util.DontObfuscate;
import com.volmit.iris.util.IO;
+import com.volmit.iris.util.J;
import com.volmit.iris.util.JSONException;
import com.volmit.iris.util.JSONObject;
@@ -21,6 +22,10 @@ public class IrisSettings
@Desc("Iris generator threads (must be 2 or higher). Threads in iris are not a perfect scale for performance as a lot of data has to be shared. 16 Threads is a good rule of thumb. Use 8 threads on a quad core processor.")
public int threads = 16;
+ @DontObfuscate
+ @Desc("The default world type incase iris doesnt have a dimension to use.")
+ public String defaultWorldType = "overworld";
+
@DontObfuscate
@Desc("Iris uses a lot of caching to speed up chunk generation. Setting this higher uses more memory, but may improve performance. Anything past 8,000 should be avoided because there is little benefit past this value.")
public int atomicCacheSize = 3000;
@@ -65,12 +70,18 @@ public class IrisSettings
@Desc("Collects anonymous metrics for bstats")
public boolean metrics = true;
+ @DontObfuscate
+ @Desc("Skips preparing spawn by using nms to hijack the world init phase")
+ public boolean skipPrepareSpawnNMS = true;
+
@DontObfuscate
@Desc("Used to activate Iris")
public String activationCode = "";
public static IrisSettings get()
{
+ IrisSettings defaults = new IrisSettings();
+ JSONObject def = new JSONObject(new Gson().toJson(defaults));
if(settings == null)
{
settings = new IrisSettings();
@@ -94,7 +105,37 @@ public class IrisSettings
{
try
{
- settings = new Gson().fromJson(IO.readAll(s), IrisSettings.class);
+ String ss = IO.readAll(s);
+ settings = new Gson().fromJson(ss, IrisSettings.class);
+
+ J.a(() ->
+ {
+ JSONObject j = new JSONObject(ss);
+ boolean u = false;
+ for(String i : def.keySet())
+ {
+ if(!j.has(i))
+ {
+ u = true;
+ j.put(i, def.get(i));
+ Iris.verbose("Adding new config key: " + i);
+ }
+ }
+
+ if(u)
+ {
+ try
+ {
+ IO.writeAll(s, j.toString(4));
+ Iris.info("Updated Configuration Files");
+ }
+
+ catch(Throwable e)
+ {
+
+ }
+ }
+ });
}
catch(JSONException | IOException e)
diff --git a/src/main/java/com/volmit/iris/command/CommandIrisCreate.java b/src/main/java/com/volmit/iris/command/CommandIrisCreate.java
index 3516b9e4f..79432e6d0 100644
--- a/src/main/java/com/volmit/iris/command/CommandIrisCreate.java
+++ b/src/main/java/com/volmit/iris/command/CommandIrisCreate.java
@@ -1,14 +1,11 @@
package com.volmit.iris.command;
import java.io.File;
-import java.io.IOException;
import org.bukkit.Bukkit;
import org.bukkit.World;
import org.bukkit.WorldCreator;
import org.bukkit.WorldType;
-import org.zeroturnaround.zip.ZipUtil;
-import org.zeroturnaround.zip.commons.FileUtils;
import com.volmit.iris.Iris;
import com.volmit.iris.IrisSettings;
@@ -17,11 +14,8 @@ import com.volmit.iris.gen.nms.NMSCreator;
import com.volmit.iris.gen.provisions.ProvisionBukkit;
import com.volmit.iris.gen.scaffold.IrisGenConfiguration;
import com.volmit.iris.gen.scaffold.TerrainTarget;
-import com.volmit.iris.manager.IrisDataManager;
-import com.volmit.iris.manager.ProjectManager;
import com.volmit.iris.object.IrisDimension;
import com.volmit.iris.util.Form;
-import com.volmit.iris.util.IO;
import com.volmit.iris.util.J;
import com.volmit.iris.util.MortarCommand;
import com.volmit.iris.util.MortarSender;
@@ -62,87 +56,9 @@ public class CommandIrisCreate extends MortarCommand
seed = i.startsWith("seed=") ? Long.valueOf(i.split("\\Q=\\E")[1]) : seed;
pregen = i.startsWith("pregen=") ? Integer.parseInt(i.split("\\Q=\\E")[1]) : pregen;
}
+
+ IrisDimension dim = Iris.proj.installIntoWorld(sender, type, folder);
- sender.sendMessage("Looking for Package: " + type);
-
- IrisDimension dim = Iris.globaldata.getDimensionLoader().load(type);
-
- if(dim == null)
- {
- for(File i : Iris.proj.getWorkspaceFolder().listFiles())
- {
- if(i.isFile() && i.getName().equals(type + ".iris"))
- {
- sender.sendMessage("Found " + type + ".iris in " + ProjectManager.workspaceName + " folder");
- ZipUtil.unpack(i, iris);
- break;
- }
- }
- }
-
- else
- {
- sender.sendMessage("Foind " + type + " dimension in " + ProjectManager.workspaceName + " folder. Repackaging");
- ZipUtil.unpack(Iris.proj.compilePackage(sender, type, true, true), iris);
- }
-
- File dimf = new File(iris, "dimensions/" + type + ".json");
-
- if(!dimf.exists() || !dimf.isFile())
- {
- Iris.globaldata.dump();
- Iris.globaldata.preferFolder(null);
- Iris.proj.downloadSearch(sender, type, false);
- File downloaded = Iris.proj.getWorkspaceFolder(type);
-
- for(File i : downloaded.listFiles())
- {
- if(i.isFile())
- {
- try
- {
- FileUtils.copyFile(i, new File(iris, i.getName()));
- }
-
- catch(IOException e)
- {
- e.printStackTrace();
- }
- }
-
- else
- {
- try
- {
- FileUtils.copyDirectory(i, new File(iris, i.getName()));
- }
-
- catch(IOException e)
- {
- e.printStackTrace();
- }
- }
- }
-
- IO.delete(downloaded);
- }
-
- if(!dimf.exists() || !dimf.isFile())
- {
- sender.sendMessage("Can't find the " + dimf.getName() + " in the dimensions folder of this pack! Failed!");
- return true;
- }
-
- IrisDataManager dm = new IrisDataManager(folder);
- dim = dm.getDimensionLoader().load(type);
-
- if(dim == null)
- {
- sender.sendMessage("Can't load the dimension! Failed!");
- return true;
- }
-
- sender.sendMessage(worldName + " type installed. Generating Spawn Area...");
//@builder
ProvisionBukkit gen = Iris.instance.createProvisionBukkit(
IrisGenConfiguration.builder()
@@ -190,8 +106,7 @@ public class CommandIrisCreate extends MortarCommand
WorldCreator wc = new WorldCreator(worldName).seed(seed).generator(gen).type(WorldType.NORMAL).environment(dim.getEnvironment());
World world = NMSCreator.createWorld(wc, false);
-
-
+
done.set(true);
sender.sendMessage(worldName + " Spawn Area generated.");
@@ -218,7 +133,7 @@ public class CommandIrisCreate extends MortarCommand
Iris.linkMultiverseCore.addWorld(worldName, dimm, seedd + "");
sender.sendMessage("Added " + worldName + " to MultiverseCore.");
}
-
+
J.a(() ->
{
while(!b.get())
diff --git a/src/main/java/com/volmit/iris/gen/DimensionalTerrainProvider.java b/src/main/java/com/volmit/iris/gen/DimensionalTerrainProvider.java
index 64b88c11e..3de9b987d 100644
--- a/src/main/java/com/volmit/iris/gen/DimensionalTerrainProvider.java
+++ b/src/main/java/com/volmit/iris/gen/DimensionalTerrainProvider.java
@@ -2,17 +2,20 @@ package com.volmit.iris.gen;
import java.io.File;
+import org.bukkit.Bukkit;
import org.bukkit.Material;
import org.bukkit.block.data.BlockData;
import org.bukkit.entity.Player;
import com.volmit.iris.Iris;
+import com.volmit.iris.IrisSettings;
import com.volmit.iris.gen.scaffold.TerrainTarget;
import com.volmit.iris.object.InferredType;
import com.volmit.iris.object.IrisBiome;
import com.volmit.iris.object.IrisDimension;
import com.volmit.iris.object.IrisRegion;
import com.volmit.iris.util.B;
+import com.volmit.iris.util.MortarSender;
import com.volmit.iris.util.RNG;
import lombok.Data;
@@ -40,7 +43,23 @@ public abstract class DimensionalTerrainProvider extends ContextualTerrainProvid
if(!folder.exists())
{
Iris.error("Missing World iris/dimensions folder! (" + folder.getAbsolutePath() + ")");
- setDimensionName("error-missing-dimension");
+ setDimensionName(IrisSettings.get().getDefaultWorldType());
+ Iris.proj.installIntoWorld(new MortarSender(Bukkit.getConsoleSender()), getDimensionName(), getTarget().getFolder());
+ return;
+ }
+
+ if(!folder.exists())
+ {
+ Iris.error("Missing World iris/dimensions folder! (" + folder.getAbsolutePath() + ")");
+ try
+ {
+ throw new RuntimeException("Cant find dimension data!");
+ }
+
+ catch(Throwable e)
+ {
+ fail(e);
+ }
return;
}
@@ -53,9 +72,20 @@ public abstract class DimensionalTerrainProvider extends ContextualTerrainProvid
}
}
- Iris.error("Missing World iris/dimensions/.json file. Assuming overworld!");
- setDimensionName("error-missing-dimension");
- fail(new RuntimeException("Missing dimension folder/file in " + folder.getAbsolutePath()));
+ if(!folder.exists())
+ {
+ Iris.error("Missing World iris/dimensions folder! (" + folder.getAbsolutePath() + ")");
+ try
+ {
+ throw new RuntimeException("Cant find dimension data!");
+ }
+
+ catch(Throwable e)
+ {
+ fail(e);
+ }
+ return;
+ }
}
try
@@ -69,6 +99,11 @@ public abstract class DimensionalTerrainProvider extends ContextualTerrainProvid
}
}
+ protected void useDefaultDimensionSetupNOW()
+ {
+
+ }
+
public void onPlayerLeft(Player p)
{
diff --git a/src/main/java/com/volmit/iris/gen/IrisTerrainProvider.java b/src/main/java/com/volmit/iris/gen/IrisTerrainProvider.java
index 722d7ef19..2fcfd7e55 100644
--- a/src/main/java/com/volmit/iris/gen/IrisTerrainProvider.java
+++ b/src/main/java/com/volmit/iris/gen/IrisTerrainProvider.java
@@ -542,12 +542,22 @@ public class IrisTerrainProvider extends SkyTerrainProvider implements IrisConte
@Override
public boolean shouldGenerateCaves()
{
+ if(getDimension() == null)
+ {
+ return false;
+ }
+
return getDimension().isVanillaCaves();
}
@Override
public boolean shouldGenerateVanillaStructures()
{
+ if(getDimension() == null)
+ {
+ return false;
+ }
+
return getDimension().isVanillaStructures();
}
diff --git a/src/main/java/com/volmit/iris/gen/nms/NMSCreator.java b/src/main/java/com/volmit/iris/gen/nms/NMSCreator.java
index 8914e05f4..47a05800a 100644
--- a/src/main/java/com/volmit/iris/gen/nms/NMSCreator.java
+++ b/src/main/java/com/volmit/iris/gen/nms/NMSCreator.java
@@ -5,6 +5,7 @@ import org.bukkit.World;
import org.bukkit.WorldCreator;
import com.volmit.iris.Iris;
+import com.volmit.iris.IrisSettings;
public class NMSCreator
{
@@ -15,31 +16,34 @@ public class NMSCreator
public static World createWorld(WorldCreator creator, boolean loadSpawn)
{
- try
+ if(IrisSettings.get().isSkipPrepareSpawnNMS())
{
- String code = Iris.nmsTag();
+ try
+ {
+ String code = Iris.nmsTag();
- if(code.equals("v1_16_R2"))
- {
- return NMSCreator162.createWorld(creator, loadSpawn);
+ if(code.equals("v1_16_R2"))
+ {
+ return NMSCreator162.createWorld(creator, loadSpawn);
+ }
+ else if(code.equals("v1_16_R1"))
+ {
+ return NMSCreator161.createWorld(creator, loadSpawn);
+ }
+ else if(code.equals("v1_15_R1"))
+ {
+ return NMSCreator151.createWorld(creator, loadSpawn);
+ }
+ else if(code.equals("v1_14_R1"))
+ {
+ return NMSCreator141.createWorld(creator, loadSpawn);
+ }
}
- else if(code.equals("v1_16_R1"))
- {
- return NMSCreator161.createWorld(creator, loadSpawn);
- }
- else if(code.equals("v1_15_R1"))
- {
- return NMSCreator151.createWorld(creator, loadSpawn);
- }
- else if(code.equals("v1_14_R1"))
- {
- return NMSCreator141.createWorld(creator, loadSpawn);
- }
- }
- catch(Throwable e)
- {
+ catch(Throwable e)
+ {
+ }
}
return Bukkit.createWorld(creator);
diff --git a/src/main/java/com/volmit/iris/manager/ProjectManager.java b/src/main/java/com/volmit/iris/manager/ProjectManager.java
index 593011cc9..014af067d 100644
--- a/src/main/java/com/volmit/iris/manager/ProjectManager.java
+++ b/src/main/java/com/volmit/iris/manager/ProjectManager.java
@@ -66,6 +66,91 @@ public class ProjectManager
}
}
+ public IrisDimension installIntoWorld(MortarSender sender, String type, File folder)
+ {
+ sender.sendMessage("Looking for Package: " + type);
+ File iris = new File(folder, "iris");
+ IrisDimension dim = Iris.globaldata.getDimensionLoader().load(type);
+
+ if(dim == null)
+ {
+ for(File i : Iris.proj.getWorkspaceFolder().listFiles())
+ {
+ if(i.isFile() && i.getName().equals(type + ".iris"))
+ {
+ sender.sendMessage("Found " + type + ".iris in " + ProjectManager.workspaceName + " folder");
+ ZipUtil.unpack(i, iris);
+ break;
+ }
+ }
+ }
+
+ else
+ {
+ sender.sendMessage("Found " + type + " dimension in " + ProjectManager.workspaceName + " folder. Repackaging");
+ ZipUtil.unpack(Iris.proj.compilePackage(sender, type, true, true), iris);
+ }
+
+ File dimf = new File(iris, "dimensions/" + type + ".json");
+
+ if(!dimf.exists() || !dimf.isFile())
+ {
+ Iris.globaldata.dump();
+ Iris.globaldata.preferFolder(null);
+ Iris.proj.downloadSearch(sender, type, false);
+ File downloaded = Iris.proj.getWorkspaceFolder(type);
+
+ for(File i : downloaded.listFiles())
+ {
+ if(i.isFile())
+ {
+ try
+ {
+ FileUtils.copyFile(i, new File(iris, i.getName()));
+ }
+
+ catch(IOException e)
+ {
+ e.printStackTrace();
+ }
+ }
+
+ else
+ {
+ try
+ {
+ FileUtils.copyDirectory(i, new File(iris, i.getName()));
+ }
+
+ catch(IOException e)
+ {
+ e.printStackTrace();
+ }
+ }
+ }
+
+ IO.delete(downloaded);
+ }
+
+ if(!dimf.exists() || !dimf.isFile())
+ {
+ sender.sendMessage("Can't find the " + dimf.getName() + " in the dimensions folder of this pack! Failed!");
+ return null;
+ }
+
+ IrisDataManager dm = new IrisDataManager(folder);
+ dim = dm.getDimensionLoader().load(type);
+
+ if(dim == null)
+ {
+ sender.sendMessage("Can't load the dimension! Failed!");
+ return null;
+ }
+
+ sender.sendMessage(folder.getName() + " type installed. ");
+ return dim;
+ }
+
public void downloadSearch(MortarSender sender, String key, boolean trim)
{
String repo = getListing(false).get(key);
diff --git a/src/main/java/com/volmit/iris/util/PregenJob.java b/src/main/java/com/volmit/iris/util/PregenJob.java
index bcb28abce..ecbd9b3bf 100644
--- a/src/main/java/com/volmit/iris/util/PregenJob.java
+++ b/src/main/java/com/volmit/iris/util/PregenJob.java
@@ -182,7 +182,7 @@ public class PregenJob implements Listener
{
chunkSpiraler.next();
- if(isChunkWithin(chunkX, chunkZ))
+ if(isChunkWithin(chunkX, chunkZ) && consumer != null)
{
consumer.accept(new ChunkPosition(chunkX, chunkZ), Color.BLUE.darker().darker());
}