mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-29 16:46:45 +01:00
Fix populator random seed / algorithm differing from chunk generator
This commit is contained in:
parent
1e1259b81d
commit
7ed693dfc8
@ -49,7 +49,7 @@ public abstract class BukkitPlotGenerator extends ChunkGenerator {
|
|||||||
public int Z;
|
public int Z;
|
||||||
private boolean loaded = false;
|
private boolean loaded = false;
|
||||||
private short[][] result;
|
private short[][] result;
|
||||||
private final PseudoRandom random = new PseudoRandom();
|
public final PseudoRandom random = new PseudoRandom();
|
||||||
|
|
||||||
public BukkitPlotGenerator(final String world) {
|
public BukkitPlotGenerator(final String world) {
|
||||||
WorldEvents.lastWorld = world;
|
WorldEvents.lastWorld = world;
|
||||||
|
@ -17,7 +17,7 @@ import com.intellectualcrafters.plot.util.SetBlockQueue;
|
|||||||
|
|
||||||
public abstract class BukkitPlotPopulator extends BlockPopulator {
|
public abstract class BukkitPlotPopulator extends BlockPopulator {
|
||||||
|
|
||||||
private final PseudoRandom random = new PseudoRandom();
|
public final PseudoRandom random = new PseudoRandom();
|
||||||
|
|
||||||
public int X;
|
public int X;
|
||||||
public int Z;
|
public int Z;
|
||||||
@ -29,8 +29,15 @@ public abstract class BukkitPlotPopulator extends BlockPopulator {
|
|||||||
try {
|
try {
|
||||||
this.chunk = chunk;
|
this.chunk = chunk;
|
||||||
worldname = world.getName();
|
worldname = world.getName();
|
||||||
X = this.chunk.getX() << 4;
|
int cx = this.chunk.getX();
|
||||||
Z = this.chunk.getZ() << 4;
|
int cz = this.chunk.getZ();
|
||||||
|
X = cx << 4;
|
||||||
|
Z = cz << 4;
|
||||||
|
final int prime = 13;
|
||||||
|
int h = 1;
|
||||||
|
h = (prime * h) + cx;
|
||||||
|
h = (prime * h) + cz;
|
||||||
|
random.state = h;
|
||||||
if (ChunkManager.FORCE_PASTE) {
|
if (ChunkManager.FORCE_PASTE) {
|
||||||
for (short x = 0; x < 16; x++) {
|
for (short x = 0; x < 16; x++) {
|
||||||
for (short z = 0; z < 16; z++) {
|
for (short z = 0; z < 16; z++) {
|
||||||
@ -43,7 +50,7 @@ public abstract class BukkitPlotPopulator extends BlockPopulator {
|
|||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
populate(world, ChunkManager.CURRENT_PLOT_CLEAR, random, X, Z);
|
populate(world, ChunkManager.CURRENT_PLOT_CLEAR, random, cx, cz);
|
||||||
if (ChunkManager.CURRENT_PLOT_CLEAR != null) {
|
if (ChunkManager.CURRENT_PLOT_CLEAR != null) {
|
||||||
PlotLoc loc;
|
PlotLoc loc;
|
||||||
for (final Entry<PlotLoc, HashMap<Short, Byte>> entry : ChunkManager.GENERATE_DATA.entrySet()) {
|
for (final Entry<PlotLoc, HashMap<Short, Byte>> entry : ChunkManager.GENERATE_DATA.entrySet()) {
|
||||||
@ -96,6 +103,14 @@ public abstract class BukkitPlotPopulator extends BlockPopulator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setBlock(final short x, final short y, final short z, final byte[] datas) {
|
||||||
|
if (datas.length == 1) {
|
||||||
|
setBlock(x, y, z, datas[0]);
|
||||||
|
} else {
|
||||||
|
setBlock(x, y, z, datas[random.random(datas.length)]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Like setblock, but lacks the data != 0 check
|
* Like setblock, but lacks the data != 0 check
|
||||||
* @param x
|
* @param x
|
||||||
|
@ -131,7 +131,7 @@ public class HybridGen extends BukkitPlotGenerator {
|
|||||||
for (int i = 0; i < cached.length; i++) {
|
for (int i = 0; i < cached.length; i++) {
|
||||||
cached[i] = new short[4096];
|
cached[i] = new short[4096];
|
||||||
}
|
}
|
||||||
final PseudoRandom random = new PseudoRandom();
|
random.state = 7919;
|
||||||
for (int x = 0; x < 16; x++) {
|
for (int x = 0; x < 16; x++) {
|
||||||
for (int z = 0; z < 16; z++) {
|
for (int z = 0; z < 16; z++) {
|
||||||
cached[CACHE_I[plotheight][x][z]][CACHE_J[plotheight][x][z]] = plotfloors[random.random(plotfloors.length)];
|
cached[CACHE_I[plotheight][x][z]][CACHE_J[plotheight][x][z]] = plotfloors[random.random(plotfloors.length)];
|
||||||
@ -209,22 +209,16 @@ public class HybridGen extends BukkitPlotGenerator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (plotworld.PLOT_BEDROCK) {
|
|
||||||
for (short x = 0; x < 16; x++) {
|
|
||||||
for (short z = 0; z < 16; z++) {
|
|
||||||
setBlock(x, 0, z, (short) 7);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (region != null) {
|
if (region != null) {
|
||||||
for (short x = 0; x < 16; x++) {
|
for (short x = 0; x < 16; x++) {
|
||||||
final int absX = ((sx + x) % size);
|
final int absX = ((sx + x) % size);
|
||||||
for (short z = 0; z < 16; z++) {
|
for (short z = 0; z < 16; z++) {
|
||||||
if (contains(region, x, z)) {
|
if (contains(region, x, z)) {
|
||||||
|
setBlock(x, 0, z, (short) 7);
|
||||||
|
setBlock(x, plotheight, z, plotfloors);
|
||||||
for (short y = 1; y < plotheight; y++) {
|
for (short y = 1; y < plotheight; y++) {
|
||||||
setBlock(x, y, z, filling);
|
setBlock(x, y, z, filling);
|
||||||
}
|
}
|
||||||
setBlock(x, plotheight, z, plotfloors);
|
|
||||||
final int absZ = ((sz + z) % size);
|
final int absZ = ((sz + z) % size);
|
||||||
final PlotLoc loc = new PlotLoc(absX, absZ);
|
final PlotLoc loc = new PlotLoc(absX, absZ);
|
||||||
final HashMap<Short, Short> blocks = plotworld.G_SCH.get(loc);
|
final HashMap<Short, Short> blocks = plotworld.G_SCH.get(loc);
|
||||||
@ -239,6 +233,14 @@ public class HybridGen extends BukkitPlotGenerator {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (plotworld.PLOT_BEDROCK) {
|
||||||
|
for (short x = 0; x < 16; x++) {
|
||||||
|
for (short z = 0; z < 16; z++) {
|
||||||
|
setBlock(x, 0, z, (short) 7);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for (short x = 0; x < 16; x++) {
|
for (short x = 0; x < 16; x++) {
|
||||||
final int absX = ((sx + x) % size);
|
final int absX = ((sx + x) % size);
|
||||||
final boolean gx = absX > pathWidthLower;
|
final boolean gx = absX > pathWidthLower;
|
||||||
@ -249,10 +251,10 @@ public class HybridGen extends BukkitPlotGenerator {
|
|||||||
final boolean lz = absZ < pathWidthUpper;
|
final boolean lz = absZ < pathWidthUpper;
|
||||||
// inside plot
|
// inside plot
|
||||||
if (gx && gz && lx && lz) {
|
if (gx && gz && lx && lz) {
|
||||||
|
setBlock(x, plotheight, z, plotfloors);
|
||||||
for (short y = 1; y < plotheight; y++) {
|
for (short y = 1; y < plotheight; y++) {
|
||||||
setBlock(x, y, z, filling);
|
setBlock(x, y, z, filling);
|
||||||
}
|
}
|
||||||
setBlock(x, plotheight, z, plotfloors);
|
|
||||||
if (plotworld.PLOT_SCHEMATIC) {
|
if (plotworld.PLOT_SCHEMATIC) {
|
||||||
final PlotLoc loc = new PlotLoc(absX, absZ);
|
final PlotLoc loc = new PlotLoc(absX, absZ);
|
||||||
final HashMap<Short, Short> blocks = plotworld.G_SCH.get(loc);
|
final HashMap<Short, Short> blocks = plotworld.G_SCH.get(loc);
|
||||||
|
@ -38,9 +38,9 @@ public class HybridPop extends BukkitPlotPopulator {
|
|||||||
final short pathWidthUpper;
|
final short pathWidthUpper;
|
||||||
private final HybridPlotWorld plotworld;
|
private final HybridPlotWorld plotworld;
|
||||||
Biome biome;
|
Biome biome;
|
||||||
private long state;
|
|
||||||
private boolean doFilling = false;
|
private boolean doFilling = false;
|
||||||
private boolean doFloor = false;
|
private boolean doFloor = false;
|
||||||
|
private boolean cached;
|
||||||
|
|
||||||
public HybridPop(final PlotWorld pw) {
|
public HybridPop(final PlotWorld pw) {
|
||||||
plotworld = (HybridPlotWorld) pw;
|
plotworld = (HybridPlotWorld) pw;
|
||||||
@ -84,24 +84,10 @@ public class HybridPop extends BukkitPlotPopulator {
|
|||||||
}
|
}
|
||||||
pathWidthUpper = (short) (pathWidthLower + plotsize + 1);
|
pathWidthUpper = (short) (pathWidthLower + plotsize + 1);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
public final long nextLong() {
|
if (!this.plotworld.PLOT_SCHEMATIC) {
|
||||||
final long a = state;
|
this.cached = true;
|
||||||
state = xorShift64(a);
|
}
|
||||||
return a;
|
|
||||||
}
|
|
||||||
|
|
||||||
public final long xorShift64(long a) {
|
|
||||||
a ^= (a << 21);
|
|
||||||
a ^= (a >>> 35);
|
|
||||||
a ^= (a << 4);
|
|
||||||
return a;
|
|
||||||
}
|
|
||||||
|
|
||||||
public final int random(final int n) {
|
|
||||||
final long result = ((nextLong() >>> 32) * n) >> 32;
|
|
||||||
return (int) result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -116,18 +102,25 @@ public class HybridPop extends BukkitPlotPopulator {
|
|||||||
sz += size;
|
sz += size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cached) {
|
||||||
|
if ((sx > pathWidthLower) && (sz > pathWidthLower) && ((sx + 15) < pathWidthUpper) && ((sz + 15) < pathWidthUpper)) {
|
||||||
|
random.state = 7919;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (requiredRegion != null) {
|
if (requiredRegion != null) {
|
||||||
|
if (!doFloor && !doFilling && plotworld.G_SCH_STATE == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
for (short x = 0; x < 16; x++) {
|
for (short x = 0; x < 16; x++) {
|
||||||
for (short z = 0; z < 16; z++) {
|
for (short z = 0; z < 16; z++) {
|
||||||
if (contains(requiredRegion, x, z)) {
|
if (contains(requiredRegion, x, z)) {
|
||||||
|
setBlock(x, (short) plotheight, z, plotfloors);
|
||||||
if (doFilling) {
|
if (doFilling) {
|
||||||
for (short y = 1; y < plotheight; y++) {
|
for (short y = 1; y < plotheight; y++) {
|
||||||
setBlock(x, y, z, filling);
|
setBlock(x, y, z, filling);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (doFloor) {
|
|
||||||
setBlock(x, (short) plotheight, z, plotfloors);
|
|
||||||
}
|
|
||||||
if (plotworld.PLOT_SCHEMATIC) {
|
if (plotworld.PLOT_SCHEMATIC) {
|
||||||
final int absX = ((sx + x) % size);
|
final int absX = ((sx + x) % size);
|
||||||
final int absZ = ((sz + z) % size);
|
final int absZ = ((sz + z) % size);
|
||||||
@ -154,19 +147,19 @@ public class HybridPop extends BukkitPlotPopulator {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (short x = 0; x < 16; x++) {
|
for (short x = 0; x < 16; x++) {
|
||||||
|
final int absX = ((sx + x) % size);
|
||||||
|
final boolean gx = absX > pathWidthLower;
|
||||||
|
final boolean lx = absX < pathWidthUpper;
|
||||||
for (short z = 0; z < 16; z++) {
|
for (short z = 0; z < 16; z++) {
|
||||||
final int absX = ((sx + x) % size);
|
|
||||||
final int absZ = ((sz + z) % size);
|
final int absZ = ((sz + z) % size);
|
||||||
final boolean gx = absX > pathWidthLower;
|
|
||||||
final boolean gz = absZ > pathWidthLower;
|
final boolean gz = absZ > pathWidthLower;
|
||||||
final boolean lx = absX < pathWidthUpper;
|
|
||||||
final boolean lz = absZ < pathWidthUpper;
|
final boolean lz = absZ < pathWidthUpper;
|
||||||
// inside plot
|
// inside plot
|
||||||
if (gx && gz && lx && lz) {
|
if (gx && gz && lx && lz) {
|
||||||
|
setBlock(x, (short) plotheight, z, plotfloors);
|
||||||
for (short y = 1; y < plotheight; y++) {
|
for (short y = 1; y < plotheight; y++) {
|
||||||
setBlock(x, y, z, filling);
|
setBlock(x, y, z, filling);
|
||||||
}
|
}
|
||||||
setBlock(x, (short) plotheight, z, plotfloors);
|
|
||||||
if (plotworld.PLOT_SCHEMATIC) {
|
if (plotworld.PLOT_SCHEMATIC) {
|
||||||
final PlotLoc loc = new PlotLoc(absX, absZ);
|
final PlotLoc loc = new PlotLoc(absX, absZ);
|
||||||
final HashMap<Short, Byte> blocks = plotworld.G_SCH_DATA.get(loc);
|
final HashMap<Short, Byte> blocks = plotworld.G_SCH_DATA.get(loc);
|
||||||
@ -215,13 +208,4 @@ public class HybridPop extends BukkitPlotPopulator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setBlock(final short x, final short y, final short z, final byte[] blkids) {
|
|
||||||
if (blkids.length == 1) {
|
|
||||||
setBlock(x, y, z, blkids[0]);
|
|
||||||
} else {
|
|
||||||
final int i = random(blkids.length);
|
|
||||||
setBlock(x, y, z, blkids[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Binary file not shown.
Loading…
Reference in New Issue
Block a user