13
0
geforkt von Mirrors/Paper

SPIGOT-6526: World entities are not populated when plugin onEnable is called

By: md_5 <git@md-5.net>
Dieser Commit ist enthalten in:
CraftBukkit/Spigot 2021-06-13 15:05:32 +10:00
Ursprung 085885b64a
Commit d5a68b79c1
3 geänderte Dateien mit 25 neuen und 20 gelöschten Zeilen

Datei anzeigen

@ -124,7 +124,7 @@
convertable_conversionsession.convert(new IProgressUpdate() { convertable_conversionsession.convert(new IProgressUpdate() {
private long timeStamp = SystemUtils.getMonotonicMillis(); private long timeStamp = SystemUtils.getMonotonicMillis();
@@ -362,48 +422,197 @@ @@ -362,48 +422,198 @@
} }
@ -303,6 +303,7 @@
- this.loadSpawn(worldloadlistener); - this.loadSpawn(worldloadlistener);
+ for (WorldServer worldserver : this.getWorlds()) { + for (WorldServer worldserver : this.getWorlds()) {
+ this.loadSpawn(worldserver.getChunkProvider().chunkMap.progressListener, worldserver); + this.loadSpawn(worldserver.getChunkProvider().chunkMap.progressListener, worldserver);
+ worldserver.entityManager.a(); // SPIGOT-6526: Load pending entities so they are available to the API
+ this.server.getPluginManager().callEvent(new org.bukkit.event.world.WorldLoadEvent(worldserver.getWorld())); + this.server.getPluginManager().callEvent(new org.bukkit.event.world.WorldLoadEvent(worldserver.getWorld()));
+ } + }
+ +
@ -353,7 +354,7 @@
if (!iworlddataserver.p()) { if (!iworlddataserver.p()) {
try { try {
a(worldserver, iworlddataserver, generatorsettings.c(), flag); a(worldserver, iworlddataserver, generatorsettings.c(), flag);
@@ -425,31 +634,8 @@ @@ -425,31 +635,8 @@
iworlddataserver.c(true); iworlddataserver.c(true);
} }
@ -386,7 +387,7 @@
private static void a(WorldServer worldserver, IWorldDataServer iworlddataserver, boolean flag, boolean flag1) { private static void a(WorldServer worldserver, IWorldDataServer iworlddataserver, boolean flag, boolean flag1) {
if (flag1) { if (flag1) {
@@ -462,6 +648,21 @@ @@ -462,6 +649,21 @@
return biomebase.b().b(); return biomebase.b().b();
}, random); }, random);
ChunkCoordIntPair chunkcoordintpair = blockposition == null ? new ChunkCoordIntPair(0, 0) : new ChunkCoordIntPair(blockposition); ChunkCoordIntPair chunkcoordintpair = blockposition == null ? new ChunkCoordIntPair(0, 0) : new ChunkCoordIntPair(blockposition);
@ -408,7 +409,7 @@
if (blockposition == null) { if (blockposition == null) {
MinecraftServer.LOGGER.warn("Unable to find spawn biome"); MinecraftServer.LOGGER.warn("Unable to find spawn biome");
@@ -536,8 +737,15 @@ @@ -536,8 +738,15 @@
iworlddataserver.setGameType(EnumGamemode.SPECTATOR); iworlddataserver.setGameType(EnumGamemode.SPECTATOR);
} }
@ -426,7 +427,7 @@
MinecraftServer.LOGGER.info("Preparing start region for dimension {}", worldserver.getDimensionKey().a()); MinecraftServer.LOGGER.info("Preparing start region for dimension {}", worldserver.getDimensionKey().a());
BlockPosition blockposition = worldserver.getSpawn(); BlockPosition blockposition = worldserver.getSpawn();
@@ -550,16 +758,20 @@ @@ -550,16 +759,20 @@
chunkproviderserver.addTicket(TicketType.START, new ChunkCoordIntPair(blockposition), 11, Unit.INSTANCE); chunkproviderserver.addTicket(TicketType.START, new ChunkCoordIntPair(blockposition), 11, Unit.INSTANCE);
while (chunkproviderserver.b() != 441) { while (chunkproviderserver.b() != 441) {
@ -455,7 +456,7 @@
ForcedChunk forcedchunk = (ForcedChunk) worldserver1.getWorldPersistentData().a(ForcedChunk::b, "chunks"); ForcedChunk forcedchunk = (ForcedChunk) worldserver1.getWorldPersistentData().a(ForcedChunk::b, "chunks");
if (forcedchunk != null) { if (forcedchunk != null) {
@@ -574,11 +786,18 @@ @@ -574,11 +787,18 @@
} }
} }
@ -477,7 +478,7 @@
} }
protected void loadResourcesZip() { protected void loadResourcesZip() {
@@ -623,12 +842,16 @@ @@ -623,12 +843,16 @@
worldserver.save((IProgressUpdate) null, flag1, worldserver.noSave && !flag2); worldserver.save((IProgressUpdate) null, flag1, worldserver.noSave && !flag2);
} }
@ -494,7 +495,7 @@
return flag3; return flag3;
} }
@@ -637,8 +860,29 @@ @@ -637,8 +861,29 @@
this.stop(); this.stop();
} }
@ -524,7 +525,7 @@
if (this.getServerConnection() != null) { if (this.getServerConnection() != null) {
this.getServerConnection().b(); this.getServerConnection().b();
} }
@@ -647,6 +891,7 @@ @@ -647,6 +892,7 @@
MinecraftServer.LOGGER.info("Saving players"); MinecraftServer.LOGGER.info("Saving players");
this.playerList.savePlayers(); this.playerList.savePlayers();
this.playerList.shutdown(); this.playerList.shutdown();
@ -532,7 +533,7 @@
} }
MinecraftServer.LOGGER.info("Saving worlds"); MinecraftServer.LOGGER.info("Saving worlds");
@@ -724,9 +969,10 @@ @@ -724,9 +970,10 @@
while (this.running) { while (this.running) {
long i = SystemUtils.getMonotonicMillis() - this.nextTickTime; long i = SystemUtils.getMonotonicMillis() - this.nextTickTime;
@ -544,7 +545,7 @@
MinecraftServer.LOGGER.warn("Can't keep up! Is the server overloaded? Running {}ms or {} ticks behind", i, j); MinecraftServer.LOGGER.warn("Can't keep up! Is the server overloaded? Running {}ms or {} ticks behind", i, j);
this.nextTickTime += j * 50L; this.nextTickTime += j * 50L;
this.lastOverloadWarning = this.nextTickTime; this.lastOverloadWarning = this.nextTickTime;
@@ -737,6 +983,7 @@ @@ -737,6 +984,7 @@
this.debugCommandProfiler = new MinecraftServer.a(SystemUtils.getMonotonicNanos(), this.tickCount); this.debugCommandProfiler = new MinecraftServer.a(SystemUtils.getMonotonicNanos(), this.tickCount);
} }
@ -552,7 +553,7 @@
this.nextTickTime += 50L; this.nextTickTime += 50L;
this.bi(); this.bi();
this.profiler.enter("tick"); this.profiler.enter("tick");
@@ -782,6 +1029,12 @@ @@ -782,6 +1030,12 @@
} catch (Throwable throwable1) { } catch (Throwable throwable1) {
MinecraftServer.LOGGER.error("Exception stopping the server", throwable1); MinecraftServer.LOGGER.error("Exception stopping the server", throwable1);
} finally { } finally {
@ -565,7 +566,7 @@
this.exit(); this.exit();
} }
@@ -790,8 +1043,15 @@ @@ -790,8 +1044,15 @@
} }
private boolean canSleepForTick() { private boolean canSleepForTick() {
@ -582,7 +583,7 @@
protected void sleepForTick() { protected void sleepForTick() {
this.executeAll(); this.executeAll();
@@ -906,7 +1166,7 @@ @@ -906,7 +1167,7 @@
this.status.b().a(agameprofile); this.status.b().a(agameprofile);
} }
@ -591,7 +592,7 @@
MinecraftServer.LOGGER.debug("Autosave started"); MinecraftServer.LOGGER.debug("Autosave started");
this.profiler.enter("save"); this.profiler.enter("save");
this.playerList.savePlayers(); this.playerList.savePlayers();
@@ -936,22 +1196,39 @@ @@ -936,22 +1197,39 @@
} }
public void b(BooleanSupplier booleansupplier) { public void b(BooleanSupplier booleansupplier) {
@ -631,7 +632,7 @@
this.profiler.enter("tick"); this.profiler.enter("tick");
@@ -1040,7 +1317,7 @@ @@ -1040,7 +1318,7 @@
@DontObfuscate @DontObfuscate
public String getServerModName() { public String getServerModName() {
@ -640,7 +641,7 @@
} }
public SystemReport b(SystemReport systemreport) { public SystemReport b(SystemReport systemreport) {
@@ -1412,16 +1689,17 @@ @@ -1412,16 +1690,17 @@
public CompletableFuture<Void> a(Collection<String> collection) { public CompletableFuture<Void> a(Collection<String> collection) {
CompletableFuture<Void> completablefuture = CompletableFuture.supplyAsync(() -> { CompletableFuture<Void> completablefuture = CompletableFuture.supplyAsync(() -> {
@ -660,7 +661,7 @@
this.packRepository.a(collection); this.packRepository.a(collection);
this.worldData.a(a(this.packRepository)); this.worldData.a(a(this.packRepository));
datapackresources.j(); datapackresources.j();
@@ -1766,6 +2044,22 @@ @@ -1766,6 +2045,22 @@
} }

Datei anzeigen

@ -23,15 +23,18 @@
public class WorldServer extends World implements GeneratorAccessSeed { public class WorldServer extends World implements GeneratorAccessSeed {
public static final BlockPosition END_SPAWN_POINT = new BlockPosition(100, 50, 0); public static final BlockPosition END_SPAWN_POINT = new BlockPosition(100, 50, 0);
@@ -160,7 +176,7 @@ @@ -160,9 +176,9 @@
final List<EntityPlayer> players; final List<EntityPlayer> players;
private final ChunkProviderServer chunkSource; private final ChunkProviderServer chunkSource;
private final MinecraftServer server; private final MinecraftServer server;
- public final IWorldDataServer serverLevelData; - public final IWorldDataServer serverLevelData;
+ public final WorldDataServer serverLevelData; // CraftBukkit - type + public final WorldDataServer serverLevelData; // CraftBukkit - type
final EntityTickList entityTickList; final EntityTickList entityTickList;
private final PersistentEntitySectionManager<Entity> entityManager; - private final PersistentEntitySectionManager<Entity> entityManager;
+ public final PersistentEntitySectionManager<Entity> entityManager;
public boolean noSave; public boolean noSave;
private final SleepStatus sleepStatus;
private int emptyTime;
@@ -180,31 +196,52 @@ @@ -180,31 +196,52 @@
private final StructureManager structureFeatureManager; private final StructureManager structureFeatureManager;
private final boolean tickTime; private final boolean tickTime;

Datei anzeigen

@ -1056,6 +1056,7 @@ public final class CraftServer implements Server {
console.levels.put(internal.getDimensionKey(), internal); console.levels.put(internal.getDimensionKey(), internal);
getServer().loadSpawn(internal.getChunkProvider().chunkMap.progressListener, internal); getServer().loadSpawn(internal.getChunkProvider().chunkMap.progressListener, internal);
internal.entityManager.a(); // SPIGOT-6526: Load pending entities so they are available to the API
pluginManager.callEvent(new WorldLoadEvent(internal.getWorld())); pluginManager.callEvent(new WorldLoadEvent(internal.getWorld()));
return internal.getWorld(); return internal.getWorld();