2022-03-02 10:21:30 +01:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2022-08-01 16:01:20 +02:00
|
|
|
From: Nassim Jahnke <nassim@njahnke.dev>
|
2022-03-02 10:21:30 +01:00
|
|
|
Date: Wed, 2 Mar 2022 09:45:56 +0100
|
|
|
|
Subject: [PATCH] Force close world loading screen
|
|
|
|
|
|
|
|
Dead players would be stuck in the world loading screen and other players may
|
|
|
|
miss messages and similar sent in the join event if chunk loading is slow.
|
|
|
|
Paper already circumvents falling through the world before chunks are loaded,
|
|
|
|
so we do not need that. The client only needs the chunk it is currently in to
|
|
|
|
be loaded to close the loading screen, so we just send an empty one.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/players/PlayerList.java b/src/main/java/net/minecraft/server/players/PlayerList.java
|
2023-09-24 08:29:07 +02:00
|
|
|
index d5d83e605a33d2edd1c7c0ef7cfa8af35e22dcc9..76e83980e96f52a8cea71d9c5e80c998021fe2ff 100644
|
2022-03-02 10:21:30 +01:00
|
|
|
--- a/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/players/PlayerList.java
|
2023-09-22 17:08:04 +02:00
|
|
|
@@ -379,6 +379,16 @@ public abstract class PlayerList {
|
2022-03-02 10:21:30 +01:00
|
|
|
|
|
|
|
// Paper start - move vehicle into method so it can be called above - short circuit around that code
|
|
|
|
onPlayerJoinFinish(player, worldserver1, s1);
|
2022-06-08 19:50:57 +02:00
|
|
|
+ // Paper start - Send empty chunk, so players aren't stuck in the world loading screen with our chunk system not sending chunks when dead
|
|
|
|
+ if (player.isDeadOrDying()) {
|
2022-12-08 04:24:00 +01:00
|
|
|
+ net.minecraft.core.Holder<net.minecraft.world.level.biome.Biome> plains = worldserver1.registryAccess().registryOrThrow(net.minecraft.core.registries.Registries.BIOME)
|
2022-06-08 19:50:57 +02:00
|
|
|
+ .getHolderOrThrow(net.minecraft.world.level.biome.Biomes.PLAINS);
|
|
|
|
+ player.connection.send(new net.minecraft.network.protocol.game.ClientboundLevelChunkWithLightPacket(
|
|
|
|
+ new net.minecraft.world.level.chunk.EmptyLevelChunk(worldserver1, player.chunkPosition(), plains),
|
2023-09-24 08:29:07 +02:00
|
|
|
+ worldserver1.getLightEngine(), (java.util.BitSet)null, (java.util.BitSet) null, false)
|
2022-06-08 19:50:57 +02:00
|
|
|
+ );
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2022-03-02 10:21:30 +01:00
|
|
|
}
|
|
|
|
private void mountSavedVehicle(ServerPlayer player, ServerLevel worldserver1, CompoundTag nbttagcompound) {
|
|
|
|
// Paper end
|