Paper/Spigot-Server-Patches/0629-Implement-PlayerFlowerPotManipulateEvent.patch

48 lines
2.5 KiB
Diff
Raw Normal View History

2019-08-14 12:47:06 +08:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: MisterVector <whizkid3000@hotmail.com>
Date: Tue, 13 Aug 2019 19:45:06 -0700
Subject: [PATCH] Implement PlayerFlowerPotManipulateEvent
diff --git a/src/main/java/net/minecraft/world/level/block/BlockFlowerPot.java b/src/main/java/net/minecraft/world/level/block/BlockFlowerPot.java
index a61d1ffeebfd00a5fcd5faf95200b0640da8ea82..18fefad056d92a6fa498ab3764cd391446c26b60 100644
--- a/src/main/java/net/minecraft/world/level/block/BlockFlowerPot.java
+++ b/src/main/java/net/minecraft/world/level/block/BlockFlowerPot.java
@@ -21,6 +21,8 @@ import net.minecraft.world.phys.MovingObjectPositionBlock;
import net.minecraft.world.phys.shapes.VoxelShape;
import net.minecraft.world.phys.shapes.VoxelShapeCollision;
2019-08-14 12:47:06 +08:00
+import io.papermc.paper.event.player.PlayerFlowerPotManipulateEvent; // Paper
+
public class BlockFlowerPot extends Block {
private static final Map<Block, Block> b = Maps.newHashMap();
@@ -52,6 +54,27 @@ public class BlockFlowerPot extends Block {
2019-08-14 12:47:06 +08:00
boolean flag1 = this.c == Blocks.AIR;
if (flag != flag1) {
+ // Paper start
+ org.bukkit.entity.Player player = (org.bukkit.entity.Player) entityhuman.getBukkitEntity();
+ boolean placing = flag1;
+ org.bukkit.block.Block bukkitblock = org.bukkit.craftbukkit.block.CraftBlock.at(world, blockposition);
+ org.bukkit.inventory.ItemStack bukkititemstack = org.bukkit.craftbukkit.inventory.CraftItemStack.asBukkitCopy(itemstack);
+ org.bukkit.Material mat = org.bukkit.craftbukkit.util.CraftMagicNumbers.getMaterial(c);
+ org.bukkit.inventory.ItemStack bukkititemstack1 = new org.bukkit.inventory.ItemStack(mat, 1);
+ org.bukkit.inventory.ItemStack whichitem = placing ? bukkititemstack : bukkititemstack1;
+
+ PlayerFlowerPotManipulateEvent event = new PlayerFlowerPotManipulateEvent(player, bukkitblock, whichitem, placing);
+ player.getServer().getPluginManager().callEvent(event);
+
+ if (event.isCancelled()) {
+ // Update client
+ player.sendBlockChange(bukkitblock.getLocation(), bukkitblock.getBlockData());
+ player.updateInventory();
+
+ return EnumInteractionResult.PASS;
+ }
+ // Paper end
+
if (flag1) {
world.setTypeAndData(blockposition, block.getBlockData(), 3);
entityhuman.a(StatisticList.POT_FLOWER);