diff --git a/patches/server/0164-Option-for-chests-to-open-even-with-a-solid-block-on.patch b/patches/server/0164-Option-for-chests-to-open-even-with-a-solid-block-on.patch new file mode 100644 index 000000000..7768cec00 --- /dev/null +++ b/patches/server/0164-Option-for-chests-to-open-even-with-a-solid-block-on.patch @@ -0,0 +1,34 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: jmp +Date: Sat, 12 Dec 2020 14:34:18 -0800 +Subject: [PATCH] Option for chests to open even with a solid block on top + + +diff --git a/src/main/java/net/minecraft/server/BlockChest.java b/src/main/java/net/minecraft/server/BlockChest.java +index 9e5e6de52..487b281cf 100644 +--- a/src/main/java/net/minecraft/server/BlockChest.java ++++ b/src/main/java/net/minecraft/server/BlockChest.java +@@ -262,6 +262,7 @@ public class BlockChest extends BlockChestAbstract implements I + } + + private static boolean a(IBlockAccess iblockaccess, BlockPosition blockposition) { ++ if (iblockaccess instanceof World && ((World) iblockaccess).purpurConfig.chestOpenWithBlockOnTop) return false; // Purpur + BlockPosition blockposition1 = blockposition.up(); + + return iblockaccess.getType(blockposition1).isOccluding(iblockaccess, blockposition1); +diff --git a/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java b/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java +index 8664315de..22d1eae89 100644 +--- a/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java ++++ b/src/main/java/net/pl3x/purpur/PurpurWorldConfig.java +@@ -370,6 +370,11 @@ public class PurpurWorldConfig { + } + } + ++ public boolean chestOpenWithBlockOnTop = false; ++ private void chestSettings() { ++ chestOpenWithBlockOnTop = getBoolean("blocks.chest.open-with-solid-block-on-top", chestOpenWithBlockOnTop); ++ } ++ + public boolean dispenserApplyCursedArmor = true; + public boolean dispenserPlaceAnvils = false; + private void dispenserSettings() {