Allow disabling of 1.6.3 structure saving. Use with caution!
This commit is contained in:
parent
4edd7598b8
commit
e116075866
2 changed files with 271 additions and 1 deletions
|
@ -1,4 +1,4 @@
|
|||
From fa744ba52455d9b4bd030e6b23d6cf4fb294621a Mon Sep 17 00:00:00 2001
|
||||
From 622fdf26e1855df13627894f8a637ff21ca8dd12 Mon Sep 17 00:00:00 2001
|
||||
From: md_5 <md_5@live.com.au>
|
||||
Date: Tue, 2 Jul 2013 13:13:29 +1000
|
||||
Subject: [PATCH] mc-dev imports
|
||||
|
@ -784,6 +784,228 @@ index 0000000..900ed68
|
|||
+ return regionfile.b(i & 31, j & 31);
|
||||
+ }
|
||||
+}
|
||||
diff --git a/src/main/java/net/minecraft/server/StructureGenerator.java b/src/main/java/net/minecraft/server/StructureGenerator.java
|
||||
new file mode 100644
|
||||
index 0000000..ab4dc19
|
||||
--- /dev/null
|
||||
+++ b/src/main/java/net/minecraft/server/StructureGenerator.java
|
||||
@@ -0,0 +1,216 @@
|
||||
+package net.minecraft.server;
|
||||
+
|
||||
+import java.util.HashMap;
|
||||
+import java.util.Iterator;
|
||||
+import java.util.List;
|
||||
+import java.util.Map;
|
||||
+import java.util.Random;
|
||||
+import java.util.concurrent.Callable;
|
||||
+
|
||||
+public abstract class StructureGenerator extends WorldGenBase {
|
||||
+
|
||||
+ private WorldGenFeature e;
|
||||
+ protected Map d = new HashMap();
|
||||
+
|
||||
+ public StructureGenerator() {}
|
||||
+
|
||||
+ public abstract String a();
|
||||
+
|
||||
+ protected final void a(World world, int i, int j, int k, int l, byte[] abyte) {
|
||||
+ this.a(world);
|
||||
+ if (!this.d.containsKey(Long.valueOf(ChunkCoordIntPair.a(i, j)))) {
|
||||
+ this.b.nextInt();
|
||||
+
|
||||
+ try {
|
||||
+ if (this.a(i, j)) {
|
||||
+ StructureStart structurestart = this.b(i, j);
|
||||
+
|
||||
+ this.d.put(Long.valueOf(ChunkCoordIntPair.a(i, j)), structurestart);
|
||||
+ this.a(i, j, structurestart);
|
||||
+ }
|
||||
+ } catch (Throwable throwable) {
|
||||
+ CrashReport crashreport = CrashReport.a(throwable, "Exception preparing structure feature");
|
||||
+ CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Feature being prepared");
|
||||
+
|
||||
+ crashreportsystemdetails.a("Is feature chunk", (Callable) (new CrashReportIsFeatureChunk(this, i, j)));
|
||||
+ crashreportsystemdetails.a("Chunk location", String.format("%d,%d", new Object[] { Integer.valueOf(i), Integer.valueOf(j)}));
|
||||
+ crashreportsystemdetails.a("Chunk pos hash", (Callable) (new CrashReportChunkPosHash(this, i, j)));
|
||||
+ crashreportsystemdetails.a("Structure type", (Callable) (new CrashReportStructureType(this)));
|
||||
+ throw new ReportedException(crashreport);
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ public boolean a(World world, Random random, int i, int j) {
|
||||
+ this.a(world);
|
||||
+ int k = (i << 4) + 8;
|
||||
+ int l = (j << 4) + 8;
|
||||
+ boolean flag = false;
|
||||
+ Iterator iterator = this.d.values().iterator();
|
||||
+
|
||||
+ while (iterator.hasNext()) {
|
||||
+ StructureStart structurestart = (StructureStart) iterator.next();
|
||||
+
|
||||
+ if (structurestart.d() && structurestart.a().a(k, l, k + 15, l + 15)) {
|
||||
+ structurestart.a(world, random, new StructureBoundingBox(k, l, k + 15, l + 15));
|
||||
+ flag = true;
|
||||
+ this.a(structurestart.e(), structurestart.f(), structurestart);
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ return flag;
|
||||
+ }
|
||||
+
|
||||
+ public boolean b(int i, int j, int k) {
|
||||
+ this.a(this.c);
|
||||
+ return this.c(i, j, k) != null;
|
||||
+ }
|
||||
+
|
||||
+ protected StructureStart c(int i, int j, int k) {
|
||||
+ Iterator iterator = this.d.values().iterator();
|
||||
+
|
||||
+ while (iterator.hasNext()) {
|
||||
+ StructureStart structurestart = (StructureStart) iterator.next();
|
||||
+
|
||||
+ if (structurestart.d() && structurestart.a().a(i, k, i, k)) {
|
||||
+ Iterator iterator1 = structurestart.b().iterator();
|
||||
+
|
||||
+ while (iterator1.hasNext()) {
|
||||
+ StructurePiece structurepiece = (StructurePiece) iterator1.next();
|
||||
+
|
||||
+ if (structurepiece.c().b(i, j, k)) {
|
||||
+ return structurestart;
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ return null;
|
||||
+ }
|
||||
+
|
||||
+ public boolean d(int i, int j, int k) {
|
||||
+ this.a(this.c);
|
||||
+ Iterator iterator = this.d.values().iterator();
|
||||
+
|
||||
+ StructureStart structurestart;
|
||||
+
|
||||
+ do {
|
||||
+ if (!iterator.hasNext()) {
|
||||
+ return false;
|
||||
+ }
|
||||
+
|
||||
+ structurestart = (StructureStart) iterator.next();
|
||||
+ } while (!structurestart.d());
|
||||
+
|
||||
+ return structurestart.a().a(i, k, i, k);
|
||||
+ }
|
||||
+
|
||||
+ public ChunkPosition getNearestGeneratedFeature(World world, int i, int j, int k) {
|
||||
+ this.c = world;
|
||||
+ this.a(world);
|
||||
+ this.b.setSeed(world.getSeed());
|
||||
+ long l = this.b.nextLong();
|
||||
+ long i1 = this.b.nextLong();
|
||||
+ long j1 = (long) (i >> 4) * l;
|
||||
+ long k1 = (long) (k >> 4) * i1;
|
||||
+
|
||||
+ this.b.setSeed(j1 ^ k1 ^ world.getSeed());
|
||||
+ this.a(world, i >> 4, k >> 4, 0, 0, (byte[]) null);
|
||||
+ double d0 = Double.MAX_VALUE;
|
||||
+ ChunkPosition chunkposition = null;
|
||||
+ Iterator iterator = this.d.values().iterator();
|
||||
+
|
||||
+ ChunkPosition chunkposition1;
|
||||
+ int l1;
|
||||
+ int i2;
|
||||
+ double d1;
|
||||
+ int j2;
|
||||
+
|
||||
+ while (iterator.hasNext()) {
|
||||
+ StructureStart structurestart = (StructureStart) iterator.next();
|
||||
+
|
||||
+ if (structurestart.d()) {
|
||||
+ StructurePiece structurepiece = (StructurePiece) structurestart.b().get(0);
|
||||
+
|
||||
+ chunkposition1 = structurepiece.a();
|
||||
+ i2 = chunkposition1.x - i;
|
||||
+ l1 = chunkposition1.y - j;
|
||||
+ j2 = chunkposition1.z - k;
|
||||
+ d1 = (double) (i2 * i2 + l1 * l1 + j2 * j2);
|
||||
+ if (d1 < d0) {
|
||||
+ d0 = d1;
|
||||
+ chunkposition = chunkposition1;
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ if (chunkposition != null) {
|
||||
+ return chunkposition;
|
||||
+ } else {
|
||||
+ List list = this.p_();
|
||||
+
|
||||
+ if (list != null) {
|
||||
+ ChunkPosition chunkposition2 = null;
|
||||
+ Iterator iterator1 = list.iterator();
|
||||
+
|
||||
+ while (iterator1.hasNext()) {
|
||||
+ chunkposition1 = (ChunkPosition) iterator1.next();
|
||||
+ i2 = chunkposition1.x - i;
|
||||
+ l1 = chunkposition1.y - j;
|
||||
+ j2 = chunkposition1.z - k;
|
||||
+ d1 = (double) (i2 * i2 + l1 * l1 + j2 * j2);
|
||||
+ if (d1 < d0) {
|
||||
+ d0 = d1;
|
||||
+ chunkposition2 = chunkposition1;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ return chunkposition2;
|
||||
+ } else {
|
||||
+ return null;
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ protected List p_() {
|
||||
+ return null;
|
||||
+ }
|
||||
+
|
||||
+ private void a(World world) {
|
||||
+ if (this.e == null) {
|
||||
+ this.e = (WorldGenFeature) world.a(WorldGenFeature.class, this.a());
|
||||
+ if (this.e == null) {
|
||||
+ this.e = new WorldGenFeature(this.a());
|
||||
+ world.a(this.a(), (WorldMapBase) this.e);
|
||||
+ } else {
|
||||
+ NBTTagCompound nbttagcompound = this.e.a();
|
||||
+ Iterator iterator = nbttagcompound.c().iterator();
|
||||
+
|
||||
+ while (iterator.hasNext()) {
|
||||
+ NBTBase nbtbase = (NBTBase) iterator.next();
|
||||
+
|
||||
+ if (nbtbase.getTypeId() == 10) {
|
||||
+ NBTTagCompound nbttagcompound1 = (NBTTagCompound) nbtbase;
|
||||
+
|
||||
+ if (nbttagcompound1.hasKey("ChunkX") && nbttagcompound1.hasKey("ChunkZ")) {
|
||||
+ int i = nbttagcompound1.getInt("ChunkX");
|
||||
+ int j = nbttagcompound1.getInt("ChunkZ");
|
||||
+ StructureStart structurestart = WorldGenFactory.a(nbttagcompound1, world);
|
||||
+
|
||||
+ this.d.put(Long.valueOf(ChunkCoordIntPair.a(i, j)), structurestart);
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ private void a(int i, int j, StructureStart structurestart) {
|
||||
+ this.e.a(structurestart.a(i, j), i, j);
|
||||
+ this.e.c();
|
||||
+ }
|
||||
+
|
||||
+ protected abstract boolean a(int i, int j);
|
||||
+
|
||||
+ protected abstract StructureStart b(int i, int j);
|
||||
+}
|
||||
--
|
||||
1.8.1.2
|
||||
|
||||
|
|
|
@ -0,0 +1,48 @@
|
|||
From 6aa4aae7c4df947c6495129a665462324da1f45e Mon Sep 17 00:00:00 2001
|
||||
From: md_5 <md_5@live.com.au>
|
||||
Date: Sat, 21 Sep 2013 12:33:09 +1000
|
||||
Subject: [PATCH] Allow Disabling of 1.6.3 Structure Saving
|
||||
|
||||
|
||||
diff --git a/src/main/java/net/minecraft/server/StructureGenerator.java b/src/main/java/net/minecraft/server/StructureGenerator.java
|
||||
index ab4dc19..8fe8c13 100644
|
||||
--- a/src/main/java/net/minecraft/server/StructureGenerator.java
|
||||
+++ b/src/main/java/net/minecraft/server/StructureGenerator.java
|
||||
@@ -178,7 +178,12 @@ public abstract class StructureGenerator extends WorldGenBase {
|
||||
|
||||
private void a(World world) {
|
||||
if (this.e == null) {
|
||||
- this.e = (WorldGenFeature) world.a(WorldGenFeature.class, this.a());
|
||||
+ // Spigot Start
|
||||
+ if ( world.spigotConfig.saveStructureInfo )
|
||||
+ {
|
||||
+ this.e = (WorldGenFeature) world.a( WorldGenFeature.class, this.a() );
|
||||
+ }
|
||||
+ // Spigot End
|
||||
if (this.e == null) {
|
||||
this.e = new WorldGenFeature(this.a());
|
||||
world.a(this.a(), (WorldMapBase) this.e);
|
||||
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
||||
index 2caafa2..a34670e 100644
|
||||
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
||||
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
||||
@@ -207,4 +207,16 @@ public class SpigotWorldConfig
|
||||
randomLightUpdates = getBoolean( "random-light-updates", false );
|
||||
log( "Random Lighting Updates: " + randomLightUpdates );
|
||||
}
|
||||
+
|
||||
+ public boolean saveStructureInfo;
|
||||
+ private void structureInfo()
|
||||
+ {
|
||||
+ saveStructureInfo = getBoolean( "save-structure-info", true );
|
||||
+ log( "Structure Info Saving: " + saveStructureInfo );
|
||||
+ if ( !saveStructureInfo )
|
||||
+ {
|
||||
+ log( "*** WARNING *** You have selected to NOT save structure info. This may cause structures such as fortresses to not spawn mobs when updating to 1.7!" );
|
||||
+ log( "*** WARNING *** Please use this option with caution, SpigotMC is not responsible for any issues this option may cause in the future!" );
|
||||
+ }
|
||||
+ }
|
||||
}
|
||||
--
|
||||
1.8.1.2
|
||||
|
Loading…
Reference in a new issue