Mirror von
https://github.com/PaperMC/Paper.git
synchronisiert 2025-01-10 15:20:06 +01:00
104 Zeilen
4.5 KiB
Diff
104 Zeilen
4.5 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||
|
Date: Tue, 18 May 2021 12:31:54 -0700
|
||
|
Subject: [PATCH] Add drops to shear events
|
||
|
|
||
|
|
||
|
diff --git a/src/main/java/org/bukkit/event/block/BlockShearEntityEvent.java b/src/main/java/org/bukkit/event/block/BlockShearEntityEvent.java
|
||
|
index 71c0af9373069cfaa074e1fbad592eab81025b1c..610768bd329b8612627d361fd9a773a7b91ff108 100644
|
||
|
--- a/src/main/java/org/bukkit/event/block/BlockShearEntityEvent.java
|
||
|
+++ b/src/main/java/org/bukkit/event/block/BlockShearEntityEvent.java
|
||
|
@@ -17,11 +17,14 @@ public class BlockShearEntityEvent extends BlockEvent implements Cancellable {
|
||
|
private final Entity sheared;
|
||
|
private final ItemStack tool;
|
||
|
private boolean cancelled;
|
||
|
+ private java.util.List<ItemStack> drops; // Paper
|
||
|
|
||
|
- public BlockShearEntityEvent(@NotNull Block dispenser, @NotNull Entity sheared, @NotNull ItemStack tool) {
|
||
|
+ @org.jetbrains.annotations.ApiStatus.Internal // Paper
|
||
|
+ public BlockShearEntityEvent(@NotNull Block dispenser, @NotNull Entity sheared, @NotNull ItemStack tool, final @NotNull java.util.List<ItemStack> drops) { // Paper - custom shear drops
|
||
|
super(dispenser);
|
||
|
this.sheared = sheared;
|
||
|
this.tool = tool;
|
||
|
+ this.drops = drops; // Paper
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
@@ -64,4 +67,24 @@ public class BlockShearEntityEvent extends BlockEvent implements Cancellable {
|
||
|
public static HandlerList getHandlerList() {
|
||
|
return handlers;
|
||
|
}
|
||
|
+ // Paper start - custom shear drops
|
||
|
+ /**
|
||
|
+ * Get an immutable list of drops for this shearing.
|
||
|
+ *
|
||
|
+ * @return the shearing drops
|
||
|
+ * @see #setDrops(java.util.List)
|
||
|
+ */
|
||
|
+ public java.util.@NotNull @org.jetbrains.annotations.Unmodifiable List<ItemStack> getDrops() {
|
||
|
+ return java.util.Collections.unmodifiableList(this.drops);
|
||
|
+ }
|
||
|
+
|
||
|
+ /**
|
||
|
+ * Sets the drops for the shearing.
|
||
|
+ *
|
||
|
+ * @param drops the shear drops
|
||
|
+ */
|
||
|
+ public void setDrops(final java.util.@NotNull List<org.bukkit.inventory.ItemStack> drops) {
|
||
|
+ this.drops = java.util.List.copyOf(drops);
|
||
|
+ }
|
||
|
+ // Paper end - custom shear drops
|
||
|
}
|
||
|
diff --git a/src/main/java/org/bukkit/event/player/PlayerShearEntityEvent.java b/src/main/java/org/bukkit/event/player/PlayerShearEntityEvent.java
|
||
|
index 04b3dce008edefb045162d0f69f87462ea1f3534..63f6799c2543ba67ce9fe6484002062d7a754fd0 100644
|
||
|
--- a/src/main/java/org/bukkit/event/player/PlayerShearEntityEvent.java
|
||
|
+++ b/src/main/java/org/bukkit/event/player/PlayerShearEntityEvent.java
|
||
|
@@ -18,17 +18,20 @@ public class PlayerShearEntityEvent extends PlayerEvent implements Cancellable {
|
||
|
private final Entity what;
|
||
|
private final ItemStack item;
|
||
|
private final EquipmentSlot hand;
|
||
|
+ private java.util.List<ItemStack> drops; // Paper - custom shear drops
|
||
|
|
||
|
- public PlayerShearEntityEvent(@NotNull Player who, @NotNull Entity what, @NotNull ItemStack item, @NotNull EquipmentSlot hand) {
|
||
|
+ @org.jetbrains.annotations.ApiStatus.Internal // Paper
|
||
|
+ public PlayerShearEntityEvent(@NotNull Player who, @NotNull Entity what, @NotNull ItemStack item, @NotNull EquipmentSlot hand, final java.util.@NotNull List<ItemStack> drops) { // Paper - custom shear drops
|
||
|
super(who);
|
||
|
this.what = what;
|
||
|
this.item = item;
|
||
|
this.hand = hand;
|
||
|
+ this.drops = drops; // Paper - custom shear drops
|
||
|
}
|
||
|
|
||
|
@Deprecated
|
||
|
public PlayerShearEntityEvent(@NotNull final Player who, @NotNull final Entity what) {
|
||
|
- this(who, what, new ItemStack(Material.SHEARS), EquipmentSlot.HAND);
|
||
|
+ this(who, what, new ItemStack(Material.SHEARS), EquipmentSlot.HAND, java.util.Collections.emptyList()); // Paper - custom shear drops
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
@@ -82,4 +85,24 @@ public class PlayerShearEntityEvent extends PlayerEvent implements Cancellable {
|
||
|
return handlers;
|
||
|
}
|
||
|
|
||
|
+ // Paper start - custom shear drops
|
||
|
+ /**
|
||
|
+ * Get an immutable list of drops for this shearing.
|
||
|
+ *
|
||
|
+ * @return the shearing drops
|
||
|
+ * @see #setDrops(java.util.List)
|
||
|
+ */
|
||
|
+ public java.util.@NotNull @org.jetbrains.annotations.Unmodifiable List<ItemStack> getDrops() {
|
||
|
+ return this.drops;
|
||
|
+ }
|
||
|
+
|
||
|
+ /**
|
||
|
+ * Sets the drops for the shearing.
|
||
|
+ *
|
||
|
+ * @param drops the shear drops
|
||
|
+ */
|
||
|
+ public void setDrops(final java.util.@NotNull List<org.bukkit.inventory.ItemStack> drops) {
|
||
|
+ this.drops = java.util.List.copyOf(drops);
|
||
|
+ }
|
||
|
+ // Paper end - custom shear drops
|
||
|
}
|