mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-22 16:31:55 +01:00
166 lines
10 KiB
Diff
166 lines
10 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Byteflux <byte@byteflux.net>
|
||
|
Date: Wed, 2 Mar 2016 02:17:54 -0600
|
||
|
Subject: [PATCH] Generator Settings
|
||
|
|
||
|
|
||
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
||
|
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
||
|
@@ -0,0 +0,0 @@ public class PaperWorldConfig {
|
||
|
private void disableRelativeProjectileVelocity() {
|
||
|
disableRelativeProjectileVelocity = getBoolean("game-mechanics.disable-relative-projectile-velocity", false);
|
||
|
}
|
||
|
+
|
||
|
+ public boolean generateFlatBedrock;
|
||
|
+ private void generatorSettings() {
|
||
|
+ generateFlatBedrock = getBoolean("generator-settings.flat-bedrock", false);
|
||
|
+ }
|
||
|
}
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/server/level/ChunkMap.java b/src/main/java/net/minecraft/server/level/ChunkMap.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/server/level/ChunkMap.java
|
||
|
+++ b/src/main/java/net/minecraft/server/level/ChunkMap.java
|
||
|
@@ -0,0 +0,0 @@ public class ChunkMap extends ChunkStorage implements ChunkHolder.PlayerProvider
|
||
|
}
|
||
|
|
||
|
this.markPositionReplaceable(pos);
|
||
|
- return Either.left(new ProtoChunk(pos, UpgradeData.EMPTY, this.level));
|
||
|
+ return Either.left(new ProtoChunk(pos, UpgradeData.EMPTY, this.level, this.level)); // Paper - add level
|
||
|
// Paper start - Async chunk io
|
||
|
};
|
||
|
CompletableFuture<Either<ChunkAccess, ChunkHolder.ChunkLoadingFailure>> ret = new CompletableFuture<>();
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/chunk/ChunkAccess.java b/src/main/java/net/minecraft/world/level/chunk/ChunkAccess.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/chunk/ChunkAccess.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/chunk/ChunkAccess.java
|
||
|
@@ -0,0 +0,0 @@ public interface ChunkAccess extends BlockGetter, FeatureAccess {
|
||
|
return GameEventDispatcher.NOOP;
|
||
|
}
|
||
|
|
||
|
+ // Paper start
|
||
|
+ default boolean generateFlatBedrock() {
|
||
|
+ if (this instanceof ProtoChunk) {
|
||
|
+ return ((ProtoChunk)this).level.paperConfig.generateFlatBedrock;
|
||
|
+ } else if (this instanceof LevelChunk) {
|
||
|
+ return ((LevelChunk)this).level.paperConfig.generateFlatBedrock;
|
||
|
+ } else {
|
||
|
+ return false;
|
||
|
+ }
|
||
|
+ }
|
||
|
+ // Paper end
|
||
|
+
|
||
|
BlockState getType(final int x, final int y, final int z); // Paper
|
||
|
@Nullable
|
||
|
BlockState setBlockState(BlockPos pos, BlockState state, boolean moved);
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/chunk/ImposterProtoChunk.java b/src/main/java/net/minecraft/world/level/chunk/ImposterProtoChunk.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/chunk/ImposterProtoChunk.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/chunk/ImposterProtoChunk.java
|
||
|
@@ -0,0 +0,0 @@ public class ImposterProtoChunk extends ProtoChunk {
|
||
|
private final LevelChunk wrapped;
|
||
|
|
||
|
public ImposterProtoChunk(LevelChunk wrapped) {
|
||
|
- super(wrapped.getPos(), UpgradeData.EMPTY, wrapped);
|
||
|
+ super(wrapped.getPos(), UpgradeData.EMPTY, wrapped, wrapped.level); // Paper - add level
|
||
|
this.wrapped = wrapped;
|
||
|
}
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/chunk/ProtoChunk.java b/src/main/java/net/minecraft/world/level/chunk/ProtoChunk.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/chunk/ProtoChunk.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/chunk/ProtoChunk.java
|
||
|
@@ -0,0 +0,0 @@ public class ProtoChunk implements ChunkAccess {
|
||
|
private long inhabitedTime;
|
||
|
private final Map<GenerationStep.Carving, BitSet> carvingMasks = new Object2ObjectArrayMap<>();
|
||
|
private volatile boolean isLightCorrect;
|
||
|
+ final net.minecraft.world.level.Level level; // Paper - Add level
|
||
|
|
||
|
- public ProtoChunk(ChunkPos pos, UpgradeData upgradeData, LevelHeightAccessor world) {
|
||
|
+ // Paper start - add level
|
||
|
+ @Deprecated public ProtoChunk(ChunkPos pos, UpgradeData upgradeData, LevelHeightAccessor world) { this(pos, upgradeData, world, null); }
|
||
|
+ public ProtoChunk(ChunkPos pos, UpgradeData upgradeData, LevelHeightAccessor world, net.minecraft.server.level.ServerLevel level) {
|
||
|
+ // Paper end
|
||
|
this(pos, upgradeData, (LevelChunkSection[])null, new ProtoTickList<>((block) -> {
|
||
|
return block == null || block.defaultBlockState().isAir();
|
||
|
}, pos, world), new ProtoTickList<>((fluid) -> {
|
||
|
return fluid == null || fluid == Fluids.EMPTY;
|
||
|
- }, pos, world), world);
|
||
|
+ }, pos, world), world, level); // Paper - add level
|
||
|
}
|
||
|
|
||
|
- public ProtoChunk(ChunkPos pos, UpgradeData upgradeData, @Nullable LevelChunkSection[] levelChunkSections, ProtoTickList<Block> blockTickScheduler, ProtoTickList<Fluid> fluidTickScheduler, LevelHeightAccessor world) {
|
||
|
+ // Paper start - add level
|
||
|
+ @Deprecated public ProtoChunk(ChunkPos pos, UpgradeData upgradeData, @Nullable LevelChunkSection[] levelChunkSections, ProtoTickList<Block> blockTickScheduler, ProtoTickList<Fluid> fluidTickScheduler, LevelHeightAccessor world) { this(pos, upgradeData, levelChunkSections, blockTickScheduler, fluidTickScheduler, world, null); }
|
||
|
+ public ProtoChunk(ChunkPos pos, UpgradeData upgradeData, @Nullable LevelChunkSection[] levelChunkSections, ProtoTickList<Block> blockTickScheduler, ProtoTickList<Fluid> fluidTickScheduler, LevelHeightAccessor world, net.minecraft.server.level.ServerLevel level) {
|
||
|
+ this.level = level;
|
||
|
+ // Paper end
|
||
|
this.chunkPos = pos;
|
||
|
this.upgradeData = upgradeData;
|
||
|
this.blockTicks = blockTickScheduler;
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
|
||
|
@@ -0,0 +0,0 @@ public class ChunkSerializer {
|
||
|
// CraftBukkit end
|
||
|
});
|
||
|
} else {
|
||
|
- ProtoChunk protochunk = new ProtoChunk(pos, chunkconverter, achunksection, protochunkticklist, protochunkticklist1, world);
|
||
|
+ ProtoChunk protochunk = new ProtoChunk(pos, chunkconverter, achunksection, protochunkticklist, protochunkticklist1, world, world); // Paper - add level
|
||
|
|
||
|
protochunk.setBiomes(biomestorage);
|
||
|
object = protochunk;
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/levelgen/NoiseBasedChunkGenerator.java b/src/main/java/net/minecraft/world/level/levelgen/NoiseBasedChunkGenerator.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/levelgen/NoiseBasedChunkGenerator.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/levelgen/NoiseBasedChunkGenerator.java
|
||
|
@@ -0,0 +0,0 @@ public final class NoiseBasedChunkGenerator extends ChunkGenerator {
|
||
|
int j = chunk.getPos().getMinBlockZ();
|
||
|
NoiseGeneratorSettings noiseGeneratorSettings = this.settings.get();
|
||
|
int k = noiseGeneratorSettings.noiseSettings().minY();
|
||
|
- int l = k + noiseGeneratorSettings.getBedrockFloorPosition();
|
||
|
- int m = this.height - 1 + k - noiseGeneratorSettings.getBedrockRoofPosition();
|
||
|
+ int l = k + noiseGeneratorSettings.getBedrockFloorPosition(); final int floorHeight = k; // Paper
|
||
|
+ int m = this.height - 1 + k - noiseGeneratorSettings.getBedrockRoofPosition(); final int roofHeight = l; // Paper
|
||
|
int n = 5;
|
||
|
int o = chunk.getMinBuildHeight();
|
||
|
int p = chunk.getMaxBuildHeight();
|
||
|
@@ -0,0 +0,0 @@ public final class NoiseBasedChunkGenerator extends ChunkGenerator {
|
||
|
for(BlockPos blockPos : BlockPos.betweenClosed(i, 0, j, i + 15, 0, j + 15)) {
|
||
|
if (bl) {
|
||
|
for(int q = 0; q < 5; ++q) {
|
||
|
- if (q <= random.nextInt(5)) {
|
||
|
+ if (q <= (chunk.generateFlatBedrock() ? roofHeight : random.nextInt(5))) { // Paper - Configurable flat bedrock roof
|
||
|
chunk.setBlockState(mutableBlockPos.set(blockPos.getX(), m - q, blockPos.getZ()), Blocks.BEDROCK.defaultBlockState(), false);
|
||
|
}
|
||
|
}
|
||
|
@@ -0,0 +0,0 @@ public final class NoiseBasedChunkGenerator extends ChunkGenerator {
|
||
|
|
||
|
if (bl2) {
|
||
|
for(int r = 4; r >= 0; --r) {
|
||
|
- if (r <= random.nextInt(5)) {
|
||
|
+ if (r <= (chunk.generateFlatBedrock() ? roofHeight : random.nextInt(5))) { // Paper - Configurable flat bedrock floor
|
||
|
chunk.setBlockState(mutableBlockPos.set(blockPos.getX(), l + r, blockPos.getZ()), Blocks.BEDROCK.defaultBlockState(), false);
|
||
|
}
|
||
|
}
|
||
|
@@ -0,0 +0,0 @@ public final class NoiseBasedChunkGenerator extends ChunkGenerator {
|
||
|
if (l <= 0) {
|
||
|
return CompletableFuture.completedFuture(chunk);
|
||
|
} else {
|
||
|
- int m = chunk.getSectionIndex(l * this.cellHeight - 1 + i);
|
||
|
+ int mStart = chunk.getSectionIndex(l * this.cellHeight - 1 + i); // Paper - decompile fix
|
||
|
int n = chunk.getSectionIndex(i);
|
||
|
return CompletableFuture.supplyAsync(() -> {
|
||
|
Set<LevelChunkSection> set = Sets.newHashSet();
|
||
|
|
||
|
ChunkAccess var16;
|
||
|
try {
|
||
|
- for(int m = m; m >= n; --m) {
|
||
|
+ for(int m = mStart; m >= n; --m) { // Paper - decompile fix
|
||
|
LevelChunkSection levelChunkSection = chunk.getOrCreateSection(m);
|
||
|
levelChunkSection.acquire();
|
||
|
set.add(levelChunkSection);
|