geforkt von Mirrors/Paper
Attribute Modifier API improvements
Co-authored-by: Malfrador <malfrador@gmail.com>
Dieser Commit ist enthalten in:
Ursprung
4e6ceb54bb
Commit
a7e97b62c9
@ -39,6 +39,42 @@ public interface AttributeInstance {
|
|||||||
@NotNull
|
@NotNull
|
||||||
Collection<AttributeModifier> getModifiers();
|
Collection<AttributeModifier> 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.
|
* Add a modifier to this instance.
|
||||||
*
|
*
|
||||||
@ -46,6 +82,16 @@ public interface AttributeInstance {
|
|||||||
*/
|
*/
|
||||||
void addModifier(@NotNull AttributeModifier modifier);
|
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.
|
* Remove a modifier from this instance.
|
||||||
*
|
*
|
||||||
|
@ -48,6 +48,12 @@ public class AttributeModifier implements ConfigurationSerializable, Keyed {
|
|||||||
this(NamespacedKey.fromString(uuid.toString()), amount, operation, slot);
|
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) {
|
public AttributeModifier(@NotNull NamespacedKey key, double amount, @NotNull Operation operation, @NotNull EquipmentSlotGroup slot) {
|
||||||
Preconditions.checkArgument(key != null, "Key cannot be null");
|
Preconditions.checkArgument(key != null, "Key cannot be null");
|
||||||
Preconditions.checkArgument(operation != null, "Operation cannot be null");
|
Preconditions.checkArgument(operation != null, "Operation cannot be null");
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren