2019-06-25 03:47:58 +02:00
|
|
|
From 7e082ac626aa32df744ce2af177a0a497ee39d27 Mon Sep 17 00:00:00 2001
|
2019-05-06 21:30:27 +02:00
|
|
|
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
|
|
|
|
Date: Mon, 6 May 2019 12:29:24 -0700
|
|
|
|
Subject: [PATCH] Async Chunk placeholder
|
|
|
|
|
|
|
|
Until we figure out Mojang's ticket system.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2019-06-25 03:47:58 +02:00
|
|
|
index 02098b9cc2..af1f1c2d62 100644
|
2019-05-06 21:30:27 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2019-06-25 03:47:58 +02:00
|
|
|
@@ -16,6 +16,7 @@ import java.util.Objects;
|
2019-05-06 21:30:27 +02:00
|
|
|
import java.util.Random;
|
|
|
|
import java.util.Set;
|
|
|
|
import java.util.UUID;
|
|
|
|
+import java.util.concurrent.CompletableFuture;
|
|
|
|
import java.util.function.Predicate;
|
|
|
|
import net.minecraft.server.AxisAlignedBB;
|
|
|
|
import net.minecraft.server.BiomeBase;
|
2019-06-25 03:47:58 +02:00
|
|
|
@@ -2155,6 +2156,40 @@ public class CraftWorld implements World {
|
2019-05-06 21:30:27 +02:00
|
|
|
return (nearest == null) ? null : new Location(this, nearest.getX(), nearest.getY(), nearest.getZ());
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
2019-05-27 07:17:12 +02:00
|
|
|
+ private Chunk getChunkAtGen(int x, int z, boolean gen) {
|
|
|
|
+ // copied from loadChunk()
|
|
|
|
+ // this function is identical except we do not add a plugin ticket
|
|
|
|
+ IChunkAccess chunk = world.getChunkProvider().getChunkAt(x, z, gen || isChunkGenerated(x, z) ? ChunkStatus.FULL : ChunkStatus.EMPTY, true);
|
|
|
|
+
|
|
|
|
+ // If generate = false, but the chunk already exists, we will get this back.
|
|
|
|
+ if (chunk instanceof ProtoChunkExtension) {
|
|
|
|
+ // We then cycle through again to get the full chunk immediately, rather than after the ticket addition
|
|
|
|
+ chunk = world.getChunkProvider().getChunkAt(x, z, ChunkStatus.FULL, true);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (chunk instanceof net.minecraft.server.Chunk) {
|
|
|
|
+ return ((net.minecraft.server.Chunk)chunk).bukkitChunk;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return null;
|
|
|
|
+ }
|
2019-05-06 21:30:27 +02:00
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public CompletableFuture<Chunk> getChunkAtAsync(int x, int z, boolean gen) {
|
|
|
|
+ // TODO placeholder
|
2019-05-27 07:17:12 +02:00
|
|
|
+ if (Bukkit.isPrimaryThread()) {
|
|
|
|
+ return CompletableFuture.completedFuture(getChunkAtGen(x, z, gen));
|
|
|
|
+ } else {
|
|
|
|
+ CompletableFuture<Chunk> ret = new CompletableFuture<>();
|
|
|
|
+ net.minecraft.server.MinecraftServer.getServer().scheduleOnMain(() -> {
|
|
|
|
+ ret.complete(getChunkAtGen(x, z, gen));
|
|
|
|
+ });
|
|
|
|
+ return ret;
|
|
|
|
+ }
|
2019-05-06 21:30:27 +02:00
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
// Spigot start
|
|
|
|
private final Spigot spigot = new Spigot()
|
|
|
|
{
|
|
|
|
--
|
2019-06-16 12:15:21 +02:00
|
|
|
2.22.0
|
2019-05-06 21:30:27 +02:00
|
|
|
|