aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0859-Fix-a-couple-of-upstream-bed-issues.patch
diff options
context:
space:
mode:
authorJake Potrebic <[email protected]>2024-04-06 12:53:39 -0700
committerGitHub <[email protected]>2024-04-06 12:53:39 -0700
commitbd38e0318ae7f8fd10c13eb52d64842a73a81437 (patch)
tree7733b775e13d21655e985a3a083b0d3835707bd8 /patches/server/0859-Fix-a-couple-of-upstream-bed-issues.patch
parenta2035440cfe3ec829513a74b1309859fc15be972 (diff)
downloadPaper-bd38e0318ae7f8fd10c13eb52d64842a73a81437.tar.gz
Paper-bd38e0318ae7f8fd10c13eb52d64842a73a81437.zip
Updated Upstream (Bukkit/CraftBukkit) (#10379)
Updated Upstream (Bukkit/CraftBukkit) Upstream has released updates that appear to apply and compile correctly. This update has not been tested by PaperMC and as with ANY update, please do your own testing Bukkit Changes: f02baa38 PR-988: Add World#getIntersectingChunks(BoundingBox) 9321d665 Move getItemInUse up to LivingEntity 819eef73 PR-959: Add access to current item's remaining ticks c4fdadb0 SPIGOT-7601: Add AbstractArrow#getItem be8261ca Add support for Java 22 26119676 PR-979: Add more translation keys 66753362 PR-985: Correct book maximum pages and characters per page documentation c8be92fa PR-980: Improve getArmorContents() documentation f1120ee2 PR-983: Expose riptide velocity to PlayerRiptideEvent CraftBukkit Changes: dfaa89bbe PR-1369: Add World#getIntersectingChunks(BoundingBox) 51bbab2b9 Move getItemInUse up to LivingEntity 668e09602 PR-1331: Add access to current item's remaining ticks a639406d1 SPIGOT-7601: Add AbstractArrow#getItem 0398930fc SPIGOT-7602: Allow opening in-world horse and related inventories ffd15611c SPIGOT-7608: Allow empty lists to morph to any PDT list 2188dcfa9 Add support for Java 22 45d6a609f SPIGOT-7604: Revert "SPIGOT-7365: DamageCause blocked by shield should trigger invulnerableTime" 06d915943 SPIGOT-7365: DamageCause blocked by shield should trigger invulnerableTime ca3bc3707 PR-1361: Add more translation keys 366c3ca80 SPIGOT-7600: EntityChangeBlockEvent is not fired for frog eggs 06d0f9ba8 SPIGOT-7593: Fix sapling growth physics / client-side updates 45c2608e4 PR-1366: Expose riptide velocity to PlayerRiptideEvent 29b6bb79b SPIGOT-7587: Remove fixes for now-resolved MC-142590 and MC-109346
Diffstat (limited to 'patches/server/0859-Fix-a-couple-of-upstream-bed-issues.patch')
-rw-r--r--patches/server/0859-Fix-a-couple-of-upstream-bed-issues.patch33
1 files changed, 33 insertions, 0 deletions
diff --git a/patches/server/0859-Fix-a-couple-of-upstream-bed-issues.patch b/patches/server/0859-Fix-a-couple-of-upstream-bed-issues.patch
new file mode 100644
index 0000000000..6740daf4d1
--- /dev/null
+++ b/patches/server/0859-Fix-a-couple-of-upstream-bed-issues.patch
@@ -0,0 +1,33 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Jake Potrebic <[email protected]>
+Date: Sun, 9 Apr 2023 21:11:58 -0700
+Subject: [PATCH] Fix a couple of upstream bed issues
+
+Upstream incorrectly skipped explosion logic if
+the bed was occupied and added a "feature" where
+if you set your spawn in a respawn anchor world
+but then replaced it with a bed, you could respawn
+at the bed in that world.
+
+diff --git a/src/main/java/net/minecraft/world/level/block/BedBlock.java b/src/main/java/net/minecraft/world/level/block/BedBlock.java
+index c14cddd42c61512c312231b1e93ccc6efbde620c..38fcde81d797dc46409f5a9ed426fe296d79bdfa 100644
+--- a/src/main/java/net/minecraft/world/level/block/BedBlock.java
++++ b/src/main/java/net/minecraft/world/level/block/BedBlock.java
+@@ -109,6 +109,7 @@ public class BedBlock extends HorizontalDirectionalBlock implements EntityBlock
+ world.explode((Entity) null, world.damageSources().badRespawnPointExplosion(vec3d, explodedBlockState), (ExplosionDamageCalculator) null, vec3d, 5.0F, true, Level.ExplosionInteraction.BLOCK); // Paper - add exploded state
+ return InteractionResult.SUCCESS;
+ } else if ((Boolean) state.getValue(BedBlock.OCCUPIED)) {
++ if (!BedBlock.canSetSpawn(world)) return this.explodeBed(state, world, pos); // Paper - check explode first
+ if (!this.kickVillagerOutOfBed(world, pos)) {
+ player.displayClientMessage(Component.translatable("block.minecraft.bed.occupied"), true);
+ }
+@@ -166,8 +167,7 @@ public class BedBlock extends HorizontalDirectionalBlock implements EntityBlock
+ // CraftBukkit end
+
+ public static boolean canSetSpawn(Level world) {
+- // CraftBukkit - moved world and biome check into EntityHuman
+- return true || world.dimensionType().bedWorks();
++ return world.dimensionType().bedWorks(); // Paper - actually check if the bed works
+ }
+
+ private boolean kickVillagerOutOfBed(Level world, BlockPos pos) {