mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-05 02:22:12 +01:00
#824: Expand upon PotionEffect API to better accommodate infinite durations
By: Parker Hawke <hawkeboyz2@hotmail.com>
This commit is contained in:
parent
d68d5105ce
commit
b1268227d9
1 changed files with 34 additions and 1 deletions
|
@ -20,6 +20,11 @@ import org.jetbrains.annotations.Nullable;
|
||||||
*/
|
*/
|
||||||
@SerializableAs("PotionEffect")
|
@SerializableAs("PotionEffect")
|
||||||
public class PotionEffect implements ConfigurationSerializable {
|
public class PotionEffect implements ConfigurationSerializable {
|
||||||
|
/**
|
||||||
|
* A constant denoting infinite potion duration.
|
||||||
|
*/
|
||||||
|
public static final int INFINITE_DURATION = -1;
|
||||||
|
|
||||||
private static final String AMPLIFIER = "amplifier";
|
private static final String AMPLIFIER = "amplifier";
|
||||||
private static final String DURATION = "duration";
|
private static final String DURATION = "duration";
|
||||||
private static final String TYPE = "effect";
|
private static final String TYPE = "effect";
|
||||||
|
@ -179,12 +184,40 @@ public class PotionEffect implements ConfigurationSerializable {
|
||||||
* Returns the duration (in ticks) that this effect will run for when
|
* Returns the duration (in ticks) that this effect will run for when
|
||||||
* applied to a {@link LivingEntity}.
|
* applied to a {@link LivingEntity}.
|
||||||
*
|
*
|
||||||
* @return The duration of the effect
|
* @return The duration of the effect, or {@value #INFINITE_DURATION} if
|
||||||
|
* this effect is infinite
|
||||||
|
* @see #isInfinite()
|
||||||
*/
|
*/
|
||||||
public int getDuration() {
|
public int getDuration() {
|
||||||
return duration;
|
return duration;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns whether or not this potion effect has an infinite duration. Potion
|
||||||
|
* effects with infinite durations will display an infinite symbol and never
|
||||||
|
* expire unless manually removed.
|
||||||
|
*
|
||||||
|
* @return whether this duration is infinite or not
|
||||||
|
*/
|
||||||
|
public boolean isInfinite() {
|
||||||
|
return duration == INFINITE_DURATION;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns whether or not this potion effect has a shorter duration than the
|
||||||
|
* provided potion effect.
|
||||||
|
* <p>
|
||||||
|
* An infinite duration is considered longer than non-infinite durations. If
|
||||||
|
* both potion effects have infinite durations, then neither is shorter than
|
||||||
|
* the other and this method will return false.
|
||||||
|
*
|
||||||
|
* @param other the other effect
|
||||||
|
* @return true if this effect is shorter than the other, false if longer or equal
|
||||||
|
*/
|
||||||
|
public boolean isShorterThan(@NotNull PotionEffect other) {
|
||||||
|
return !isInfinite() && (duration < other.duration || other.isInfinite());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the {@link PotionEffectType} of this effect.
|
* Returns the {@link PotionEffectType} of this effect.
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue