Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rework Potions #4183

Draft
wants to merge 191 commits into
base: dev/feature
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
191 commits
Select commit Hold shift + click to select a range
acf60ae
Rework EffPotion
APickledWalrus Jul 11, 2021
299b759
Centralize default duration
APickledWalrus Jul 11, 2021
ff07bb5
Merge branch 'master' into enchancement/potions-rework
APickledWalrus Nov 30, 2021
36870ad
Merge branch 'master' into enchancement/potions-rework
APickledWalrus Jan 17, 2022
1412299
Merge branch 'master' into enchancement/potions-rework
APickledWalrus Jul 16, 2022
4672301
First pass for potion "module"
APickledWalrus Jul 16, 2022
dd419d8
Comparison improvements + cleanup
APickledWalrus Sep 28, 2022
d7b87fe
Merge branch 'master' into enchancement/potions-rework
APickledWalrus Sep 28, 2022
0024d6a
Update package
APickledWalrus Sep 28, 2022
7086861
Merge branch 'enchancement/potions-rework' of https://github.com/APic…
APickledWalrus Sep 28, 2022
7b8ee05
Fix some update fails
APickledWalrus Sep 28, 2022
0272224
Fix some additional issues
APickledWalrus Sep 28, 2022
503c80b
Merge branch 'master' into enchancement/potions-rework
APickledWalrus Sep 28, 2022
0cc8236
Change package
APickledWalrus Dec 27, 2022
1c62976
First api design
kiip1 Jan 5, 2023
f913c6b
Rework and implement for expression
kiip1 Jan 5, 2023
43d4cee
Implement for all syntax elements
kiip1 Jan 5, 2023
42fe5ca
Rename to Skript and other small refactors
kiip1 Jan 5, 2023
3297132
Registration closing
kiip1 Jan 5, 2023
5c69bdc
Child key
kiip1 Jan 6, 2023
d74c11f
Cleanup
kiip1 Jan 6, 2023
0fd91f4
Moving
kiip1 Jan 6, 2023
98f6b3d
hashcode
kiip1 Jan 6, 2023
7b5c8b8
Oops
kiip1 Jan 6, 2023
c5ac2d0
TODO
kiip1 Jan 6, 2023
3e1849f
Move event pattern transformation to the correct place
kiip1 Jan 6, 2023
a44c08e
Merge branch 'master' into feature/api-rework
kiip1 Jan 6, 2023
e467eb0
Moves key implementation away
kiip1 Jan 6, 2023
8b82bb8
Apply suggestions from code review
kiip1 Jan 7, 2023
501573a
Apply suggestions from code review
kiip1 Jan 7, 2023
513a008
Requested changes
kiip1 Jan 7, 2023
552e7b5
Package rename
kiip1 Jan 7, 2023
678cb85
Refactoring
kiip1 Jan 7, 2023
a85016f
Deprecation
kiip1 Jan 7, 2023
11ffcf4
Merge branch 'master' into feature/api-rework
kiip1 Jan 7, 2023
9807e83
Merge remote-tracking branch 'origin/feature/api-rework' into feature…
kiip1 Jan 7, 2023
f5498a7
Builders
kiip1 Jan 7, 2023
2d7f4fb
Use builders
kiip1 Jan 7, 2023
51782ec
Certified license header moment
kiip1 Jan 7, 2023
4a00130
Not too proud of this one
kiip1 Jan 7, 2023
3f877f1
Merge branch 'master' into feature/api-rework
kiip1 Jan 21, 2023
04505e0
Merge branch 'master' into feature/api-rework
kiip1 Jan 26, 2023
63957ea
Fix tests
kiip1 Jan 26, 2023
69b5960
Refactoring
kiip1 Jan 26, 2023
5976231
Replace with shorter version
kiip1 Jan 26, 2023
241f97e
Fix order
kiip1 Jan 28, 2023
eafffac
Merge branch 'master' into feature/api-rework
kiip1 Jan 28, 2023
5b686c0
Refactoring
kiip1 Jan 28, 2023
abab4f7
Merge branch 'master' into feature/api-rework
kiip1 Jan 28, 2023
6cd6215
Merge branch 'master' into feature/api-rework
kiip1 Feb 12, 2023
b9ed60f
Merge branch 'master' into feature/api-rework
kiip1 Feb 17, 2023
7983cf5
Cherry-pick docs-tool into api-rework
kiip1 Feb 27, 2023
db7b807
Merge branch 'master' into feature/api-rework
kiip1 Feb 27, 2023
c983079
Fix documentation
kiip1 Feb 27, 2023
8726396
Merge remote-tracking branch 'origin/feature/api-rework' into feature…
kiip1 Feb 27, 2023
af6c9b7
Merge branch 'master' into feature/api-rework
kiip1 May 1, 2023
d768af4
Double tabbing
kiip1 May 1, 2023
131d07b
Fix registrations
kiip1 May 1, 2023
e07efe7
Attempt 2
kiip1 May 1, 2023
0c281fa
Merge branch 'master' into feature/api-rework
kiip1 May 18, 2023
78443ff
Apply suggestions from code review
kiip1 May 18, 2023
f4238e9
Allows updating of Skript instance.
kiip1 May 18, 2023
72049bd
Fix error
kiip1 May 18, 2023
238ab4f
Deprecation
kiip1 May 18, 2023
159da8f
Simpler keys
kiip1 May 18, 2023
130933b
SimpleSkriptRegistry
kiip1 May 18, 2023
5dbdf41
Priority stuff
kiip1 May 18, 2023
f402417
Allow for multiple Skript instances
kiip1 May 19, 2023
3eab3d1
Suppliers for syntax elements
kiip1 May 19, 2023
6403f63
Merge remote-tracking branch 'upstream/master' into enchancement/poti…
APickledWalrus Jun 28, 2023
647d758
Cleanup and fixes
APickledWalrus Jun 28, 2023
78543d2
First pass for infinite duration and icon support
APickledWalrus Jun 28, 2023
4d6fc5a
Add potion properties condition and enhance tests
APickledWalrus Jun 28, 2023
51dd32d
Fix package scheme
APickledWalrus Jun 28, 2023
fc55396
Add potion property enum
APickledWalrus Jun 28, 2023
3d2d945
Untested potion properties
APickledWalrus Sep 16, 2023
b2a9ef1
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Dec 19, 2023
db97884
Fixes for event parsing changes
APickledWalrus Dec 19, 2023
9f912e7
Improve BukkitOrigin; Remove LegacyEventImpl
APickledWalrus Dec 19, 2023
3d6b116
Origin improvements
APickledWalrus Dec 19, 2023
1b9587e
Rework SyntaxInfo/Builder system
APickledWalrus Dec 21, 2023
53cba39
Improve Registry and Key system
APickledWalrus Dec 21, 2023
61205ea
Improve SyntaxRegister docs
APickledWalrus Dec 21, 2023
387b57c
Improve SyntaxInfo implementations
APickledWalrus Dec 21, 2023
93fe78c
Add missing JavaDocs
APickledWalrus Dec 21, 2023
5870190
Require builders for creating SyntaxInfos
APickledWalrus Dec 21, 2023
bab67ee
Initial implementation of new Addon API
APickledWalrus Dec 22, 2023
f376b7b
Merge branch 'dev/feature' into feature/registration-rework
Moderocky Dec 23, 2023
c67420f
Address UnderscoreTud's review
APickledWalrus Dec 26, 2023
c983968
Address Moderocky's review
APickledWalrus Dec 26, 2023
98a4e1d
Improve compatibility implementation
APickledWalrus Dec 26, 2023
30ceb36
Remove Skript State system
APickledWalrus Dec 26, 2023
f59ae28
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Jan 12, 2024
6816377
Minor Tweaks
APickledWalrus Jan 13, 2024
88ecd23
Localizer system draft
APickledWalrus Jan 13, 2024
966beb2
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Feb 2, 2024
3edc884
Localizer Fixes
APickledWalrus Feb 9, 2024
7ad773f
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Feb 9, 2024
014f1b5
Merge branch 'dev/feature' into enchancement/potions-rework
APickledWalrus Feb 9, 2024
d2c0a8c
First pass at fixes and improvements
APickledWalrus Feb 9, 2024
a595070
Restore EffPoison behavior
APickledWalrus Feb 9, 2024
d2d9298
Additional fixes and enhancements
APickledWalrus Feb 10, 2024
dc2872b
Add support for property registration methods
APickledWalrus Feb 10, 2024
f98af1e
Merge branch 'feature/registration-rework' into enchancement/potions-…
APickledWalrus Feb 10, 2024
7f80d4f
Use New Registration API
APickledWalrus Feb 10, 2024
e763810
Add support for unregistering syntax infos
APickledWalrus Mar 11, 2024
7759fcd
First pass at SkriptAddon rework
APickledWalrus Mar 12, 2024
eadae09
Implement child registries for addons
APickledWalrus Mar 12, 2024
65ad3a6
Fix language and addon compatibility
APickledWalrus Mar 12, 2024
bce2323
Fix building and tests
APickledWalrus Mar 12, 2024
17937f2
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Mar 12, 2024
2560021
Block registration of interfaces/abstract classes
APickledWalrus Mar 13, 2024
fc5c637
Origin reworks
APickledWalrus Mar 13, 2024
9c60638
First pass at priority rework
APickledWalrus Mar 13, 2024
397b831
Add priority support to info builders
APickledWalrus Mar 13, 2024
3f7f973
Revert Structure priority changes
APickledWalrus Mar 14, 2024
39f26b2
Pivot to a relational priority system
APickledWalrus Mar 14, 2024
2316060
Replace ExpressionType with priority system
APickledWalrus Mar 14, 2024
bb47855
Revert some unnecessary changes
APickledWalrus Mar 14, 2024
cc6394f
Add missing EventValueExpression registration api
APickledWalrus Mar 14, 2024
2ec8806
Rework Expression priorities to be for all SyntaxInfos
APickledWalrus Mar 14, 2024
7dbe48b
Change Skript.createInstance to also return modifiable addon
APickledWalrus Mar 14, 2024
97f0603
Add SyntaxPriority
APickledWalrus Mar 15, 2024
b025c15
Move module loading out of registration
APickledWalrus Mar 15, 2024
e4a28a0
Add missing PriorityImpl checks
APickledWalrus Mar 15, 2024
efaa4fe
SyntaxPriority improvements and clarifications
APickledWalrus Mar 15, 2024
eaf5c4e
Limitations on SyntaxPriority
APickledWalrus Mar 15, 2024
3333273
Alternative module loading method
APickledWalrus Apr 17, 2024
6efbb55
Remove unnecessary SyntaxRegister interface
APickledWalrus Apr 17, 2024
3b22fe9
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Jun 1, 2024
c165765
Fix simple structure support
APickledWalrus Jun 1, 2024
92712ef
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Jun 3, 2024
a9c414b
Implement Registry interface
APickledWalrus Jun 3, 2024
dd7903e
Remove SyntaxPriority Implementation
APickledWalrus Jun 3, 2024
f296812
Disconnect Event Info from Structure Info
APickledWalrus Jun 3, 2024
f272892
Allow structures to be simple or section
APickledWalrus Jun 3, 2024
a2b9264
Improve SyntaxInfo parameter checks
APickledWalrus Jun 7, 2024
a886b25
Add class loading utilities
APickledWalrus Jun 14, 2024
8998a2e
Replace ClassLoader Java 11 methods
APickledWalrus Jun 14, 2024
bd18917
SkriptAddon: remove unnecessary annotations
APickledWalrus Jun 14, 2024
5f483a5
ClassLoader: add default loadClasses method
APickledWalrus Jun 14, 2024
a11a9a9
Use builder method for Expression return type
APickledWalrus Jun 28, 2024
b97269e
Remove license headers
APickledWalrus Jun 28, 2024
776129e
Prevent SkriptImpl from exposing its addons
APickledWalrus Jun 28, 2024
a7d5088
Use the same registry across all addons
APickledWalrus Jun 28, 2024
ce2e82e
Rename SkriptAddon#registry to SkriptAddon#syntaxRegistry
APickledWalrus Jun 28, 2024
e73da23
Add ViewProvider interface
APickledWalrus Jun 29, 2024
55fa670
Improve annotation usage and placement
APickledWalrus Jun 29, 2024
681585c
Remove deprecation annotations
APickledWalrus Jun 29, 2024
a0839ef
Add listening behavior to Event SyntaxInfo
APickledWalrus Jun 29, 2024
65507f8
Add missing experimental annotations
APickledWalrus Jun 29, 2024
537fc4a
Rename BukkitInfos to BukkitSyntaxInfos
APickledWalrus Jun 29, 2024
ec1f772
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Jun 29, 2024
dbc48af
Add unmodifiableView for Skript
APickledWalrus Jun 29, 2024
82d1978
Add registry storage to SkriptAddon
APickledWalrus Jun 30, 2024
036d0b5
Add source requirement to SkriptAddon
APickledWalrus Jun 30, 2024
2d94cf5
Remove source from Localizer
APickledWalrus Jun 30, 2024
7414f40
Fix old addon registration
APickledWalrus Jul 1, 2024
6956294
Merge branch 'dev/feature' into feature/registration-rework
Moderocky Aug 15, 2024
5ffc974
SyntaxInfo equals/hashCode improvements
APickledWalrus Aug 28, 2024
3687940
Implementation optimizations
APickledWalrus Sep 2, 2024
a15d3cc
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Sep 2, 2024
f1f4915
Fix ConditionType support
APickledWalrus Sep 2, 2024
96874c5
Return the constructed info for static registration methods
APickledWalrus Sep 2, 2024
fd9bb95
Builder interface
APickledWalrus Sep 5, 2024
b99b686
Merge branch 'dev/feature' into feature/registration-rework
sovdeeth Sep 29, 2024
73a61cd
Remove unncessary package infos
APickledWalrus Sep 29, 2024
f4d1df6
Implement Buildable interface
APickledWalrus Sep 29, 2024
f609017
Improve legacy collection methods
APickledWalrus Sep 29, 2024
0c30aba
Use a map for modern addon tracking
APickledWalrus Sep 29, 2024
865ddd0
Fix SkriptEventInfo Compatibility
APickledWalrus Sep 29, 2024
3077f8d
Allow Skript#getAddon to return Skript's addon instance
APickledWalrus Sep 30, 2024
5cdeb5e
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Nov 19, 2024
e005a4c
Tweak Preconditions check
APickledWalrus Nov 19, 2024
8a69e33
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Nov 19, 2024
ea854db
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Nov 27, 2024
9f11266
Merge branch 'feature/registration-rework' into enchancement/potions-…
APickledWalrus Nov 27, 2024
38430a8
Update to latest Registration API
APickledWalrus Nov 27, 2024
645d8ec
Remove erroneous import
APickledWalrus Nov 27, 2024
7c4d51c
Use PotionType when available
APickledWalrus Dec 2, 2024
a02951e
Try alternate PotionType check
APickledWalrus Dec 2, 2024
a5796c9
PotionType my beloved
APickledWalrus Dec 2, 2024
fc97b56
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Dec 15, 2024
9ec6fec
Merge branch 'dev/feature' into feature/registration-rework
Efnilite Dec 18, 2024
5d228b5
ExpressionInfo Builder: require returnType at creation
APickledWalrus Dec 19, 2024
ff40117
Add 'clear' methods to builders
APickledWalrus Dec 19, 2024
ad81a6f
AddonModule: add init phase
APickledWalrus Dec 19, 2024
df3392f
Fix incorrect Expression Builder uses
APickledWalrus Dec 19, 2024
4899216
Merge branch 'dev/feature' into feature/registration-rework
APickledWalrus Dec 20, 2024
5854d90
Merge branch 'feature/registration-rework' into enchancement/potions-…
APickledWalrus Dec 20, 2024
c4eafb3
Update Registration API usage
APickledWalrus Dec 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
*/
package ch.njol.skript.classes.data;

import ch.njol.skript.util.PotionEffectUtils;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.OfflinePlayer;
Expand All @@ -34,6 +35,8 @@
import org.bukkit.inventory.InventoryHolder;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.PlayerInventory;
import org.bukkit.potion.PotionEffect;
import org.bukkit.potion.PotionEffectType;
import org.bukkit.util.Vector;
import org.eclipse.jdt.annotation.Nullable;

Expand Down Expand Up @@ -353,5 +356,11 @@ public EnchantmentType convert(EnchantmentOffer eo) {
}
});
}

// PotionEffectType -> PotionEffect
Converters.registerConverter(PotionEffectType.class, PotionEffect.class,
potionEffectType -> new PotionEffect(potionEffectType, PotionEffectUtils.DEFAULT_DURATION_TICKS, 0, false, true)
);

}
}
5 changes: 2 additions & 3 deletions src/main/java/ch/njol/skript/effects/EffPoison.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
*/
package ch.njol.skript.effects;

import ch.njol.skript.util.PotionEffectUtils;
import org.bukkit.entity.LivingEntity;
import org.bukkit.event.Event;
import org.bukkit.potion.PotionEffect;
Expand Down Expand Up @@ -51,8 +52,6 @@ public class EffPoison extends Effect {
"(cure|unpoison) %livingentities% [(from|of) poison]");
}

private final static int DEFAULT_DURATION = 15 * 20; // 15 seconds on hard difficulty, same as EffPotion

@SuppressWarnings("null")
private Expression<LivingEntity> entites;
@Nullable
Expand Down Expand Up @@ -81,7 +80,7 @@ protected void execute(final Event e) {
if (!cure) {
Timespan dur;
int d = (int) (duration != null && (dur = duration.getSingle(e)) != null ?
(dur.getTicks_i() >= Integer.MAX_VALUE ? Integer.MAX_VALUE : dur.getTicks_i()) : DEFAULT_DURATION);
(dur.getTicks_i() >= Integer.MAX_VALUE ? Integer.MAX_VALUE : dur.getTicks_i()) : PotionEffectUtils.DEFAULT_DURATION_TICKS);
if (le.hasPotionEffect(PotionEffectType.POISON)) {
for (final PotionEffect pe : le.getActivePotionEffects()) {
if (pe.getType() != PotionEffectType.POISON)
Expand Down
164 changes: 42 additions & 122 deletions src/main/java/ch/njol/skript/effects/EffPotion.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,6 @@
*/
package ch.njol.skript.effects;

import org.bukkit.entity.LivingEntity;
import org.bukkit.event.Event;
import org.bukkit.potion.PotionEffect;
import org.bukkit.potion.PotionEffectType;
import org.eclipse.jdt.annotation.Nullable;

import ch.njol.skript.Skript;
import ch.njol.skript.doc.Description;
import ch.njol.skript.doc.Examples;
Expand All @@ -35,144 +29,70 @@
import ch.njol.skript.util.PotionEffectUtils;
import ch.njol.skript.util.Timespan;
import ch.njol.util.Kleenean;
import org.bukkit.entity.LivingEntity;
import org.bukkit.event.Event;
import org.bukkit.potion.PotionEffect;
import org.eclipse.jdt.annotation.Nullable;

/**
* @author Peter Güttinger
*/
@Name("Potion Effects")
@Description("Apply or remove potion effects to/from entities.")
@Examples({"apply swiftness 2 to the player",
"remove haste from the victim",
@Description("Apply potion effects to/from entities.")
@Examples({
"apply swiftness 2 to the player",
"on join:",
"\tapply potion of strength of tier {strength.%player%} to the player for 999 days",
APickledWalrus marked this conversation as resolved.
Show resolved Hide resolved
"apply potion effects of player's tool to player"})
@Since("2.0, 2.2-dev27 (ambient and particle-less potion effects), 2.5 (replacing existing effect), 2.5.2 (potion effects)")
"apply potion effects of player's tool to player"
})
@Since("2.0, 2.2-dev27 (ambient and particle-less potion effects), 2.5 (replacing existing effect), 2.5.2 (potion effects), INSERT VERSION (total rework)")
public class EffPotion extends Effect {

static {
// While allowing the user to specify the timespan here is repetitive as you can do it in ExprPotionEffect,
// it allows syntax like "apply haste 3 to the player for 5 seconds" to work
Skript.registerEffect(EffPotion.class,
"apply [potion of] %potioneffecttypes% [potion] [[[of] tier] %-number%] to %livingentities% [for %-timespan%] [(1¦replacing [the] existing effect)]",
"apply ambient [potion of] %potioneffecttypes% [potion] [[[of] tier] %-number%] to %livingentities% [for %-timespan%] [(1¦replacing [the] existing effect)]",
"apply [potion of] %potioneffecttypes% [potion] [[[of] tier] %-number%] without [any] particles to %livingentities% [for %-timespan%] [(1¦replacing [the] existing effect)]",
"apply %potioneffects% to %livingentities%"
//, "apply %itemtypes% to %livingentities%"
/*,"remove %potioneffecttypes% from %livingentities%"*/);
"apply %potioneffects% to %livingentities% [for %-timespan%]",
"effect %livingentities% with %potioneffects% [for %-timespan%]"
);
}

private final static int DEFAULT_DURATION = 15 * 20; // 15 seconds, same as EffPoison
private boolean replaceExisting;

@SuppressWarnings("null")
private Expression<PotionEffectType> potions;
@Nullable
private Expression<Number> tier;
@SuppressWarnings("null")

@SuppressWarnings("NotNullFieldNotInitialized")
private Expression<PotionEffect> potionEffects;
@SuppressWarnings("NotNullFieldNotInitialized")
private Expression<LivingEntity> entities;
@Nullable
private Expression<Timespan> duration;
@SuppressWarnings("null")
private Expression<PotionEffect> potionEffects;
private boolean apply;
private boolean ambient; // Ambient means less particles
private boolean particles; // Particles or no particles?
private boolean potionEffect; // PotionEffects rather than PotionEffectTypes

@SuppressWarnings({"unchecked", "null"})

@Override
public boolean init(final Expression<?>[] exprs, final int matchedPattern, final Kleenean isDelayed, final ParseResult parseResult) {
apply = matchedPattern < 3;
potionEffect = matchedPattern == 3;
replaceExisting = parseResult.mark == 1;
if (potionEffect) {
potionEffects = (Expression<PotionEffect>) exprs[0];
entities = (Expression<LivingEntity>) exprs[1];
} else if (apply) {
potions = (Expression<PotionEffectType>) exprs[0];
tier = (Expression<Number>) exprs[1];
entities = (Expression<LivingEntity>) exprs[2];
duration = (Expression<Timespan>) exprs[3];
} else {
potions = (Expression<PotionEffectType>) exprs[0];
entities = (Expression<LivingEntity>) exprs[1];
}

// Ambience and particles
switch (matchedPattern) {
case 0:
ambient = false;
particles = true;
break;
case 1:
ambient = true;
particles = true;
break;
case 2:
ambient = false;
particles = false;
break;
}

@SuppressWarnings("unchecked")
public boolean init(Expression<?>[] exprs, int matchedPattern, Kleenean isDelayed, ParseResult parseResult) {
boolean first = matchedPattern == 0;
potionEffects = (Expression<PotionEffect>) exprs[first ? 0 : 1];
entities = (Expression<LivingEntity>) exprs[first ? 1 : 0];
duration = (Expression<Timespan>) exprs[2];
return true;
}

@Override
protected void execute(final Event e) {
if (potionEffect) {
for (LivingEntity livingEntity : entities.getArray(e)) {
PotionEffect[] potionEffects = this.potionEffects.getArray(e);
PotionEffectUtils.addEffects(livingEntity, potionEffects);
}
} else {
final PotionEffectType[] ts = potions.getArray(e);
if (ts.length == 0)
return;
if (!apply) {
for (LivingEntity en : entities.getArray(e)) {
for (final PotionEffectType t : ts)
en.removePotionEffect(t);
}
return;
}
int a = 0;
if (tier != null) {
final Number amp = tier.getSingle(e);
if (amp == null)
return;
a = amp.intValue() - 1;
}
int d = DEFAULT_DURATION;
if (duration != null) {
final Timespan dur = duration.getSingle(e);
if (dur == null)
return;
d = (int) (dur.getTicks_i() >= Integer.MAX_VALUE ? Integer.MAX_VALUE : dur.getTicks_i());
}
for (final LivingEntity en : entities.getArray(e)) {
for (final PotionEffectType t : ts) {
int duration = d;
if (!replaceExisting) {
if (en.hasPotionEffect(t)) {
for (final PotionEffect eff : en.getActivePotionEffects()) {
if (eff.getType() == t) {
duration += eff.getDuration();
break;
}
}
}
}
en.addPotionEffect(new PotionEffect(t, duration, a, ambient, particles), true);
}
protected void execute(Event e) {
PotionEffect[] potionEffects = this.potionEffects.getArray(e);

// Change duration for some backwards compatibility with older Skript versions
if (duration != null) {
Timespan timespan = duration.getSingle(e);
if (timespan != null) {
int ticks = (int) timespan.getTicks_i();
for (int i = 0; i < potionEffects.length; i++)
potionEffects[i] = potionEffects[i].withDuration(ticks);
APickledWalrus marked this conversation as resolved.
Show resolved Hide resolved
}
}

for (LivingEntity livingEntity : entities.getArray(e)) {
PotionEffectUtils.addEffects(livingEntity, potionEffects);
}
}

@Override
public String toString(final @Nullable Event e, final boolean debug) {
if (potionEffect)
return "apply " + potionEffects.toString(e, debug) + " to " + entities.toString(e, debug);
else if (apply)
return "apply " + potions.toString(e, debug) + (tier != null ? " of tier " + tier.toString(e, debug) : "") + " to " + entities.toString(e, debug) + (duration != null ? " for " + duration.toString(e, debug) : "");
else
return "remove " + potions.toString(e, debug) + " from " + entities.toString(e, debug);
return "apply " + potionEffects.toString(e, debug) + " to " + entities.toString(e, debug);
}

}
41 changes: 27 additions & 14 deletions src/main/java/ch/njol/skript/expressions/ExprPotionEffect.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
*/
package ch.njol.skript.expressions;

import ch.njol.skript.util.PotionEffectUtils;
import org.bukkit.event.Event;
import org.bukkit.potion.PotionEffect;
import org.bukkit.potion.PotionEffectType;
Expand All @@ -36,21 +37,29 @@
import ch.njol.util.Kleenean;

@Name("Potion Effect")
@Description({"Create a new potion effect to apply to an entity or item type. Do note that when applying potion effects ",
"to tipped arrows/lingering potions, Minecraft reduces the timespan."})
@Examples({"set {_p} to potion effect of speed of tier 1 without particles for 10 minutes",
"add {_p} to potion effects of player's tool",
"add {_p} to potion effects of target entity",
"add potion effect of speed 1 to potion effects of player"})
@Since("2.5.2")
@Description({
"Create a new potion effect to apply to an entity or item type. Do note that when applying potion effects ",
"to tipped arrows/lingering potions, Minecraft reduces the timespan."
})
@Examples({
"set {_p} to potion effect of speed of tier 1 without particles for 10 minutes",
"add {_p} to potion effects of player's tool",
"add {_p} to potion effects of target entity",
"add potion effect of speed 1 to potion effects of player"
})
@Since("2.5.2, INSERT VERSION (new syntax)")
public class ExprPotionEffect extends SimpleExpression<PotionEffect> {

static {
Skript.registerExpression(ExprPotionEffect.class, PotionEffect.class, ExpressionType.COMBINED,
"[new] potion effect of %potioneffecttype% [potion] [[[of] tier] %-number%] [(1¦without particles)] [for %-timespan%]",
"[new] ambient potion effect of %potioneffecttype% [potion] [[[of] tier] %-number%] [(1¦without particles)] [for %-timespan%]");
"[new] potion [effect] of %potioneffecttype% [potion] [[[of] tier] %-number%] [(1¦without particles)] [for %-timespan%]",
"[new] [potion [effect] of] %potioneffecttype% [potion] [[of] tier] %number% [(1¦without particles)] [for %-timespan%]", // "speed 2"
"[new] ambient potion [effect] of %potioneffecttype% [potion] [[[of] tier] %-number%] [(1¦without particles)] [for %-timespan%]",
"[new] ambient [potion [effect] of] %potioneffecttype% [potion] [[of] tier] %number% [(1¦without particles)] [for %-timespan%]" // "ambient speed 2"
);
APickledWalrus marked this conversation as resolved.
Show resolved Hide resolved
}

@SuppressWarnings("null")
@SuppressWarnings("NotNullFieldNotInitialized")
private Expression<PotionEffectType> potionEffectType;
@Nullable
private Expression<Number> tier;
Expand All @@ -60,33 +69,37 @@ public class ExprPotionEffect extends SimpleExpression<PotionEffect> {
private boolean ambient;

@Override
public boolean init(final Expression<?>[] exprs, final int matchedPattern, final Kleenean isDelayed, final ParseResult parseResult) {
@SuppressWarnings("unchecked")
public boolean init(Expression<?>[] exprs, int matchedPattern, Kleenean isDelayed, ParseResult parseResult) {
potionEffectType = (Expression<PotionEffectType>) exprs[0];
tier = (Expression<Number>) exprs[1];
timespan = (Expression<Timespan>) exprs[2];
particles = parseResult.mark == 0;
ambient = matchedPattern == 1;
ambient = matchedPattern >= 2;
return true;
}

@Override
@Nullable
protected PotionEffect[] get(final Event e) {
protected PotionEffect[] get(Event e) {
PotionEffectType potionEffectType = this.potionEffectType.getSingle(e);
if (potionEffectType == null)
return null;

int tier = 0;
if (this.tier != null) {
Number n = this.tier.getSingle(e);
if (n != null)
tier = n.intValue() - 1;
}
int ticks = 15 * 20; // 15 second default potion length

int ticks = PotionEffectUtils.DEFAULT_DURATION_TICKS;
if (this.timespan != null) {
Timespan timespan = this.timespan.getSingle(e);
if (timespan != null)
ticks = (int) timespan.getTicks_i();
}

return new PotionEffect[]{new PotionEffect(potionEffectType, ticks, tier, ambient, particles)};
}

Expand Down
10 changes: 8 additions & 2 deletions src/main/java/ch/njol/skript/util/PotionEffectUtils.java
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,12 @@
public abstract class PotionEffectUtils {

private static final boolean HAS_SUSPICIOUS_META = Skript.classExists("org.bukkit.inventory.meta.SuspiciousStewMeta");

/**
* 30 seconds is the default length for the /effect command
* https://minecraft.fandom.com/wiki/Commands/effect
*/
public static final int DEFAULT_DURATION_TICKS = 600;

private PotionEffectUtils() {}

Expand Down Expand Up @@ -248,7 +254,7 @@ public static void addEffects(LivingEntity entity, Object[] effects) {
if (object instanceof PotionEffect)
effect = (PotionEffect) object;
else if (object instanceof PotionEffectType)
effect = new PotionEffect((PotionEffectType) object, 15 * 20, 0, false);
effect = new PotionEffect((PotionEffectType) object, DEFAULT_DURATION_TICKS, 0, false);
else
continue;

Expand Down Expand Up @@ -303,7 +309,7 @@ public static void addEffects(ItemType itemType, Object[] effects) {
if (object instanceof PotionEffect)
effect = (PotionEffect) object;
else if (object instanceof PotionEffectType)
effect = new PotionEffect((PotionEffectType) object, 15 * 20, 0, false);
effect = new PotionEffect((PotionEffectType) object, DEFAULT_DURATION_TICKS, 0, false);
else
continue;

Expand Down