From a7e97b62c98c5accb482d219b8b665e54827fde5 Mon Sep 17 00:00:00 2001 From: TonytheMacaroni Date: Thu, 9 Nov 2023 20:35:35 -0500 Subject: [PATCH] Attribute Modifier API improvements Co-authored-by: Malfrador --- .../bukkit/attribute/AttributeInstance.java | 46 +++++++++++++++++++ .../bukkit/attribute/AttributeModifier.java | 6 +++ 2 files changed, 52 insertions(+) diff --git a/paper-api/src/main/java/org/bukkit/attribute/AttributeInstance.java b/paper-api/src/main/java/org/bukkit/attribute/AttributeInstance.java index f08ee26cc4..f1fa86ddf1 100644 --- a/paper-api/src/main/java/org/bukkit/attribute/AttributeInstance.java +++ b/paper-api/src/main/java/org/bukkit/attribute/AttributeInstance.java @@ -39,6 +39,42 @@ public interface AttributeInstance { @NotNull Collection getModifiers(); + // Paper start + /** + * Gets the modifier with the corresponding key. + * + * @param key the jey of the modifier + * @return the modifier, if it exists + */ + @org.jetbrains.annotations.Nullable AttributeModifier getModifier(@NotNull net.kyori.adventure.key.Key key); + + /** + * Remove a modifier with the corresponding key from this instance. + * + * @param key the key of the modifier + */ + void removeModifier(@NotNull net.kyori.adventure.key.Key key); + + /** + * Gets the modifier with the corresponding UUID. + * + * @param uuid the UUID of the modifier + * @return the modifier, if it exists + * @deprecated use {@link #getModifier(net.kyori.adventure.key.Key)}, modifiers are no longer stored by UUID + */ + @Deprecated(forRemoval = true, since = "1.21") + @org.jetbrains.annotations.Nullable AttributeModifier getModifier(@NotNull java.util.UUID uuid); + + /** + * Remove a modifier with the corresponding UUID from this instance. + * + * @param uuid the UUID of the modifier + * @deprecated use {@link #removeModifier(net.kyori.adventure.key.Key)}, modifiers are no longer stored by UUID + */ + @Deprecated(forRemoval = true, since = "1.21") + void removeModifier(@NotNull java.util.UUID uuid); + // Paper end + /** * Add a modifier to this instance. * @@ -46,6 +82,16 @@ public interface AttributeInstance { */ void addModifier(@NotNull AttributeModifier modifier); + // Paper start - Transient modifier API + /** + * Add a transient modifier to this instance. + * Transient modifiers are not persisted (saved with the NBT data) + * + * @param modifier to add + */ + void addTransientModifier(@NotNull AttributeModifier modifier); + // Paper end + /** * Remove a modifier from this instance. * diff --git a/paper-api/src/main/java/org/bukkit/attribute/AttributeModifier.java b/paper-api/src/main/java/org/bukkit/attribute/AttributeModifier.java index b90af00a8e..4ad09a2673 100644 --- a/paper-api/src/main/java/org/bukkit/attribute/AttributeModifier.java +++ b/paper-api/src/main/java/org/bukkit/attribute/AttributeModifier.java @@ -48,6 +48,12 @@ public class AttributeModifier implements ConfigurationSerializable, Keyed { this(NamespacedKey.fromString(uuid.toString()), amount, operation, slot); } + // Paper start - Add constructor without EquipmentSlotGroup + public AttributeModifier(@NotNull NamespacedKey key, double amount, @NotNull Operation operation) { + this(key, amount, operation, EquipmentSlotGroup.ANY); + } + // Paper end + public AttributeModifier(@NotNull NamespacedKey key, double amount, @NotNull Operation operation, @NotNull EquipmentSlotGroup slot) { Preconditions.checkArgument(key != null, "Key cannot be null"); Preconditions.checkArgument(operation != null, "Operation cannot be null");