mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 17:01:56 +01:00
44 lines
3 KiB
Diff
44 lines
3 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||
|
Date: Fri, 8 Oct 2021 13:12:58 -0700
|
||
|
Subject: [PATCH] Fix cancelled powdered snow bucket placement
|
||
|
|
||
|
Cancelling the placement of powdered snow from the powdered
|
||
|
snow bucket didn't revert grass that became snowy because of the
|
||
|
placement.
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/world/item/BlockItem.java b/src/main/java/net/minecraft/world/item/BlockItem.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/item/BlockItem.java
|
||
|
+++ b/src/main/java/net/minecraft/world/item/BlockItem.java
|
||
|
@@ -0,0 +0,0 @@ public class BlockItem extends Item {
|
||
|
blockstate.update(true, false);
|
||
|
|
||
|
if (this instanceof SolidBucketItem) {
|
||
|
+ ((ServerPlayer) entityhuman).connection.send(new net.minecraft.network.protocol.game.ClientboundBlockUpdatePacket(world, blockposition.below())); // Paper - update block below
|
||
|
((ServerPlayer) entityhuman).getBukkitEntity().updateInventory(); // SPIGOT-4541
|
||
|
}
|
||
|
return InteractionResult.FAIL;
|
||
|
diff --git a/src/main/java/net/minecraft/world/item/ItemStack.java b/src/main/java/net/minecraft/world/item/ItemStack.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/item/ItemStack.java
|
||
|
+++ b/src/main/java/net/minecraft/world/item/ItemStack.java
|
||
|
@@ -0,0 +0,0 @@ public final class ItemStack {
|
||
|
int oldCount = this.getCount();
|
||
|
ServerLevel world = (ServerLevel) itemactioncontext.getLevel();
|
||
|
|
||
|
- if (!(this.getItem() instanceof BucketItem || this.getItem() instanceof SolidBucketItem)) { // if not bucket
|
||
|
+ if (!(this.getItem() instanceof BucketItem/* || this.getItem() instanceof SolidBucketItem*/)) { // if not bucket // Paper - capture block states for snow buckets
|
||
|
world.captureBlockStates = true;
|
||
|
// special case bonemeal
|
||
|
if (this.getItem() == Items.BONE_MEAL) {
|
||
|
@@ -0,0 +0,0 @@ public final class ItemStack {
|
||
|
world.capturedBlockStates.clear();
|
||
|
if (blocks.size() > 1) {
|
||
|
placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockMultiPlaceEvent(world, entityhuman, enumhand, blocks, blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
||
|
- } else if (blocks.size() == 1) {
|
||
|
+ } else if (blocks.size() == 1 && item != Items.POWDER_SNOW_BUCKET) { // Paper - don't call event twice for snow buckets
|
||
|
placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent(world, entityhuman, enumhand, blocks.get(0), blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
||
|
}
|
||
|
|