aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0745-Allow-delegation-to-vanilla-chunk-gen.patch
diff options
context:
space:
mode:
authorSpottedleaf <[email protected]>2023-06-08 16:21:20 -0700
committerSpottedleaf <[email protected]>2023-06-08 16:21:20 -0700
commit902691b636614df08ba407823109b44be47f2277 (patch)
treed81004f9582a0eef33672278697d7fad798e84b2 /patches/server/0745-Allow-delegation-to-vanilla-chunk-gen.patch
parent619d7c93d80c4fecf7b3db9f2750e44a0ce611d2 (diff)
downloadPaper-902691b636614df08ba407823109b44be47f2277.tar.gz
Paper-902691b636614df08ba407823109b44be47f2277.zip
Apply last patch
Diffstat (limited to 'patches/server/0745-Allow-delegation-to-vanilla-chunk-gen.patch')
-rw-r--r--patches/server/0745-Allow-delegation-to-vanilla-chunk-gen.patch129
1 files changed, 129 insertions, 0 deletions
diff --git a/patches/server/0745-Allow-delegation-to-vanilla-chunk-gen.patch b/patches/server/0745-Allow-delegation-to-vanilla-chunk-gen.patch
new file mode 100644
index 0000000000..5fe3066574
--- /dev/null
+++ b/patches/server/0745-Allow-delegation-to-vanilla-chunk-gen.patch
@@ -0,0 +1,129 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: MiniDigger <[email protected]>
+Date: Wed, 29 Apr 2020 02:10:32 +0200
+Subject: [PATCH] Allow delegation to vanilla chunk gen
+
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+index ecd6d91ca1ddee0d0d3b6d41fb96f432273deffc..9b2f05e6d1d8e52842abaa4c92b60f7558480c70 100644
+--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
++++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+@@ -2354,6 +2354,90 @@ public final class CraftServer implements Server {
+ return new OldCraftChunkData(world.getMinHeight(), world.getMaxHeight(), handle.registryAccess().registryOrThrow(Registries.BIOME));
+ }
+
++ // Paper start
++ private static final List<net.minecraft.world.level.chunk.ChunkStatus> VANILLA_GEN_STATUSES = List.of(
++ net.minecraft.world.level.chunk.ChunkStatus.EMPTY,
++ net.minecraft.world.level.chunk.ChunkStatus.STRUCTURE_STARTS,
++ net.minecraft.world.level.chunk.ChunkStatus.STRUCTURE_REFERENCES,
++ net.minecraft.world.level.chunk.ChunkStatus.BIOMES,
++ net.minecraft.world.level.chunk.ChunkStatus.NOISE,
++ net.minecraft.world.level.chunk.ChunkStatus.SURFACE,
++ net.minecraft.world.level.chunk.ChunkStatus.CARVERS,
++ net.minecraft.world.level.chunk.ChunkStatus.LIQUID_CARVERS,
++ net.minecraft.world.level.chunk.ChunkStatus.FEATURES,
++ net.minecraft.world.level.chunk.ChunkStatus.LIGHT
++ );
++
++ @Override
++ @Deprecated(forRemoval = true)
++ public ChunkGenerator.ChunkData createVanillaChunkData(World world, int x, int z) {
++ // do bunch of vanilla shit
++ final net.minecraft.server.level.ServerLevel serverLevel = ((CraftWorld) world).getHandle();
++ final net.minecraft.core.Registry<net.minecraft.world.level.biome.Biome> biomeRegistry = serverLevel.getServer().registryAccess().registryOrThrow(net.minecraft.core.registries.Registries.BIOME);
++ final net.minecraft.world.level.chunk.ProtoChunk protoChunk = new net.minecraft.world.level.chunk.ProtoChunk(
++ new net.minecraft.world.level.ChunkPos(x, z),
++ net.minecraft.world.level.chunk.UpgradeData.EMPTY,
++ serverLevel,
++ biomeRegistry,
++ null
++ );
++
++ final net.minecraft.world.level.chunk.ChunkGenerator chunkGenerator;
++ if (serverLevel.chunkSource.getGenerator() instanceof org.bukkit.craftbukkit.generator.CustomChunkGenerator bukkit) {
++ chunkGenerator = bukkit.getDelegate();
++ } else {
++ chunkGenerator = serverLevel.chunkSource.getGenerator();
++ }
++
++ final net.minecraft.world.level.ChunkPos chunkPos = new net.minecraft.world.level.ChunkPos(x, z);
++ final net.minecraft.util.thread.ProcessorMailbox<Runnable> mailbox = net.minecraft.util.thread.ProcessorMailbox.create(
++ net.minecraft.Util.backgroundExecutor(),
++ "CraftServer#createVanillaChunkData(worldName='" + world.getName() + "', x='" + x + "', z='" + z + "')"
++ );
++ for (final net.minecraft.world.level.chunk.ChunkStatus chunkStatus : VANILLA_GEN_STATUSES) {
++ final List<net.minecraft.world.level.chunk.ChunkAccess> chunks = Lists.newArrayList();
++ final int statusRange = Math.max(1, chunkStatus.getRange());
++
++ for (int zz = chunkPos.z - statusRange; zz <= chunkPos.z + statusRange; ++zz) {
++ for (int xx = chunkPos.x - statusRange; xx <= chunkPos.x + statusRange; ++xx) {
++ if (xx == chunkPos.x && zz == chunkPos.z) {
++ chunks.add(protoChunk);
++ } else {
++ final net.minecraft.core.Holder<net.minecraft.world.level.biome.Biome> biomeHolder = serverLevel.registryAccess().registryOrThrow(net.minecraft.core.registries.Registries.BIOME).getHolderOrThrow(net.minecraft.world.level.biome.Biomes.PLAINS);
++ final net.minecraft.world.level.chunk.ChunkAccess chunk = new net.minecraft.world.level.chunk.EmptyLevelChunk(serverLevel, new net.minecraft.world.level.ChunkPos(xx, zz), biomeHolder);
++ chunks.add(chunk);
++ }
++ }
++ }
++
++ chunkStatus.generate(
++ mailbox::tell,
++ serverLevel,
++ chunkGenerator,
++ serverLevel.getStructureManager(),
++ serverLevel.chunkSource.getLightEngine(),
++ chunk -> {
++ throw new UnsupportedOperationException("Not creating full chunks here");
++ },
++ chunks,
++ true
++ ).thenAccept(either -> {
++ if (chunkStatus == net.minecraft.world.level.chunk.ChunkStatus.NOISE) {
++ either.left().ifPresent(chunk -> net.minecraft.world.level.levelgen.Heightmap.primeHeightmaps(chunk, net.minecraft.world.level.chunk.ChunkStatus.POST_FEATURES));
++ }
++ }).join();
++ }
++
++ // get empty object
++ OldCraftChunkData data = (OldCraftChunkData) this.createChunkData(world);
++ // copy over generated sections
++ data.getLights().addAll(protoChunk.getLights().toList());
++ data.setRawChunkData(protoChunk.getSections());
++ // hooray!
++ return data;
++ }
++ // Paper end
++
+ @Override
+ public BossBar createBossBar(String title, BarColor color, BarStyle style, BarFlag... flags) {
+ return new CraftBossBar(title, color, style, flags);
+diff --git a/src/main/java/org/bukkit/craftbukkit/generator/OldCraftChunkData.java b/src/main/java/org/bukkit/craftbukkit/generator/OldCraftChunkData.java
+index c23ce88cb9693291fec81a99e3a5bcb2615bb897..189a584b4b81bbc28d4c47b901b5aa6f85fb7932 100644
+--- a/src/main/java/org/bukkit/craftbukkit/generator/OldCraftChunkData.java
++++ b/src/main/java/org/bukkit/craftbukkit/generator/OldCraftChunkData.java
+@@ -23,7 +23,7 @@ import org.bukkit.material.MaterialData;
+ public final class OldCraftChunkData implements ChunkGenerator.ChunkData {
+ private final int minHeight;
+ private final int maxHeight;
+- private final LevelChunkSection[] sections;
++ private LevelChunkSection[] sections; // Paper
+ private final Registry<net.minecraft.world.level.biome.Biome> biomes;
+ private Set<BlockPos> tiles;
+ private final Set<BlockPos> lights = new HashSet<>();
+@@ -189,7 +189,13 @@ public final class OldCraftChunkData implements ChunkGenerator.ChunkData {
+ return this.tiles;
+ }
+
+- Set<BlockPos> getLights() {
++ public Set<BlockPos> getLights() { // Paper
+ return this.lights;
+ }
++
++ // Paper start
++ public void setRawChunkData(LevelChunkSection[] sections) {
++ this.sections = sections;
++ }
++ // Paper end
+ }