aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0190-WitchConsumePotionEvent.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0190-WitchConsumePotionEvent.patch')
-rw-r--r--patches/server/0190-WitchConsumePotionEvent.patch24
1 files changed, 24 insertions, 0 deletions
diff --git a/patches/server/0190-WitchConsumePotionEvent.patch b/patches/server/0190-WitchConsumePotionEvent.patch
new file mode 100644
index 0000000000..fead120a99
--- /dev/null
+++ b/patches/server/0190-WitchConsumePotionEvent.patch
@@ -0,0 +1,24 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Aikar <[email protected]>
+Date: Wed, 16 May 2018 20:35:16 -0400
+Subject: [PATCH] WitchConsumePotionEvent
+
+Fires when a witch consumes the potion in their hand
+
+diff --git a/src/main/java/net/minecraft/world/entity/monster/Witch.java b/src/main/java/net/minecraft/world/entity/monster/Witch.java
+index a4d10409f06316ee628b683b231b3cc2a08bf593..f9cd71379a1d195731e7348ac6928372a4b2c29c 100644
+--- a/src/main/java/net/minecraft/world/entity/monster/Witch.java
++++ b/src/main/java/net/minecraft/world/entity/monster/Witch.java
+@@ -123,6 +123,12 @@ public class Witch extends Raider implements RangedAttackMob {
+
+ this.setItemSlot(EquipmentSlot.MAINHAND, ItemStack.EMPTY);
+ PotionContents potioncontents = (PotionContents) itemstack.get(DataComponents.POTION_CONTENTS);
++ // Paper start - WitchConsumePotionEvent
++ if (itemstack.is(Items.POTION)) {
++ com.destroystokyo.paper.event.entity.WitchConsumePotionEvent event = new com.destroystokyo.paper.event.entity.WitchConsumePotionEvent((org.bukkit.entity.Witch) this.getBukkitEntity(), org.bukkit.craftbukkit.inventory.CraftItemStack.asCraftMirror(itemstack));
++ potioncontents = event.callEvent() ? org.bukkit.craftbukkit.inventory.CraftItemStack.unwrap(event.getPotion()).get(DataComponents.POTION_CONTENTS) : null;
++ }
++ // Paper end - WitchConsumePotionEvent
+
+ if (itemstack.is(Items.POTION) && potioncontents != null) {
+ potioncontents.forEachEffect((effect) -> this.addEffect(effect, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.ATTACK)); // CraftBukkit