aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0740-fix-powder-snow-cauldrons-not-turning-to-water.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0740-fix-powder-snow-cauldrons-not-turning-to-water.patch')
-rw-r--r--patches/server/0740-fix-powder-snow-cauldrons-not-turning-to-water.patch45
1 files changed, 45 insertions, 0 deletions
diff --git a/patches/server/0740-fix-powder-snow-cauldrons-not-turning-to-water.patch b/patches/server/0740-fix-powder-snow-cauldrons-not-turning-to-water.patch
new file mode 100644
index 0000000000..1d388d0504
--- /dev/null
+++ b/patches/server/0740-fix-powder-snow-cauldrons-not-turning-to-water.patch
@@ -0,0 +1,45 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Jake Potrebic <[email protected]>
+Date: Thu, 30 Dec 2021 14:02:13 -0800
+Subject: [PATCH] fix powder snow cauldrons not turning to water
+
+Powder snow cauldrons should turn to water when
+extinguishing an entity
+
+diff --git a/src/main/java/net/minecraft/world/level/block/LayeredCauldronBlock.java b/src/main/java/net/minecraft/world/level/block/LayeredCauldronBlock.java
+index 542bc6be48d5c53eee988156e7aa6ecfccb51069..42c1e3dfec23d6a7d832bf73d47ecae1212ec2c9 100644
+--- a/src/main/java/net/minecraft/world/level/block/LayeredCauldronBlock.java
++++ b/src/main/java/net/minecraft/world/level/block/LayeredCauldronBlock.java
+@@ -69,7 +69,7 @@ public class LayeredCauldronBlock extends AbstractCauldronBlock {
+ if (!world.isClientSide && entity.isOnFire() && this.isEntityInsideContent(state, pos, entity)) {
+ // CraftBukkit start
+ if (entity.mayInteract(world, pos)) {
+- if (!LayeredCauldronBlock.lowerFillLevel(state, world, pos, entity, CauldronLevelChangeEvent.ChangeReason.EXTINGUISH)) {
++ if (!this.handleEntityOnFireInsideWithEvent(state, world, pos, entity)) { // Paper - fix powdered snow cauldron extinguishing entities
+ return;
+ }
+ }
+@@ -79,6 +79,7 @@ public class LayeredCauldronBlock extends AbstractCauldronBlock {
+
+ }
+
++ @io.papermc.paper.annotation.DoNotUse @Deprecated // Paper - fix powdered snow cauldron extinguishing entities; use #handleEntityOnFireInsideWithEvent
+ private void handleEntityOnFireInside(BlockState state, Level world, BlockPos pos) {
+ if (this.precipitationType == Biome.Precipitation.SNOW) {
+ LayeredCauldronBlock.lowerFillLevel((BlockState) Blocks.WATER_CAULDRON.defaultBlockState().setValue(LayeredCauldronBlock.LEVEL, (Integer) state.getValue(LayeredCauldronBlock.LEVEL)), world, pos);
+@@ -87,6 +88,15 @@ public class LayeredCauldronBlock extends AbstractCauldronBlock {
+ }
+
+ }
++ // Paper start - fix powdered snow cauldron extinguishing entities
++ protected boolean handleEntityOnFireInsideWithEvent(BlockState state, Level world, BlockPos pos, Entity entity) {
++ if (this.precipitationType == Biome.Precipitation.SNOW) {
++ return LayeredCauldronBlock.lowerFillLevel((BlockState) Blocks.WATER_CAULDRON.defaultBlockState().setValue(LayeredCauldronBlock.LEVEL, (Integer) state.getValue(LayeredCauldronBlock.LEVEL)), world, pos, entity, CauldronLevelChangeEvent.ChangeReason.EXTINGUISH);
++ } else {
++ return LayeredCauldronBlock.lowerFillLevel(state, world, pos, entity, CauldronLevelChangeEvent.ChangeReason.EXTINGUISH);
++ }
++ }
++ // Paper end - fix powdered snow cauldron extinguishing entities
+
+ public static void lowerFillLevel(BlockState state, Level world, BlockPos pos) {
+ // CraftBukkit start