mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-30 16:19:03 +01:00
29 lines
1.5 KiB
Diff
29 lines
1.5 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: chickeneer <emcchickeneer@gmail.com>
|
||
|
Date: Mon, 4 Jan 2016 00:19:32 -0600
|
||
|
Subject: [PATCH] SPIGOT-1387: Resolve bed issues on unloaded chunks
|
||
|
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/server/EntityHuman.java b/src/main/java/net/minecraft/server/EntityHuman.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/server/EntityHuman.java
|
||
|
+++ b/src/main/java/net/minecraft/server/EntityHuman.java
|
||
|
@@ -0,0 +0,0 @@ public abstract class EntityHuman extends EntityLiving {
|
||
|
return this.world.getType(this.bx).getBlock() == Blocks.BED;
|
||
|
}
|
||
|
|
||
|
+ // PaperSpigot start - SPIGOT-1387: Resolve bed issues on unloaded chunks
|
||
|
public static BlockPosition getBed(World world, BlockPosition blockposition, boolean flag) {
|
||
|
+ boolean before = ((WorldServer) world).chunkProviderServer.forceChunkLoad;
|
||
|
+ ((WorldServer) world).chunkProviderServer.forceChunkLoad = true;
|
||
|
+ final BlockPosition result = getBed0(world, blockposition, flag);
|
||
|
+ ((WorldServer) world).chunkProviderServer.forceChunkLoad = before;
|
||
|
+ return result;
|
||
|
+ }
|
||
|
+
|
||
|
+ private static BlockPosition getBed0(World world, BlockPosition blockposition, boolean flag) {
|
||
|
+ // PaperSpigot end
|
||
|
((ChunkProviderServer) world.chunkProvider).getChunkAt(blockposition.getX() >> 4, blockposition.getZ() >> 4); // CraftBukkit
|
||
|
Block block = world.getType(blockposition).getBlock();
|
||
|
|
||
|
--
|