From 1f4ffeec8d9d0e69bf12a2258808132af7991494 Mon Sep 17 00:00:00 2001 From: DelayedGaming Date: Wed, 24 May 2023 00:56:18 +0800 Subject: [PATCH 001/176] Initial (pt 1) --- src/main/java/ch/njol/skript/events/EvtMove.java | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/src/main/java/ch/njol/skript/events/EvtMove.java b/src/main/java/ch/njol/skript/events/EvtMove.java index 58dfb2f2351..6e22096c85b 100644 --- a/src/main/java/ch/njol/skript/events/EvtMove.java +++ b/src/main/java/ch/njol/skript/events/EvtMove.java @@ -43,7 +43,7 @@ public class EvtMove extends SkriptEvent { else events = CollectionUtils.array(PlayerMoveEvent.class); - Skript.registerEvent("Move", EvtMove.class, events, "%entitydata% (move|walk|step)") + Skript.registerEvent("Move", EvtMove.class, events, "%entitydata% (move|walk|step|:rotate)") .description("Called when a player or entity moves.", "NOTE: Move event will only be called when the entity/player moves position, not orientation (ie: looking around).", "NOTE: These events can be performance heavy as they are called quite often.", @@ -60,11 +60,13 @@ public class EvtMove extends SkriptEvent { private EntityData type; private boolean isPlayer; + private boolean isRotate; @Override public boolean init(Literal[] args, int matchedPattern, ParseResult parseResult) { type = ((Literal>) args[0]).getSingle(); isPlayer = Player.class.isAssignableFrom(type.getType()); + isRotate = parseResult.hasTag("rotate"); if (!HAS_ENTITY_MOVE && !isPlayer) { Skript.error("Entity move event requires Paper 1.16.5+", ErrorQuality.SEMANTIC_ERROR); @@ -77,10 +79,14 @@ public boolean init(Literal[] args, int matchedPattern, ParseResult parseResu public boolean check(Event event) { if (isPlayer && event instanceof PlayerMoveEvent) { PlayerMoveEvent playerEvent = (PlayerMoveEvent) event; + if (isRotate) + return rotateCheck(playerEvent.getFrom(), playerEvent.getTo()); return moveCheck(playerEvent.getFrom(), playerEvent.getTo()); } else if (HAS_ENTITY_MOVE && event instanceof EntityMoveEvent) { EntityMoveEvent entityEvent = (EntityMoveEvent) event; if (type.isInstance(entityEvent.getEntity())) { + if (isRotate) + return rotateCheck(entityEvent.getFrom(), entityEvent.getTo()); return moveCheck(entityEvent.getFrom(), entityEvent.getTo()); } } @@ -109,4 +115,8 @@ private static boolean moveCheck(Location from, Location to) { return from.getX() != to.getX() || from.getY() != to.getY() || from.getZ() != to.getZ() || from.getWorld() != to.getWorld(); } + private static boolean rotateCheck(Location from, Location to) { + return !moveCheck(from, to) && from.getYaw() != to.getYaw() || from.getPitch() != to.getPitch(); + } + } From 2a9cc6f65510183856077c0d56e41e4f9beabcb5 Mon Sep 17 00:00:00 2001 From: DelayedGaming Date: Sat, 2 Sep 2023 00:38:46 +0800 Subject: [PATCH 002/176] Finish --- src/main/java/ch/njol/skript/events/EvtMove.java | 12 ++---------- 1 file changed, 2 insertions(+), 10 deletions(-) diff --git a/src/main/java/ch/njol/skript/events/EvtMove.java b/src/main/java/ch/njol/skript/events/EvtMove.java index 6e22096c85b..d20d2450008 100644 --- a/src/main/java/ch/njol/skript/events/EvtMove.java +++ b/src/main/java/ch/njol/skript/events/EvtMove.java @@ -79,15 +79,11 @@ public boolean init(Literal[] args, int matchedPattern, ParseResult parseResu public boolean check(Event event) { if (isPlayer && event instanceof PlayerMoveEvent) { PlayerMoveEvent playerEvent = (PlayerMoveEvent) event; - if (isRotate) - return rotateCheck(playerEvent.getFrom(), playerEvent.getTo()); - return moveCheck(playerEvent.getFrom(), playerEvent.getTo()); + return moveCheck(playerEvent.getFrom(), playerEvent.getTo()) ^ isRotate; } else if (HAS_ENTITY_MOVE && event instanceof EntityMoveEvent) { EntityMoveEvent entityEvent = (EntityMoveEvent) event; if (type.isInstance(entityEvent.getEntity())) { - if (isRotate) - return rotateCheck(entityEvent.getFrom(), entityEvent.getTo()); - return moveCheck(entityEvent.getFrom(), entityEvent.getTo()); + return moveCheck(entityEvent.getFrom(), entityEvent.getTo()) ^ isRotate; } } return false; @@ -115,8 +111,4 @@ private static boolean moveCheck(Location from, Location to) { return from.getX() != to.getX() || from.getY() != to.getY() || from.getZ() != to.getZ() || from.getWorld() != to.getWorld(); } - private static boolean rotateCheck(Location from, Location to) { - return !moveCheck(from, to) && from.getYaw() != to.getYaw() || from.getPitch() != to.getPitch(); - } - } From dd838d1b37c052719d755ed0b5febe0f8d8d6768 Mon Sep 17 00:00:00 2001 From: DelayedGaming Date: Sat, 2 Sep 2023 01:14:07 +0800 Subject: [PATCH 003/176] Clean up --- .../java/ch/njol/skript/events/EvtMove.java | 39 ++++++++++--------- 1 file changed, 21 insertions(+), 18 deletions(-) diff --git a/src/main/java/ch/njol/skript/events/EvtMove.java b/src/main/java/ch/njol/skript/events/EvtMove.java index d20d2450008..9b70d02fae6 100644 --- a/src/main/java/ch/njol/skript/events/EvtMove.java +++ b/src/main/java/ch/njol/skript/events/EvtMove.java @@ -23,14 +23,13 @@ import ch.njol.skript.lang.Literal; import ch.njol.skript.lang.SkriptEvent; import ch.njol.skript.lang.SkriptParser.ParseResult; -import ch.njol.skript.log.ErrorQuality; import ch.njol.util.coll.CollectionUtils; import io.papermc.paper.event.entity.EntityMoveEvent; import org.bukkit.Location; import org.bukkit.entity.Player; import org.bukkit.event.Event; import org.bukkit.event.player.PlayerMoveEvent; -import org.eclipse.jdt.annotation.Nullable; +import org.jetbrains.annotations.Nullable; public class EvtMove extends SkriptEvent { @@ -43,19 +42,23 @@ public class EvtMove extends SkriptEvent { else events = CollectionUtils.array(PlayerMoveEvent.class); - Skript.registerEvent("Move", EvtMove.class, events, "%entitydata% (move|walk|step|:rotate)") - .description("Called when a player or entity moves.", - "NOTE: Move event will only be called when the entity/player moves position, not orientation (ie: looking around).", - "NOTE: These events can be performance heavy as they are called quite often.", - "If you use these events, and later remove them, a server restart is recommended to clear registered events from Skript.") - .examples("on player move:", - "\tif player does not have permission \"player.can.move\":", - "\t\tcancel event", - "on skeleton move:", - "\tif event-entity is not in world \"world\":", - "\t\tkill event-entity") - .requiredPlugins("Paper 1.16.5+ (entity move)") - .since("2.6"); + Skript.registerEvent("Move / Rotate", EvtMove.class, events, "%entitydata% (move|walk|step|rotate:(look around|rotate))") + .description( + "Called when a player or entity moves or rotates their head.", + "NOTE: Move event will only be called when the entity/player moves position, not orientation (ie: looking around). Use the keyword 'rotate' instead.", + "NOTE: These events can be performance heavy as they are called quite often.", + "If you use these events, and later remove them, a server restart is recommended to clear registered events from Skript.") + .examples( + "on player move:", + "\tif player does not have permission \"player.can.move\":", + "\t\tcancel event", + "on skeleton move:", + "\tif event-entity is not in world \"world\":", + "\t\tkill event-entity", + "on player rotate:", + "send action bar \"You are currently looking around!\" to player") + .requiredPlugins("Paper 1.16.5+ (entity move)") + .since("2.6, INSERT VERSION (rotate)"); } private EntityData type; @@ -63,13 +66,13 @@ public class EvtMove extends SkriptEvent { private boolean isRotate; @Override + @SuppressWarnings("unchecked") public boolean init(Literal[] args, int matchedPattern, ParseResult parseResult) { type = ((Literal>) args[0]).getSingle(); isPlayer = Player.class.isAssignableFrom(type.getType()); isRotate = parseResult.hasTag("rotate"); - if (!HAS_ENTITY_MOVE && !isPlayer) { - Skript.error("Entity move event requires Paper 1.16.5+", ErrorQuality.SEMANTIC_ERROR); + Skript.error("Entity move event requires Paper 1.16.5+"); return false; } return true; @@ -103,7 +106,7 @@ public boolean check(Event event) { } @Override - public String toString(@Nullable Event e, boolean debug) { + public String toString(@Nullable Event event, boolean debug) { return type + " move"; } From 6ed6889dfbcefe0a966a410ba0de0413d6aa08de Mon Sep 17 00:00:00 2001 From: DelayedGaming Date: Sat, 2 Sep 2023 01:19:53 +0800 Subject: [PATCH 004/176] Clean up --- src/main/java/ch/njol/skript/events/EvtMove.java | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/main/java/ch/njol/skript/events/EvtMove.java b/src/main/java/ch/njol/skript/events/EvtMove.java index 9b70d02fae6..2a96778fb99 100644 --- a/src/main/java/ch/njol/skript/events/EvtMove.java +++ b/src/main/java/ch/njol/skript/events/EvtMove.java @@ -41,7 +41,6 @@ public class EvtMove extends SkriptEvent { events = CollectionUtils.array(PlayerMoveEvent.class, EntityMoveEvent.class); else events = CollectionUtils.array(PlayerMoveEvent.class); - Skript.registerEvent("Move / Rotate", EvtMove.class, events, "%entitydata% (move|walk|step|rotate:(look around|rotate))") .description( "Called when a player or entity moves or rotates their head.", @@ -100,9 +99,8 @@ public boolean check(Event event) { return new Class[] {PlayerMoveEvent.class}; } else if (HAS_ENTITY_MOVE) { return new Class[] {EntityMoveEvent.class}; - } else { - return null; } + return null; } @Override From 7d2b6f02dcf22f47cc9b478eca3787de06e23d52 Mon Sep 17 00:00:00 2001 From: DelayedGaming Date: Sat, 2 Sep 2023 01:25:14 +0800 Subject: [PATCH 005/176] Improve pattern --- src/main/java/ch/njol/skript/events/EvtMove.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/ch/njol/skript/events/EvtMove.java b/src/main/java/ch/njol/skript/events/EvtMove.java index 2a96778fb99..b3b9dc9bf41 100644 --- a/src/main/java/ch/njol/skript/events/EvtMove.java +++ b/src/main/java/ch/njol/skript/events/EvtMove.java @@ -41,7 +41,7 @@ public class EvtMove extends SkriptEvent { events = CollectionUtils.array(PlayerMoveEvent.class, EntityMoveEvent.class); else events = CollectionUtils.array(PlayerMoveEvent.class); - Skript.registerEvent("Move / Rotate", EvtMove.class, events, "%entitydata% (move|walk|step|rotate:(look around|rotate))") + Skript.registerEvent("Move / Rotate", EvtMove.class, events, "%entitydata% (move|walk|step|rotate:(look[ing] around|rotate))") .description( "Called when a player or entity moves or rotates their head.", "NOTE: Move event will only be called when the entity/player moves position, not orientation (ie: looking around). Use the keyword 'rotate' instead.", From c3da232dc51df40f16a03d94cd74d22b7f0b6d13 Mon Sep 17 00:00:00 2001 From: DelayedGaming Date: Sun, 3 Sep 2023 00:35:24 +0800 Subject: [PATCH 006/176] Revamped this class for the new features --- .../java/ch/njol/skript/events/EvtMove.java | 59 ++++++++++++++++--- 1 file changed, 50 insertions(+), 9 deletions(-) diff --git a/src/main/java/ch/njol/skript/events/EvtMove.java b/src/main/java/ch/njol/skript/events/EvtMove.java index b3b9dc9bf41..a9ef10eb39b 100644 --- a/src/main/java/ch/njol/skript/events/EvtMove.java +++ b/src/main/java/ch/njol/skript/events/EvtMove.java @@ -41,7 +41,9 @@ public class EvtMove extends SkriptEvent { events = CollectionUtils.array(PlayerMoveEvent.class, EntityMoveEvent.class); else events = CollectionUtils.array(PlayerMoveEvent.class); - Skript.registerEvent("Move / Rotate", EvtMove.class, events, "%entitydata% (move|walk|step|rotate:(look[ing] around|rotate))") + Skript.registerEvent("Move / Rotate", EvtMove.class, events, + "%entitydata% (move|walk|step|rotate:(look[ing] around|rotate))", + "%entitydata% (move|walk|step) or (look[ing] around|rotate)") .description( "Called when a player or entity moves or rotates their head.", "NOTE: Move event will only be called when the entity/player moves position, not orientation (ie: looking around). Use the keyword 'rotate' instead.", @@ -63,30 +65,65 @@ public class EvtMove extends SkriptEvent { private EntityData type; private boolean isPlayer; private boolean isRotate; + private Move moveType; + + private enum Move { + + POSITION("move"), + ORIENTATION("rotate"), + POSITION_OR_ORIENTATION("move or rotate"); + + private final String toString; + Move(String toString) { + this.toString = toString; + } + + public String getString() { + return toString; + } + + } @Override @SuppressWarnings("unchecked") public boolean init(Literal[] args, int matchedPattern, ParseResult parseResult) { type = ((Literal>) args[0]).getSingle(); - isPlayer = Player.class.isAssignableFrom(type.getType()); - isRotate = parseResult.hasTag("rotate"); if (!HAS_ENTITY_MOVE && !isPlayer) { Skript.error("Entity move event requires Paper 1.16.5+"); return false; } + isPlayer = Player.class.isAssignableFrom(type.getType()); + if (matchedPattern == 1) { + moveType = Move.POSITION_OR_ORIENTATION; + } else if (parseResult.hasTag("rotate")) { + moveType = Move.ORIENTATION; + } else { + moveType = Move.POSITION; + } return true; } @Override public boolean check(Event event) { + Location from, to; if (isPlayer && event instanceof PlayerMoveEvent) { PlayerMoveEvent playerEvent = (PlayerMoveEvent) event; - return moveCheck(playerEvent.getFrom(), playerEvent.getTo()) ^ isRotate; + from = playerEvent.getFrom(); + to = playerEvent.getTo(); } else if (HAS_ENTITY_MOVE && event instanceof EntityMoveEvent) { EntityMoveEvent entityEvent = (EntityMoveEvent) event; - if (type.isInstance(entityEvent.getEntity())) { - return moveCheck(entityEvent.getFrom(), entityEvent.getTo()) ^ isRotate; - } + from = entityEvent.getFrom(); + to = entityEvent.getTo(); + } else { + return false; + } + switch (moveType) { + case POSITION: + return hasChangedPosition(from, to); + case ORIENTATION: + return hasChangedOrientation(from, to); + case POSITION_OR_ORIENTATION: + return true; } return false; } @@ -105,11 +142,15 @@ public boolean check(Event event) { @Override public String toString(@Nullable Event event, boolean debug) { - return type + " move"; + return type + " " + moveType.getString(); } - private static boolean moveCheck(Location from, Location to) { + private static boolean hasChangedPosition(Location from, Location to) { return from.getX() != to.getX() || from.getY() != to.getY() || from.getZ() != to.getZ() || from.getWorld() != to.getWorld(); } + private static boolean hasChangedOrientation(Location from, Location to) { + return from.getYaw() != to.getYaw() || from.getPitch() != to.getPitch(); + } + } From 6e830c61aa702144a2929bb633862368577ac59a Mon Sep 17 00:00:00 2001 From: DelayedGaming Date: Mon, 4 Sep 2023 02:24:31 +0800 Subject: [PATCH 007/176] Requested changes + minor cleanup --- .../java/ch/njol/skript/events/EvtMove.java | 51 ++++++++++--------- 1 file changed, 27 insertions(+), 24 deletions(-) diff --git a/src/main/java/ch/njol/skript/events/EvtMove.java b/src/main/java/ch/njol/skript/events/EvtMove.java index a9ef10eb39b..6c76b6eaedb 100644 --- a/src/main/java/ch/njol/skript/events/EvtMove.java +++ b/src/main/java/ch/njol/skript/events/EvtMove.java @@ -43,12 +43,12 @@ public class EvtMove extends SkriptEvent { events = CollectionUtils.array(PlayerMoveEvent.class); Skript.registerEvent("Move / Rotate", EvtMove.class, events, "%entitydata% (move|walk|step|rotate:(look[ing] around|rotate))", - "%entitydata% (move|walk|step) or (look[ing] around|rotate)") + "%entitydata% (move|walk|step) or (look[ing] around|rotate)", + "%entitydata% (look[ing] around|rotate) or (move|walk|step)") .description( "Called when a player or entity moves or rotates their head.", - "NOTE: Move event will only be called when the entity/player moves position, not orientation (ie: looking around). Use the keyword 'rotate' instead.", - "NOTE: These events can be performance heavy as they are called quite often.", - "If you use these events, and later remove them, a server restart is recommended to clear registered events from Skript.") + "NOTE: Move event will only be called when the entity/player moves position, keyword 'rotate' is for orientation (ie: looking around), and the combined syntax listens for both.", + "NOTE: These events can be performance heavy as they are called quite often.") .examples( "on player move:", "\tif player does not have permission \"player.can.move\":", @@ -62,24 +62,25 @@ public class EvtMove extends SkriptEvent { .since("2.6, INSERT VERSION (rotate)"); } - private EntityData type; + private EntityData entityData; private boolean isPlayer; - private boolean isRotate; private Move moveType; private enum Move { - POSITION("move"), - ORIENTATION("rotate"), - POSITION_OR_ORIENTATION("move or rotate"); + MOVE("move"), + MOVE_OR_ROTATE("move or rotate"), + ROTATE("rotate"); - private final String toString; - Move(String toString) { - this.toString = toString; + private final String name; + + Move(String name) { + this.name = name; } - public String getString() { - return toString; + @Override + public String toString() { + return name; } } @@ -87,18 +88,18 @@ public String getString() { @Override @SuppressWarnings("unchecked") public boolean init(Literal[] args, int matchedPattern, ParseResult parseResult) { - type = ((Literal>) args[0]).getSingle(); + entityData = ((Literal>) args[0]).getSingle(); + isPlayer = Player.class.isAssignableFrom(entityData.getType()); if (!HAS_ENTITY_MOVE && !isPlayer) { Skript.error("Entity move event requires Paper 1.16.5+"); return false; } - isPlayer = Player.class.isAssignableFrom(type.getType()); - if (matchedPattern == 1) { - moveType = Move.POSITION_OR_ORIENTATION; + if (matchedPattern > 0) { + moveType = Move.MOVE_OR_ROTATE; } else if (parseResult.hasTag("rotate")) { - moveType = Move.ORIENTATION; + moveType = Move.ROTATE; } else { - moveType = Move.POSITION; + moveType = Move.MOVE; } return true; } @@ -112,17 +113,19 @@ public boolean check(Event event) { to = playerEvent.getTo(); } else if (HAS_ENTITY_MOVE && event instanceof EntityMoveEvent) { EntityMoveEvent entityEvent = (EntityMoveEvent) event; + if (!(entityData.isInstance(entityEvent.getEntity()))) + return false; from = entityEvent.getFrom(); to = entityEvent.getTo(); } else { return false; } switch (moveType) { - case POSITION: + case MOVE: return hasChangedPosition(from, to); - case ORIENTATION: + case ROTATE: return hasChangedOrientation(from, to); - case POSITION_OR_ORIENTATION: + case MOVE_OR_ROTATE: return true; } return false; @@ -142,7 +145,7 @@ public boolean check(Event event) { @Override public String toString(@Nullable Event event, boolean debug) { - return type + " " + moveType.getString(); + return entityData + " " + moveType; } private static boolean hasChangedPosition(Location from, Location to) { From d4c0a68010fb2558a92eb3cc02edde518f0e4601 Mon Sep 17 00:00:00 2001 From: _tud Date: Sun, 17 Sep 2023 14:38:05 +0300 Subject: [PATCH 008/176] Fix ExprRandomNumber using a method from Java 17 (#6022) --- src/main/java/ch/njol/skript/expressions/ExprRandomNumber.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/ch/njol/skript/expressions/ExprRandomNumber.java b/src/main/java/ch/njol/skript/expressions/ExprRandomNumber.java index d774cbd9848..ba3853ad311 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprRandomNumber.java +++ b/src/main/java/ch/njol/skript/expressions/ExprRandomNumber.java @@ -88,7 +88,7 @@ protected Number[] get(Event event) { return new Long[] {sup}; return new Long[0]; } - return new Long[] {random.nextLong(inf, sup + 1)}; + return new Long[] {inf + Math2.mod(random.nextLong(), sup - inf + 1)}; } return new Double[] {min + random.nextDouble() * (max - min)}; From e04806843413bb52a5f06a0755cf69b400cf5fc1 Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Sun, 17 Sep 2023 04:46:06 -0700 Subject: [PATCH 009/176] Fix changing remaining time of command cooldown (#6021) Update ScriptCommand.java Co-authored-by: Moderocky --- .../ch/njol/skript/command/ScriptCommand.java | 86 +++++++++++-------- 1 file changed, 49 insertions(+), 37 deletions(-) diff --git a/src/main/java/ch/njol/skript/command/ScriptCommand.java b/src/main/java/ch/njol/skript/command/ScriptCommand.java index 93e8cad25b0..be7942e3ca7 100644 --- a/src/main/java/ch/njol/skript/command/ScriptCommand.java +++ b/src/main/java/ch/njol/skript/command/ScriptCommand.java @@ -18,44 +18,11 @@ */ package ch.njol.skript.command; -import java.lang.reflect.Constructor; -import java.lang.reflect.Field; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.HashMap; -import java.util.Iterator; -import java.util.List; -import java.util.Locale; -import java.util.Map; -import java.util.Map.Entry; -import java.util.Set; -import java.util.UUID; - import ch.njol.skript.ScriptLoader; -import ch.njol.skript.config.SectionNode; -import org.skriptlang.skript.lang.script.Script; -import org.bukkit.Bukkit; -import org.bukkit.ChatColor; -import org.bukkit.OfflinePlayer; -import org.bukkit.command.Command; -import org.bukkit.command.CommandSender; -import org.bukkit.command.PluginCommand; -import org.bukkit.command.SimpleCommandMap; -import org.bukkit.command.TabExecutor; -import org.bukkit.entity.Player; -import org.bukkit.event.Event; -import org.bukkit.help.GenericCommandHelpTopic; -import org.bukkit.help.HelpMap; -import org.bukkit.help.HelpTopic; -import org.bukkit.help.HelpTopicComparator; -import org.bukkit.help.IndexHelpTopic; -import org.bukkit.plugin.Plugin; -import org.eclipse.jdt.annotation.Nullable; - import ch.njol.skript.Skript; import ch.njol.skript.SkriptConfig; import ch.njol.skript.command.Commands.CommandAliasHelpTopic; +import ch.njol.skript.config.SectionNode; import ch.njol.skript.lang.Expression; import ch.njol.skript.lang.SkriptParser; import ch.njol.skript.lang.Trigger; @@ -77,6 +44,39 @@ import ch.njol.skript.variables.Variables; import ch.njol.util.StringUtils; import ch.njol.util.Validate; +import org.bukkit.Bukkit; +import org.bukkit.ChatColor; +import org.bukkit.OfflinePlayer; +import org.bukkit.command.Command; +import org.bukkit.command.CommandSender; +import org.bukkit.command.PluginCommand; +import org.bukkit.command.SimpleCommandMap; +import org.bukkit.command.TabExecutor; +import org.bukkit.entity.Player; +import org.bukkit.event.Event; +import org.bukkit.help.GenericCommandHelpTopic; +import org.bukkit.help.HelpMap; +import org.bukkit.help.HelpTopic; +import org.bukkit.help.HelpTopicComparator; +import org.bukkit.help.IndexHelpTopic; +import org.bukkit.plugin.Plugin; +import org.eclipse.jdt.annotation.Nullable; +import org.skriptlang.skript.lang.script.Script; + +import java.lang.reflect.Constructor; +import java.lang.reflect.Field; +import java.util.ArrayList; +import java.util.Collection; +import java.util.Collections; +import java.util.HashMap; +import java.util.Iterator; +import java.util.List; +import java.util.Locale; +import java.util.Map; +import java.util.Map.Entry; +import java.util.Objects; +import java.util.Set; +import java.util.UUID; /** * This class is used for user-defined commands. @@ -274,9 +274,21 @@ public boolean execute(final CommandSender sender, final String commandLabel, fi } Runnable runnable = () -> { + // save previous last usage date to check if the execution has set the last usage date + Date previousLastUsage = null; + if (sender instanceof Player) + previousLastUsage = getLastUsage(((Player) sender).getUniqueId(), event); + + // execute the command - may modify the last usage date execute2(event, sender, commandLabel, rest); - if (sender instanceof Player && !event.isCooldownCancelled()) - setLastUsage(((Player) sender).getUniqueId(), event, new Date()); + + if (sender instanceof Player && !event.isCooldownCancelled()) { + Date lastUsage = getLastUsage(((Player) sender).getUniqueId(), event); + // check if the execution has set the last usage date + // if not, set it to the current date. if it has, we leave it alone so as not to affect the remaining/elapsed time (#5862) + if (Objects.equals(lastUsage, previousLastUsage)) + setLastUsage(((Player) sender).getUniqueId(), event, new Date()); + } }; if (Bukkit.isPrimaryThread()) { runnable.run(); @@ -510,7 +522,7 @@ public void setRemainingMilliseconds(UUID uuid, Event event, long milliseconds) assert cooldown != null; long cooldownMs = cooldown.getMilliSeconds(); if (milliseconds > cooldownMs) - throw new IllegalArgumentException("Remaining time may not be longer than the cooldown"); + milliseconds = cooldownMs; setElapsedMilliSeconds(uuid, event, cooldownMs - milliseconds); } From 4b78e985bf67527f8a4be41cd75ab81766eba2ff Mon Sep 17 00:00:00 2001 From: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> Date: Sun, 17 Sep 2023 08:00:47 -0600 Subject: [PATCH 010/176] Bump version to 2.7.1 (#5993) Co-authored-by: Moderocky --- gradle.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle.properties b/gradle.properties index 62d7b588c56..a8e8c966957 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,6 +1,6 @@ groupid=ch.njol name=skript -version=2.7.0 +version=2.7.1 jarName=Skript.jar testEnv=java17/paper-1.20.1 testEnvJavaVersion=17 From da67d640ff2f4c1ea78c9dcbae071597908fc78f Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Mon, 18 Sep 2023 01:43:47 -0700 Subject: [PATCH 011/176] fix 3 stray INSERT VERSIONs from 2.7.0 (#6027) correct incorrect values --- src/main/java/ch/njol/skript/conditions/CondIsInfinite.java | 2 +- src/main/java/ch/njol/skript/effects/EffPotion.java | 2 +- src/main/java/ch/njol/skript/events/SimpleEvents.java | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/main/java/ch/njol/skript/conditions/CondIsInfinite.java b/src/main/java/ch/njol/skript/conditions/CondIsInfinite.java index 98ed56c0570..725480bac1b 100644 --- a/src/main/java/ch/njol/skript/conditions/CondIsInfinite.java +++ b/src/main/java/ch/njol/skript/conditions/CondIsInfinite.java @@ -31,7 +31,7 @@ @Name("Is Infinite") @Description("Checks whether potion effects are infinite.") @Examples("all of the active potion effects of the player are infinite") -@Since("INSERT VERSION") +@Since("2.7") public class CondIsInfinite extends PropertyCondition { static { diff --git a/src/main/java/ch/njol/skript/effects/EffPotion.java b/src/main/java/ch/njol/skript/effects/EffPotion.java index 46abcb3ecf4..4ebc19e8d9f 100644 --- a/src/main/java/ch/njol/skript/effects/EffPotion.java +++ b/src/main/java/ch/njol/skript/effects/EffPotion.java @@ -52,7 +52,7 @@ @Since( "2.0, 2.2-dev27 (ambient and particle-less potion effects), " + "2.5 (replacing existing effect), 2.5.2 (potion effects), " + - "INSERT VERSION (icon and infinite)" + "2.7 (icon and infinite)" ) public class EffPotion extends Effect { diff --git a/src/main/java/ch/njol/skript/events/SimpleEvents.java b/src/main/java/ch/njol/skript/events/SimpleEvents.java index bcb301489e1..376acae9d13 100644 --- a/src/main/java/ch/njol/skript/events/SimpleEvents.java +++ b/src/main/java/ch/njol/skript/events/SimpleEvents.java @@ -718,7 +718,7 @@ public class SimpleEvents { "\t\tsend \"You can't drag your items here!\" to player", "\t\tcancel event" ) - .since("INSERT VERSION"); + .since("2.7"); } From a27101f8026d029685bb7fd3d2b736af03ae143d Mon Sep 17 00:00:00 2001 From: Patrick Miller Date: Tue, 19 Sep 2023 17:53:49 -0400 Subject: [PATCH 012/176] Fix Documentation Actions on dev/patch (#6042) --- .github/workflows/cleanup-docs.yml | 39 +++++++++++ .../workflows/docs/generate-docs/action.yml | 64 ++++++++++++++++++- .github/workflows/docs/push-docs/action.yml | 14 ++-- .github/workflows/docs/setup-docs/action.yml | 1 - .github/workflows/nightly-docs.yml | 15 ++++- .github/workflows/release-docs.yml | 4 +- build.gradle | 31 ++++++--- .../ch/njol/skript/doc/Documentation.java | 2 +- 8 files changed, 146 insertions(+), 24 deletions(-) create mode 100644 .github/workflows/cleanup-docs.yml diff --git a/.github/workflows/cleanup-docs.yml b/.github/workflows/cleanup-docs.yml new file mode 100644 index 00000000000..750bab83213 --- /dev/null +++ b/.github/workflows/cleanup-docs.yml @@ -0,0 +1,39 @@ +name: Cleanup nightly documentation +on: delete +jobs: + cleanup-nightly-docs: + if: github.event.ref_type == 'branch' + runs-on: ubuntu-latest + steps: + - name: Configure workflow + id: configuration + env: + DELETED_BRANCH: ${{ github.event.ref }} + run: | + BRANCH_NAME="${DELETED_BRANCH#refs/*/}" + echo "BRANCH_NAME=${BRANCH_NAME}" >> $GITHUB_OUTPUT + echo "DOCS_OUTPUT_DIR=${GITHUB_WORKSPACE}/skript-docs/docs/nightly/${BRANCH_NAME}" >> $GITHUB_OUTPUT + echo "DOCS_REPO_DIR=${GITHUB_WORKSPACE}/skript-docs" >> $GITHUB_OUTPUT + - name: Checkout Skript + uses: actions/checkout@v3 + with: + ref: ${{ github.event.repository.default_branch }} + submodules: recursive + path: skript + - name: Setup documentation environment + uses: ./skript/.github/workflows/docs/setup-docs + with: + docs_deploy_key: ${{ secrets.DOCS_DEPLOY_KEY }} + docs_output_dir: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} + - name: Cleanup nightly documentation + env: + DOCS_OUTPUT_DIR: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} + run: | + rm -rf ${DOCS_OUTPUT_DIR} || true + - name: Push nightly documentation cleanup + uses: ./skript/.github/workflows/docs/push-docs + with: + docs_repo_dir: ${{ steps.configuration.outputs.DOCS_REPO_DIR }} + git_name: Nightly Docs Bot + git_email: nightlydocs@skriptlang.org + git_commit_message: "Delete ${{ steps.configuration.outputs.BRANCH_NAME }} branch nightly docs" diff --git a/.github/workflows/docs/generate-docs/action.yml b/.github/workflows/docs/generate-docs/action.yml index f84023a60df..84cc2153f86 100644 --- a/.github/workflows/docs/generate-docs/action.yml +++ b/.github/workflows/docs/generate-docs/action.yml @@ -18,24 +18,82 @@ inputs: required: false default: false type: boolean + cleanup_pattern: + description: "A pattern designating which files to delete when cleaning the documentation output directory" + required: false + default: "*" + type: string + +outputs: + DOCS_CHANGED: + description: "Whether or not the documentation has changed since the last push" + value: ${{ steps.generate.outputs.DOCS_CHANGED }} runs: using: 'composite' steps: - name: generate-docs + id: generate shell: bash env: DOCS_OUTPUT_DIR: ${{ inputs.docs_output_dir }} DOCS_REPO_DIR: ${{ inputs.docs_repo_dir }} SKRIPT_REPO_DIR: ${{ inputs.skript_repo_dir }} IS_RELEASE: ${{ inputs.is_release }} + CLEANUP_PATTERN: ${{ inputs.cleanup_pattern }} run: | - export SKRIPT_DOCS_TEMPLATE_DIR=${DOCS_REPO_DIR}/doc-templates - export SKRIPT_DOCS_OUTPUT_DIR=${DOCS_OUTPUT_DIR}/ + replace_in_directory() { + find $1 -type f -exec sed -i -e "s/$2/$3/g" {} \; + } + + # this should be replaced with a more reliable jq command, + # but it can't be right now because docs.json is actually not valid json. + get_skript_version_of_directory() { + grep skriptVersion "$1/docs.json" | cut -d\" -f 4 + } + + if [ -d "${DOCS_REPO_DIR}/docs/templates" ] + then + export SKRIPT_DOCS_TEMPLATE_DIR=${DOCS_REPO_DIR}/docs/templates + else + export SKRIPT_DOCS_TEMPLATE_DIR=${DOCS_REPO_DIR}/doc-templates + fi + + export SKRIPT_DOCS_OUTPUT_DIR=/tmp/generated-docs + cd $SKRIPT_REPO_DIR if [[ "${IS_RELEASE}" == "true" ]]; then ./gradlew genReleaseDocs releaseJavadoc else ./gradlew genNightlyDocs javadoc fi - cp -a "./build/docs/javadoc/." "${DOCS_OUTPUT_DIR}/javadocs" + + if [ -d "${DOCS_OUTPUT_DIR}" ]; then + mkdir -p "${SKRIPT_DOCS_OUTPUT_DIR}/javadocs" && cp -a "./build/docs/javadoc/." "$_" + + mkdir -p "/tmp/normalized-output-docs" && cp -a "${DOCS_OUTPUT_DIR}/." "$_" + mkdir -p "/tmp/normalized-generated-docs" && cp -a "${SKRIPT_DOCS_OUTPUT_DIR}/." "$_" + + output_skript_version=$(get_skript_version_of_directory "/tmp/normalized-output-docs") + generated_skript_version=$(get_skript_version_of_directory "/tmp/normalized-generated-docs") + + replace_in_directory "/tmp/normalized-output-docs" "${output_skript_version}" "Skript" + replace_in_directory "/tmp/normalized-generated-docs" "${generated_skript_version}" "Skript" + + diff -qbr /tmp/normalized-output-docs /tmp/normalized-generated-docs || diff_exit_code=$? + # If diff exits with exit code 1, that means there were some differences + if [[ ${diff_exit_code} -eq 1 ]]; then + echo "DOCS_CHANGED=true" >> $GITHUB_OUTPUT + echo "Documentation has changed since last push" + else + echo "Documentation hasn't changed since last push" + fi + else + echo "DOCS_CHANGED=true" >> $GITHUB_OUTPUT + echo "No existing documentation found" + fi + + rm -rf ${DOCS_OUTPUT_DIR}/${CLEANUP_PATTERN} || true + mkdir -p "${DOCS_OUTPUT_DIR}/" && cp -a "${SKRIPT_DOCS_OUTPUT_DIR}/." "$_" + + diff --git a/.github/workflows/docs/push-docs/action.yml b/.github/workflows/docs/push-docs/action.yml index bcc296a85c3..477a4c46aa4 100644 --- a/.github/workflows/docs/push-docs/action.yml +++ b/.github/workflows/docs/push-docs/action.yml @@ -1,10 +1,6 @@ -name: Generate documentation +name: Push documentation inputs: - docs_output_dir: - description: "The directory to generate the documentation into" - required: true - type: string docs_repo_dir: description: "The skript-docs repository directory" required: true @@ -38,4 +34,10 @@ runs: git config user.email "${GIT_EMAIL}" git add -A git commit -m "${GIT_COMMIT_MESSAGE}" || (echo "Nothing to push!" && exit 0) - git push origin main + # Attempt rebasing and pushing 5 times in case another job pushes before us + for i in 1 2 3 4 5 + do + git pull --rebase -X theirs origin main + git push origin main && break + sleep 5 + done diff --git a/.github/workflows/docs/setup-docs/action.yml b/.github/workflows/docs/setup-docs/action.yml index 1feedcd8f10..cd6c6a05216 100644 --- a/.github/workflows/docs/setup-docs/action.yml +++ b/.github/workflows/docs/setup-docs/action.yml @@ -38,7 +38,6 @@ runs: CLEANUP_PATTERN: ${{ inputs.cleanup_pattern }} run: | eval `ssh-agent` - rm -rf ${DOCS_OUTPUT_DIR}/${CLEANUP_PATTERN} || true echo "$DOCS_DEPLOY_KEY" | tr -d '\r' | ssh-add - > /dev/null mkdir ~/.ssh ssh-keyscan www.github.com >> ~/.ssh/known_hosts diff --git a/.github/workflows/nightly-docs.yml b/.github/workflows/nightly-docs.yml index 2a6841c3771..782b76b9ed5 100644 --- a/.github/workflows/nightly-docs.yml +++ b/.github/workflows/nightly-docs.yml @@ -9,12 +9,20 @@ on: jobs: nightly-docs: - if: "! contains(toJSON(github.event.commits.*.message), '[ci skip]')" + if: "!contains(toJSON(github.event.commits.*.message), '[ci skip]')" runs-on: ubuntu-latest steps: - name: Configure workflow id: configuration + env: + DOCS_DEPLOY_KEY: ${{ secrets.DOCS_DEPLOY_KEY }} run: | + if [ -n "$DOCS_DEPLOY_KEY" ] + then + echo "DOCS_DEPLOY_KEY_PRESENT=true" >> $GITHUB_OUTPUT + else + echo "Secret 'DOCS_DEPLOY_KEY' not present. Exiting job." + fi BRANCH_NAME="${GITHUB_REF#refs/*/}" echo "BRANCH_NAME=${BRANCH_NAME}" >> $GITHUB_OUTPUT echo "DOCS_OUTPUT_DIR=${GITHUB_WORKSPACE}/skript-docs/docs/nightly/${BRANCH_NAME}" >> $GITHUB_OUTPUT @@ -26,20 +34,23 @@ jobs: submodules: recursive path: skript - name: Setup documentation environment + if: steps.configuration.outputs.DOCS_DEPLOY_KEY_PRESENT == 'true' uses: ./skript/.github/workflows/docs/setup-docs with: docs_deploy_key: ${{ secrets.DOCS_DEPLOY_KEY }} docs_output_dir: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} - name: Generate documentation + id: generate + if: steps.configuration.outputs.DOCS_DEPLOY_KEY_PRESENT == 'true' uses: ./skript/.github/workflows/docs/generate-docs with: docs_output_dir: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} docs_repo_dir: ${{ steps.configuration.outputs.DOCS_REPO_DIR }} skript_repo_dir: ${{ steps.configuration.outputs.SKRIPT_REPO_DIR }} - name: Push nightly documentation + if: steps.generate.outputs.DOCS_CHANGED == 'true' uses: ./skript/.github/workflows/docs/push-docs with: - docs_output_dir: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} docs_repo_dir: ${{ steps.configuration.outputs.DOCS_REPO_DIR }} git_name: Nightly Docs Bot git_email: nightlydocs@skriptlang.org diff --git a/.github/workflows/release-docs.yml b/.github/workflows/release-docs.yml index 9ec5a5ad257..a8ccb4000bb 100644 --- a/.github/workflows/release-docs.yml +++ b/.github/workflows/release-docs.yml @@ -26,7 +26,6 @@ jobs: with: docs_deploy_key: ${{ secrets.DOCS_DEPLOY_KEY }} docs_output_dir: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} - cleanup_pattern: "!(nightly|archives)" - name: Generate documentation uses: ./skript/.github/workflows/docs/generate-docs with: @@ -34,6 +33,7 @@ jobs: docs_repo_dir: ${{ steps.configuration.outputs.DOCS_REPO_DIR }} skript_repo_dir: ${{ steps.configuration.outputs.SKRIPT_REPO_DIR }} is_release: true + cleanup_pattern: "!(nightly|archives|templates)" - name: Push release documentation uses: ./skript/.github/workflows/docs/push-docs with: @@ -68,14 +68,12 @@ jobs: - name: Generate documentation uses: ./skript/.github/workflows/docs/generate-docs with: - docs_output_dir: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} docs_repo_dir: ${{ steps.configuration.outputs.DOCS_REPO_DIR }} skript_repo_dir: ${{ steps.configuration.outputs.SKRIPT_REPO_DIR }} is_release: true - name: Push archive documentation uses: ./skript/.github/workflows/docs/push-docs with: - docs_output_dir: ${{ steps.configuration.outputs.DOCS_OUTPUT_DIR }} docs_repo_dir: ${{ steps.configuration.outputs.DOCS_REPO_DIR }} git_name: Archive Docs Bot git_email: archivedocs@skriptlang.org diff --git a/build.gradle b/build.gradle index 5920cb95ac8..9a525ff1e1d 100644 --- a/build.gradle +++ b/build.gradle @@ -149,14 +149,6 @@ license { exclude('**/*.json') // JSON files do not have headers } -javadoc { - source = sourceSets.main.allJava - classpath = configurations.compileClasspath - options.encoding = 'UTF-8' - // currently our javadoc has a lot of errors, so we need to suppress the linter - options.addStringOption('Xdoclint:none', '-quiet') -} - task releaseJavadoc(type: Javadoc) { title = project.property('version') source = sourceSets.main.allJava @@ -394,3 +386,26 @@ task nightlyRelease(type: ShadowJar) { ) } } + +javadoc { + dependsOn nightlyResources + + source = sourceSets.main.allJava + + exclude("ch/njol/skript/conditions/**") + exclude("ch/njol/skript/expressions/**") + exclude("ch/njol/skript/effects/**") + exclude("ch/njol/skript/events/**") + exclude("ch/njol/skript/sections/**") + exclude("ch/njol/skript/structures/**") + exclude("ch/njol/skript/lang/function/EffFunctionCall.java") + exclude("ch/njol/skript/lang/function/ExprFunctionCall.java") + exclude("ch/njol/skript/hooks/**") + exclude("ch/njol/skript/test/**") + + classpath = configurations.compileClasspath + sourceSets.main.output + options.encoding = 'UTF-8' + // currently our javadoc has a lot of errors, so we need to suppress the linter + options.addStringOption('Xdoclint:none', '-quiet') +} + diff --git a/src/main/java/ch/njol/skript/doc/Documentation.java b/src/main/java/ch/njol/skript/doc/Documentation.java index 5da07aefb09..c7b9ebebbb1 100644 --- a/src/main/java/ch/njol/skript/doc/Documentation.java +++ b/src/main/java/ch/njol/skript/doc/Documentation.java @@ -60,7 +60,7 @@ public class Documentation { private static final Pattern CP_EMPTY_PARSE_MARKS_PATTERN = Pattern.compile("\\(\\)"); private static final Pattern CP_PARSE_TAGS_PATTERN = Pattern.compile("(?<=[(|\\[ ])[-a-zA-Z0-9!$#%^&*_+~=\"'<>?,.]*?:"); private static final Pattern CP_EXTRA_OPTIONAL_PATTERN = Pattern.compile("\\[\\(((\\w+? ?)+)\\)]"); - private static final File DOCS_TEMPLATE_DIRECTORY = new File(Skript.getInstance().getDataFolder(), "doc-templates"); + private static final File DOCS_TEMPLATE_DIRECTORY = new File(Skript.getInstance().getDataFolder(), "docs/templates"); private static final File DOCS_OUTPUT_DIRECTORY = new File(Skript.getInstance().getDataFolder(), "docs"); /** From 9e429f2597a7c39de6c9b7faa0c26f7c66fab6c9 Mon Sep 17 00:00:00 2001 From: Moderocky Date: Wed, 20 Sep 2023 09:34:31 +0100 Subject: [PATCH 013/176] Tidy up parts of config class. (#6025) --- .../java/ch/njol/skript/config/Config.java | 61 ++++++++----------- 1 file changed, 26 insertions(+), 35 deletions(-) diff --git a/src/main/java/ch/njol/skript/config/Config.java b/src/main/java/ch/njol/skript/config/Config.java index 6ec44491749..bcabb8859f3 100644 --- a/src/main/java/ch/njol/skript/config/Config.java +++ b/src/main/java/ch/njol/skript/config/Config.java @@ -18,9 +18,11 @@ */ package ch.njol.skript.config; +import ch.njol.skript.Skript; +import ch.njol.skript.config.validate.SectionValidator; + import java.io.ByteArrayInputStream; import java.io.File; -import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.io.PrintWriter; @@ -28,15 +30,13 @@ import java.lang.reflect.Modifier; import java.nio.channels.Channels; import java.nio.channels.FileChannel; +import java.nio.file.Files; import java.nio.file.Path; import java.util.HashMap; import org.eclipse.jdt.annotation.NonNull; import org.eclipse.jdt.annotation.Nullable; -import ch.njol.skript.Skript; -import ch.njol.skript.config.validate.SectionValidator; - /** * Represents a config file. * @@ -44,7 +44,7 @@ */ public class Config implements Comparable { - boolean simple = false; + boolean simple; /** * One level of the indentation, e.g. a tab or 4 spaces. @@ -58,8 +58,6 @@ public class Config implements Comparable { final String defaultSeparator; String separator; - String line = ""; - int level = 0; private final SectionNode main; @@ -91,11 +89,8 @@ public Config(final InputStream source, final String fileName, @Nullable final F if (Skript.logVeryHigh()) Skript.info("loading '" + fileName + "'"); - final ConfigReader r = new ConfigReader(source); - try { - main = SectionNode.load(this, r); - } finally { - r.close(); + try (ConfigReader reader = new ConfigReader(source)) { + main = SectionNode.load(this, reader); } } finally { source.close(); @@ -106,9 +101,8 @@ public Config(final InputStream source, final String fileName, final boolean sim this(source, fileName, null, simple, allowEmptySections, defaultSeparator); } - @SuppressWarnings("resource") public Config(final File file, final boolean simple, final boolean allowEmptySections, final String defaultSeparator) throws IOException { - this(new FileInputStream(file), "" + file.getName(), simple, allowEmptySections, defaultSeparator); + this(Files.newInputStream(file.toPath()), file.getName(), simple, allowEmptySections, defaultSeparator); this.file = file.toPath(); } @@ -120,7 +114,7 @@ public Config(final Path file, final boolean simple, final boolean allowEmptySec /** * For testing - * + * * @param s * @param fileName * @param simple @@ -133,7 +127,7 @@ public Config(final String s, final String fileName, final boolean simple, final } void setIndentation(final String indent) { - assert indent != null && indent.length() > 0 : indent; + assert indent != null && !indent.isEmpty() : indent; indentation = indent; indentationName = (indent.charAt(0) == ' ' ? "space" : "tab"); } @@ -156,7 +150,7 @@ public String getFileName() { /** * Saves the config to a file. - * + * * @param f The file to save to * @throws IOException If the file could not be written to. */ @@ -175,7 +169,7 @@ public void save(final File f) throws IOException { * Sets this config's values to those in the given config. *

* Used by Skript to import old settings into the updated config. The return value is used to not modify the config if no new options were added. - * + * * @param other * @return Whether the configs' keys differ, i.e. false == configs only differ in values, not keys. */ @@ -203,7 +197,7 @@ public File getFile() { if (file != null) { try { return file.toFile(); - } catch(Exception e) { + } catch (Exception e) { return null; // ZipPath, for example, throws undocumented exception } } @@ -235,7 +229,7 @@ public String getSaveSeparator() { /** * Splits the given path at the dot character and passes the result to {@link #get(String...)}. - * + * * @param path * @return get(path.split("\\.")) */ @@ -247,7 +241,7 @@ public String getByPath(final String path) { /** * Gets an entry node's value at the designated path - * + * * @param path * @return The entry node's value at the location defined by path or null if it either doesn't exist or is not an entry. */ @@ -284,22 +278,19 @@ public boolean validate(final SectionValidator validator) { return validator.validate(getMainNode()); } - private void load(final Class c, final @Nullable Object o, final String path) { - for (final Field f : c.getDeclaredFields()) { - f.setAccessible(true); - if (o != null || Modifier.isStatic(f.getModifiers())) { + private void load(final Class cls, final @Nullable Object object, final String path) { + for (final Field field : cls.getDeclaredFields()) { + field.setAccessible(true); + if (object != null || Modifier.isStatic(field.getModifiers())) { try { - if (OptionSection.class.isAssignableFrom(f.getType())) { - final Object p = f.get(o); - @NonNull - final Class pc = p.getClass(); - load(pc, p, path + ((OptionSection) p).key + "."); - } else if (Option.class.isAssignableFrom(f.getType())) { - ((Option) f.get(o)).set(this, path); + if (OptionSection.class.isAssignableFrom(field.getType())) { + final OptionSection section = (OptionSection) field.get(object); + @NonNull final Class pc = section.getClass(); + load(pc, section, path + section.key + "."); + } else if (Option.class.isAssignableFrom(field.getType())) { + ((Option) field.get(object)).set(this, path); } - } catch (final IllegalArgumentException e) { - assert false; - } catch (final IllegalAccessException e) { + } catch (final IllegalArgumentException | IllegalAccessException e) { assert false; } } From 438851a4648dba346911b54312f117800845d1e6 Mon Sep 17 00:00:00 2001 From: Patrick Miller Date: Wed, 20 Sep 2023 04:55:48 -0400 Subject: [PATCH 014/176] Add Release Model Document (#6041) Add release model document Co-authored-by: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> Co-authored-by: Moderocky --- CLOCKWORK_RELEASE_MODEL.md | 294 +++++++++++++++++++++++++++++++++++++ README.md | 2 + 2 files changed, 296 insertions(+) create mode 100644 CLOCKWORK_RELEASE_MODEL.md diff --git a/CLOCKWORK_RELEASE_MODEL.md b/CLOCKWORK_RELEASE_MODEL.md new file mode 100644 index 00000000000..e5e086f62eb --- /dev/null +++ b/CLOCKWORK_RELEASE_MODEL.md @@ -0,0 +1,294 @@ +# Clockwork Release Model + +## Table of Contents +1. [Introduction](#introduction) + - [Preamble](#preamble) + - [Motivations](#motivations) + - [Goals](#goals) + - [Non-Goals](#non-goals) +2. [Release Types](#release-types) + - [Feature Releases](#feature-releases) + - [Patch Releases](#patch-releases) + - [Pre-Releases](#pre-releases) + - [Emergency Patch Releases](#emergency-patch-releases) +3. [Timetable](#timetable) + - [Major Version Schedule](#major-version-schedule) + - [Pre-Release Schedule](#pre-release-schedule) + - [Patch Schedule](#patch-schedule) +4. [Content Curation](#content-curation) + - [Labels](#labels) + - [Branches](#branches) +5. [Conclusion](#conclusion) + - [Paradigm Versions](#addendum-1-paradigm-versions) + - [Failure Standards](#addendum-2-failure-standards) + +## Introduction + +### Preamble + +This document defines the structure of future Skript releases, the kinds of material included in releases and the outline of the dates on which releases will be published. + +A 'release' is the publication of a verified and signed build artefact on the GitHub releases tab, made available for all users to download and install. + +This document does *not* cover the distribution or publication of artifacts built in other ways (e.g. privately, from a nightly action) or those not published from our GitHub (e.g. test builds shared in our public testing group). + +Plans for a new release model began in March 2023 and several models were discussed, with this being the final version agreed upon by the organisation's administrative group and approved by the core contributors. + +### Motivations + +The release cycle for the `2.7.0` version was significant in that it took an unusually long time and included an unusually-large number of additions and changes. + +While it was not the first version to have taken a long time to finalise and produce, it was distinct in that a lot of time had passed since the previous public build of Skript having been marked stable. + +Members of the organisation and the wider community identified several problems that resulted from this, some of which are (not exhaustively) detailed below: +- 291 days had passed since the previous release + - Users were unable to benefit from bug fixes or new features produced during that time + - Although beta versions were released, these were marked unstable and were not fully tested +- When the release arrived it contained a very large number of changes and additions + - Some users were unaware of changes that could not be extensively documented in the changelog or were buried in a large list + - Users who obtained a build elsewhere (e.g. direct download, automatic installer) may have been unaware of the scale of the changes +- Several additions were made at short notice and without sufficient testing + - Some of these introduced problems that required fixes in a following `2.7.1` patch +- Several features could not be completed in time and had to be dropped to a future `2.8.0` version + - One result of this was that any corrections or improvements made as part of these were not present in `2.7.0` + - Aspects of some of these larger-scale changes had to be re-created or cherry-picked for the `2.7.0` version +- The release lacked a clear timetable or vision for what additions to include + - The initial timetable was not adhered to; plans were made for pre-releases to begin at the end of November 2022, which was delayed to early December in order to accommodate a large feature PR (which was eventually dropped to `2.8.0`) + - Delays persisted, and the final release took place 7 months later in September 2023 + - There was no clear cut-off point for new features; feature pull requests were being included even up to 3 days before release + +Of these, the principle complaint is that the `2.7.0` version took a significant amount of time to finish and this had an adverse effect on the community and the wider ecosystem. + +### Goals + +Our release model has been designed to achieve the following goals: +1. To reduce the delay between finishing new features and releasing them to the public. +2. To significantly reduce the time between an issue being fixed and that fix being made public in a stable build. +3. To reduce the risk of untested changes going into a release. +4. To make the release timetable clear and accessible. +5. To prevent a version being indefinitely delayed to accommodate additional changes. + +### Non-Goals + +This release model is not intended to change any of the following: +- The content or feature-theme of a particular version. +- The process for reviewing or approving changes. + +## Release Types + +This section details the different categories of version for release. + +The versioning will follow the form `A.B.C`, where `B` is a [feature version](#Feature-Releases) containing changes and additions, `C` is a [patch version](#Patch-Releases) containing only issue fixes, and `A` is reserved for major paradigmatic changes. + +### Feature Releases +A 'feature' version (labelled `0.X.0`) may contain: +- Additions to the language (syntax, grammar, structures) +- Bug fixes +- Developer API additions and changes +- Breaking changes1 + +All content added to a feature version must pass through the typical review process. +Content must also have been included in a prior [pre-release](#Pre-Releases) for public testing. + +> 1 Breaking changes are to be avoided where possible but may be necessary, such as in a case where a significant improvement could be made to an existing feature but only by changing its structure somehow. +> Such changes should be clearly labelled and well documented, preferably giving users ample notice. + +### Patch Releases +A 'patch' version (labelled `0.0.X`) may contain: +- Bug fixes +- Non-impactful2 improvements to existing features +- Changes to meta content (e.g. documentation) + +There may be **very rare** occasions when a breaking change is necessary in a patch release. These may occur if and only if: either a breaking change is required in order to fix an issue, and the issue is significant enough to need fixing in a patch rather than waiting for a major release, or an issue occurred with an inclusion in the version immediately-prior to this, which must be changed or reverted in some way. + +All content added to a patch version must pass through the typical review process. + +> 2 A non-impactful change is one in which there is no apparent difference to the user in how a feature is employed or what it does but that may have a material difference in areas such as performance, efficiency or machine resource usage. + +### Pre-Releases + +A 'pre-release' version (labelled `0.X.0-preY`) will contain all of the content expected to be in the feature release immediately following this. + +Pre-release versions are a final opportunity for testing and getting public feedback on changes before a major release, allowing time to identify and fix any issues before the proper release, rather than needing an immediate patch. + +The content of a pre-release should be identical to the content of the upcoming release -- barring any bug fixes -- and new content should never be included after a pre-release. + +### Emergency Patch Releases + +An 'emergency patch' version will be released if a critical security vulnerability is reported that the organisation feels prevents an immediate risk to the user base, such that it cannot wait for the subsequent patch. + +An emergency patch will be labelled as another patch version (`0.0.X`). It should be noted that an emergency patch will *not* disrupt the typical timetable detailed below. + +These kinds of releases may be published immediately and do not have to go through the typical reviewing and testing process. \ +They must never include content, additions or unnecessary changes. + +The only content permitted in an emergency patch is the material needed to fix the security risk. + +The exact nature of the security vulnerability (such as the means to reproduce it) should not be included in the notes surrounding the release. + +## Timetable + +The 'clockwork' release model follows a strict monthly cycle, with versions being released on exact dates. + +A table of (expected) dates is displayed below. + +| Date | Release Type | Example Version
Name | +|----------|-----------------|-------------------------| +| 1st Jan | Pre-release | 0.1.0-pre1 | +| 15th Jan | Feature release | 0.1.0 | +| 1st Feb | Patch | 0.1.1 | +| 1st Mar | Patch | 0.1.2 | +| 1st Apr | Patch | 0.1.3 | +| 1st May | Patch | 0.1.4 | +| 1st Jun | Patch | 0.1.5 | +| 1st Jul | Pre-release | 0.2.0-pre1 | +| 15th Jul | Feature release | 0.2.0 | +| 1st Aug | Patch | 0.2.1 | +| 1st Sep | Patch | 0.2.2 | +| 1st Oct | Patch | 0.2.3 | +| 1st Nov | Patch | 0.2.4 | +| 1st Dec | Patch | 0.2.5 | + +An estimated 14 releases are expected per year, with 10 patches, 2 pre-releases and 2 feature-releases that immediately follow them. + +Please note that the actual number may differ from this in cases such as: +- A version requiring multiple pre-releases to correct mistakes (`0.3.0-pre1`, `0.3.0-pre2`) +- An emergency patch having to be released +- No bug fixes being prepared in a month, meaning no patch is needed + +There is no fixed timetable for the circulation of unpublished builds to the public testing group or the addon developers group. + +### Major Version Schedule + +A [feature version](#feature-releases) will be released on the **15th of January** and the **15th of July**. + +This will include all finished content from the previous 6 months that was tested in the pre-release. + +Any features, additions or changes that were *not* ready or approved at the time of the pre-release may **not** be included in the feature release [according to goal 3](#goals). \ +The feature release must **not** be delayed to accomodate content that was not ready by the deadline [according to goal 5](#goals). + +If there is no content ready at the scheduled date of a feature release, the release will be skipped and a notice published explaining this. + +### Pre-Release Schedule + +A [pre-release](#pre-releases) will be released on the **1st of January** and the **1st of July**, leaving two weeks before the following release for public testing to occur. + +This pre-release may include all finished content from the previous 6 months. + +Any features, additions or changes that have *not* passed the review/approval process by the day of the pre-release may **not** be included in the pre-release [according to goal 3](#goals). \ +The pre-release must **not** be delayed to accomodate content that was not ready by the deadline [according to goal 5](#goals). + +If there is no content ready at the scheduled date of a pre-release, the entire feature-release will be skipped and a notice published explaining this. + +If issues are found requiring a new build be produced (e.g. the build fails to load, a core feature is non-functional, a fix was made but needs additional testing) then another version of the pre-release may be published. +There is no limit on the number of pre-releases that can be published if required. + +### Patch Schedule + +A [patch](#patch-releases) will be released on the **1st** of every month (except January and July) containing any fixes prepared during the previous month(s). + +On the 1st of January and July the patch will be replaced by the pre-release. + +A patch should include all bug fixes from the previous month that have passed the review/approval process. + +Ideally, a patch build should be circulated in the public testing group prior to its release, but this is not a strict requirement. + +If there are no applicable bug fixes ready by the scheduled date of the patch then the month will be skipped and the patch will not take place. A public notice is not required to explain this. + +## Content Curation + +To help curate content on our GitHub repository we have designed a new branch model and accompanying labels for categorising contributions. + +### Labels + +We shall provide issue and pull request labels to help categorise changes to prevent contributions missing a release (or slipping into the incorrect kind of release). + +1. `patch-ready` \ + to denote a pull request that has: + - passed the review/approval process + - is of the sufficient kind to be included in a monthly patch version +2. `feature-ready` \ + to denote a pull request that has: + - passed the review/approval process + - should wait for a biannual feature release + - is not suitable to be included in a patch + +### Branches + +We shall maintain three core branches: `dev/patch`, `dev/feature` and `master`, which function vertically3. + +We may also create legacy branches where necessary. \ +As an example, if a previous release, say `2.6.4` requires an emergency security update, a branch can be made from its release tag and the patch may directly target that branch (and be released). + +We may also maintain other assorted branches for individual features, for the purpose of group work or for experimentation. These are not detailed below. + +> 3 Changes are always made to the 'top' (working) branch and then this is merged downwards into the more stable branch below when required. +> +> Branches are never merged upwards. + +#### Patch + +Pull requests that only address issues or are otherwise suitable for a patch release should target the **`dev/patch` branch**. These may be merged whenever appropriate (i.e. all review and testing requirements have passed). + +At the time of the patch release, the **patch branch** will be merged downwards into the **master branch**, and a release will be created from the **master branch**. + +When a feature release occurs and all branches are merged into the master branch, the patch branch will be rebased off the current master commit, effectively bringing it up to speed with the new changes. \ +As an example, when feature version 0.5.0 releases, the patch branch will be at 0.4.5 and missing the new features, so must be rebased off the current release and catch up before changes for version 0.5.1 may be merged. + +#### Feature + +Pull requests that add features, make breaking changes or are otherwise unsuitable for a patch version should target the **`dev/feature` branch**. \ +These should be merged whenever appropriate (i.e. all review and testing requirements have passed), so that testing builds can be created and circulated in the public testing group. + +The **patch branch** may be merged downwards into the **feature branch** whenever appropriate (e.g. after changes have been made to it that may affect the state of contributions targeting the feature branch). + +The feature branch should __**never**__ be merged upwards into the patch branch4. + +The feature branch is only merged downwards into the master branch directly before a full feature release (i.e. after the pre-release and testing is complete.) + +Pre-releases are made directly from the feature branch5. At the end of the pre-release testing period the feature branch can be merged downwards into the master branch in order for the full release to be made. + +> 4 Merges only ever occur downwards. For the patch branch to see changes from the feature branch it must be rebased onto master branch after a feature release occurs. +> +> 5 Merging the branch down for the pre-release would introduce potentially-buggy, untested changes to the master branch. + +#### Master + +The **`master` branch** should reflect the most recent feature release. +Pull requests should **never** directly target the master branch. Changes are made to one of the other branches (as applicable) and then that branch is merged downwards into the **master branch** only when it is time for a release. + +This means that any user building from the master branch is guaranteed to receive a safe, stable build of the quality that we would release. + +The master branch should never be merged upwards into the feature or patch branches. If these branches need to see changes from the master branch they must be rebased onto the latest master branch commit. + +## Conclusion + +It is our aim that this release model will address all of our goals and satisfy our motivations. + +Setting a strict and regular schedule ought to prevent too much time passing without a release, while also helping to prevent a single release from becoming bloated and overbearing. + +By including testing requirements and mandating public pre-releases we hope to solve the persistent issue of untested changes slipping into supposedly-stable versions. + +Finally, by scheduling regular patches we aim to reduce the time between a bug being 'fixed' by a contributor and the userbase being able to benefit from that fix. Keeping these patches as small, controlled releases allows us to mark them as 'stable' therefore letting the version reach a wider audience. + +### Addendum 1: Paradigm Versions + +Paradigmatic `X.0.0` versions were deliberately excluded from this proposal. \ +The reasoning behind this choice was that over 10 years have passed since the inception of major version`2.0.0` in 2012, the previous paradigmatic change. + +As of writing this document there are proposals and roadmaps for a version `3.0.0` but no timetable or predicted date on the horizon. + +This kind of version, were it to be released, would likely take the place of a typical feature release in the model calendar, i.e. occurring on the 15th of January or July. However, due to its potentially-significant nature it may require exceptional changes to the pre-release cycle. + +As details of such a version are neither known nor easy to predict, it has been left to the discretion of the future team to be decided when required. + +### Addendum 2: Failure Standards + +No proposal is complete without failure standards; this model can be deemed to have failed if, in two years' time: +1. The delay between finishing new features and releasing them to the public has not been reduced. +2. The delay between an issue being fixed and that fix being made public in a stable build has not been reduced. +3. Untested features are being released in 'stable' builds. +4. The release timetable is unclear or inaccessible. +5. Versions are being indefinitely delayed to accommodate additional changes. + +Additionally, if this model is considered to have put an undue burden on the core development team, to the extent that it has hampered progress in a significant and measurable way, then it can be considered to have failed. diff --git a/README.md b/README.md index e23e1a288d2..36c82e5c00f 100644 --- a/README.md +++ b/README.md @@ -26,6 +26,8 @@ versions will be supported as soon as possible. ## Download You can find the downloads for each version with their release notes in the [releases page](https://github.com/SkriptLang/Skript/releases). +Two major feature updates are expected each year in January and July, with monthly patches occurring in between. For full details, please review our [release model](CLOCKWORK_RELEASE_MODEL.md). + ## Documentation Documentation is available [here](https://docs.skriptlang.org/) for the latest version of Skript. From 06df2811c5e1ee6e6b9d353fc0a4142e883d0e39 Mon Sep 17 00:00:00 2001 From: Moderocky Date: Wed, 20 Sep 2023 10:08:03 +0100 Subject: [PATCH 015/176] (Cherry Pick) Fix cast throwing if existing variable for command storage exists (#5942) (#6026) Fix cast throwing if existing variable for command storage exists (#5942) * Fix cast throwing if existing variable for command storage exists * Update src/main/java/ch/njol/skript/command/ScriptCommand.java --------- Co-authored-by: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> Co-authored-by: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> --- src/main/java/ch/njol/skript/command/ScriptCommand.java | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/main/java/ch/njol/skript/command/ScriptCommand.java b/src/main/java/ch/njol/skript/command/ScriptCommand.java index be7942e3ca7..2ce33ac7152 100644 --- a/src/main/java/ch/njol/skript/command/ScriptCommand.java +++ b/src/main/java/ch/njol/skript/command/ScriptCommand.java @@ -486,7 +486,13 @@ public Date getLastUsage(UUID uuid, Event event) { } else { String name = getStorageVariableName(event); assert name != null; - return (Date) Variables.getVariable(name, null, false); + Object variable = Variables.getVariable(name, null, false); + if (!(variable instanceof Date)) { + Skript.warning("Variable {" + name + "} was not a date! You may be using this variable elsewhere. " + + "This warning is letting you know that this variable is now overridden for the command storage."); + return null; + } + return (Date) variable; } } From 5711da917a84f81124aa4a52711da385df638a76 Mon Sep 17 00:00:00 2001 From: Moderocky Date: Wed, 20 Sep 2023 10:40:16 +0100 Subject: [PATCH 016/176] (Cherry Pick) Fix NPE with invalid attributes and clean up ExprEntityAttribute (#5978) (#6023) Fix NPE with invalid attributes and clean up ExprEntityAttribute (#5978) * Avoid NPE and clean up class * Update ExprEntityAttribute.java * Update src/main/java/ch/njol/skript/expressions/ExprEntityAttribute.java * Update src/main/java/ch/njol/skript/expressions/ExprEntityAttribute.java --------- Co-authored-by: sovdee <10354869+sovdeeth@users.noreply.github.com> Co-authored-by: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> --- .../expressions/ExprEntityAttribute.java | 78 ++++++++++--------- 1 file changed, 41 insertions(+), 37 deletions(-) diff --git a/src/main/java/ch/njol/skript/expressions/ExprEntityAttribute.java b/src/main/java/ch/njol/skript/expressions/ExprEntityAttribute.java index c7c81de0d5c..ddb4b3b27ad 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprEntityAttribute.java +++ b/src/main/java/ch/njol/skript/expressions/ExprEntityAttribute.java @@ -18,16 +18,6 @@ */ package ch.njol.skript.expressions; -import org.bukkit.attribute.Attribute; - -import java.util.stream.Stream; - -import org.bukkit.attribute.Attributable; -import org.bukkit.attribute.AttributeInstance; -import org.bukkit.entity.Entity; -import org.bukkit.event.Event; -import org.eclipse.jdt.annotation.Nullable; - import ch.njol.skript.Skript; import ch.njol.skript.classes.Changer.ChangeMode; import ch.njol.skript.doc.Description; @@ -40,21 +30,34 @@ import ch.njol.skript.lang.SkriptParser.ParseResult; import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; +import org.bukkit.attribute.Attributable; +import org.bukkit.attribute.Attribute; +import org.bukkit.attribute.AttributeInstance; +import org.bukkit.entity.Entity; +import org.bukkit.event.Event; +import org.eclipse.jdt.annotation.Nullable; + +import java.util.Objects; +import java.util.stream.Stream; @Name("Entity Attribute") -@Description({"The numerical value of an entity's particular attribute.", - "Note that the movement speed attribute cannot be reliably used for players. For that purpose, use the speed expression instead.", - "Resetting an entity's attribute is only available in Minecraft 1.11 and above."}) -@Examples({"on damage of player:", - " send \"You are wounded!\"", - " set victim's attack speed attribute to 2"}) +@Description({ + "The numerical value of an entity's particular attribute.", + "Note that the movement speed attribute cannot be reliably used for players. For that purpose, use the speed expression instead.", + "Resetting an entity's attribute is only available in Minecraft 1.11 and above." +}) +@Examples({ + "on damage of player:", + "\tsend \"You are wounded!\" to victim", + "\tset victim's attack speed attribute to 2" +}) @Since("2.5, 2.6.1 (final attribute value)") public class ExprEntityAttribute extends PropertyExpression { static { Skript.registerExpression(ExprEntityAttribute.class, Number.class, ExpressionType.COMBINED, - "[the] %attributetype% [(1¦(total|final|modified))] attribute [value] of %entities%", - "%entities%'[s] %attributetype% [(1¦(total|final|modified))] attribute [value]"); + "[the] %attributetype% [(1:(total|final|modified))] attribute [value] of %entities%", + "%entities%'[s] %attributetype% [(1:(total|final|modified))] attribute [value]"); } @Nullable @@ -72,10 +75,11 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Number[] get(Event e, Entity[] entities) { - Attribute a = attributes.getSingle(e); + protected Number[] get(Event event, Entity[] entities) { + Attribute attribute = attributes.getSingle(event); return Stream.of(entities) - .map(ent -> getAttribute(ent, a)) + .map(ent -> getAttribute(ent, attribute)) + .filter(Objects::nonNull) .map(att -> withModifiers ? att.getValue() : att.getBaseValue()) .toArray(Number[]::new); } @@ -90,27 +94,27 @@ public Class[] acceptChange(ChangeMode mode) { @Override @SuppressWarnings("null") - public void change(Event e, @Nullable Object[] delta, ChangeMode mode) { - Attribute a = attributes.getSingle(e); - double d = delta == null ? 0 : ((Number) delta[0]).doubleValue(); - for (Entity entity : getExpr().getArray(e)) { - AttributeInstance ai = getAttribute(entity, a); - if(ai != null) { + public void change(Event event, @Nullable Object[] delta, ChangeMode mode) { + Attribute attribute = attributes.getSingle(event); + double deltaValue = delta == null ? 0 : ((Number) delta[0]).doubleValue(); + for (Entity entity : getExpr().getArray(event)) { + AttributeInstance instance = getAttribute(entity, attribute); + if (instance != null) { switch(mode) { case ADD: - ai.setBaseValue(ai.getBaseValue() + d); + instance.setBaseValue(instance.getBaseValue() + deltaValue); break; case SET: - ai.setBaseValue(d); + instance.setBaseValue(deltaValue); break; case DELETE: - ai.setBaseValue(0); + instance.setBaseValue(0); break; case RESET: - ai.setBaseValue(ai.getDefaultValue()); + instance.setBaseValue(instance.getDefaultValue()); break; case REMOVE: - ai.setBaseValue(ai.getBaseValue() - d); + instance.setBaseValue(instance.getBaseValue() - deltaValue); break; case REMOVE_ALL: assert false; @@ -126,14 +130,14 @@ public Class getReturnType() { @Override @SuppressWarnings("null") - public String toString(@Nullable Event e, boolean debug) { - return "entity " + getExpr().toString(e, debug) + "'s " + (attributes == null ? "" : attributes.toString(e, debug)) + "attribute"; + public String toString(@Nullable Event event, boolean debug) { + return "entity " + getExpr().toString(event, debug) + "'s " + (attributes == null ? "" : attributes.toString(event, debug)) + "attribute"; } @Nullable - private static AttributeInstance getAttribute(Entity e, @Nullable Attribute a) { - if (a != null && e instanceof Attributable) { - return ((Attributable) e).getAttribute(a); + private static AttributeInstance getAttribute(Entity entity, @Nullable Attribute attribute) { + if (attribute != null && entity instanceof Attributable) { + return ((Attributable) entity).getAttribute(attribute); } return null; } From afc9148d264e4ef7b925ac02a12b98d3ca1d1fbf Mon Sep 17 00:00:00 2001 From: Patrick Miller Date: Thu, 21 Sep 2023 23:26:51 -0400 Subject: [PATCH 017/176] Fix multiple aliases sections not working (#6050) --- .../java/ch/njol/skript/structures/StructAliases.java | 8 +++++++- .../skript/tests/syntaxes/structures/StructAliases.sk | 9 +++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) create mode 100644 src/test/skript/tests/syntaxes/structures/StructAliases.sk diff --git a/src/main/java/ch/njol/skript/structures/StructAliases.java b/src/main/java/ch/njol/skript/structures/StructAliases.java index 8d09fcf802d..cf473c63eb3 100644 --- a/src/main/java/ch/njol/skript/structures/StructAliases.java +++ b/src/main/java/ch/njol/skript/structures/StructAliases.java @@ -20,6 +20,7 @@ import ch.njol.skript.Skript; import ch.njol.skript.aliases.Aliases; +import ch.njol.skript.aliases.ScriptAliases; import ch.njol.skript.config.SectionNode; import ch.njol.skript.doc.Description; import ch.njol.skript.doc.Examples; @@ -30,6 +31,7 @@ import org.bukkit.event.Event; import org.jetbrains.annotations.Nullable; import org.skriptlang.skript.lang.entry.EntryContainer; +import org.skriptlang.skript.lang.script.Script; import org.skriptlang.skript.lang.structure.Structure; @Name("Aliases") @@ -54,7 +56,11 @@ public boolean init(Literal[] args, int matchedPattern, ParseResult parseResu node.convertToEntries(0, "="); // Initialize and load script aliases - Aliases.createScriptAliases(getParser().getCurrentScript()).parser.load(node); + Script script = getParser().getCurrentScript(); + ScriptAliases scriptAliases = Aliases.getScriptAliases(script); + if (scriptAliases == null) + scriptAliases = Aliases.createScriptAliases(script); + scriptAliases.parser.load(node); return true; } diff --git a/src/test/skript/tests/syntaxes/structures/StructAliases.sk b/src/test/skript/tests/syntaxes/structures/StructAliases.sk new file mode 100644 index 00000000000..88b1024793b --- /dev/null +++ b/src/test/skript/tests/syntaxes/structures/StructAliases.sk @@ -0,0 +1,9 @@ +aliases: + cool_dirt = dirt + +aliases: + cool_stone = stone + +test "script aliases": + assert cool_dirt is dirt with "custom dirt alias failed" + assert cool_stone is stone with "custom stone alias failed" From bfa4421188896d1b71061f022b13de159a4b08e7 Mon Sep 17 00:00:00 2001 From: Moderocky Date: Fri, 22 Sep 2023 18:28:14 +0100 Subject: [PATCH 018/176] Fix error when unloading a script with multiple variables sections (#6047) * Returns the old 2.6.4 duplicate variables section behaviour. * Add an error but i don't know what it's for * Add lots of brackets to keep walrus happy :}}} * Add load tracker to prevent multiple loading. * Prevent variable data wipe, fix another bug * Support IDEs from the dark ages that don't know what a star is and think it orbits the earth or something * add a test --------- Co-authored-by: APickledWalrus --- .../skript/structures/StructVariables.java | 39 ++++++++++++++----- .../syntaxes/structures/StructVariables.sk | 10 +++++ 2 files changed, 40 insertions(+), 9 deletions(-) create mode 100644 src/test/skript/tests/syntaxes/structures/StructVariables.sk diff --git a/src/main/java/ch/njol/skript/structures/StructVariables.java b/src/main/java/ch/njol/skript/structures/StructVariables.java index b6810c4812e..f3e32e19dcf 100644 --- a/src/main/java/ch/njol/skript/structures/StructVariables.java +++ b/src/main/java/ch/njol/skript/structures/StructVariables.java @@ -87,14 +87,14 @@ public static class DefaultVariables implements ScriptData { private final Deque[]>> hints = new ArrayDeque<>(); private final List> variables; + private boolean loaded; public DefaultVariables(Collection> variables) { this.variables = ImmutableList.copyOf(variables); } - @SuppressWarnings("unchecked") public void add(String variable, Class... hints) { - if (hints == null || hints.length <= 0) + if (hints == null || hints.length == 0) return; if (CollectionUtils.containsAll(hints, Object.class)) // Ignore useless type hint. return; @@ -115,7 +115,7 @@ public void exitScope() { /** * Returns the type hints of a variable. * Can be null if no type hint was saved. - * + * * @param variable The variable string of a variable. * @return type hints of a variable if found otherwise null. */ @@ -140,14 +140,24 @@ public boolean hasDefaultVariables() { public List> getVariables() { return variables; } + + private boolean isLoaded() { + return loaded; + } } @Override public boolean init(Literal[] args, int matchedPattern, ParseResult parseResult, EntryContainer entryContainer) { SectionNode node = entryContainer.getSource(); node.convertToEntries(0, "="); - - List> variables = new ArrayList<>(); + List> variables; + Script script = getParser().getCurrentScript(); + DefaultVariables existing = script.getData(DefaultVariables.class); // if the user has TWO variables: sections + if (existing != null && existing.hasDefaultVariables()) { + variables = new ArrayList<>(existing.variables); + } else { + variables = new ArrayList<>(); + } for (Node n : node) { if (!(n instanceof EntryNode)) { Skript.error("Invalid line in variables structure"); @@ -227,20 +237,26 @@ public boolean init(Literal[] args, int matchedPattern, ParseResult parseResu } variables.add(new NonNullPair<>(name, o)); } - getParser().getCurrentScript().addData(new DefaultVariables(variables)); + script.addData(new DefaultVariables(variables)); // we replace the previous entry return true; } @Override public boolean load() { DefaultVariables data = getParser().getCurrentScript().getData(DefaultVariables.class); + if (data == null) { // this shouldn't happen + Skript.error("Default variables data missing"); + return false; + } else if (data.isLoaded()) { + return true; + } for (NonNullPair pair : data.getVariables()) { String name = pair.getKey(); if (Variables.getVariable(name, null, false) != null) continue; - Variables.setVariable(name, pair.getValue(), null, false); } + data.loaded = true; return true; } @@ -248,8 +264,13 @@ public boolean load() { public void postUnload() { Script script = getParser().getCurrentScript(); DefaultVariables data = script.getData(DefaultVariables.class); - for (NonNullPair pair : data.getVariables()) - Variables.setVariable(pair.getKey(), null, null, false); + if (data == null) // band-aid fix for this section's behaviour being handled by a previous section + return; // see https://github.com/SkriptLang/Skript/issues/6013 + for (NonNullPair pair : data.getVariables()) { + String name = pair.getKey(); + if (name.contains("<") && name.contains(">")) // probably a template made by us + Variables.setVariable(pair.getKey(), null, null, false); + } script.removeData(DefaultVariables.class); } diff --git a/src/test/skript/tests/syntaxes/structures/StructVariables.sk b/src/test/skript/tests/syntaxes/structures/StructVariables.sk new file mode 100644 index 00000000000..5de1d5c7be3 --- /dev/null +++ b/src/test/skript/tests/syntaxes/structures/StructVariables.sk @@ -0,0 +1,10 @@ +variables: + {variables_test1} = true + +variables: + {variables_test1} = false # we hope it doesn't overwrite! + {variables_test2} = true + +test "default variables": + assert {variables_test1} is true with "{variables_test1} was not true" + assert {variables_test2} is true with "{variables_test2} was not true" From e618afa662b03d29363d8be2e18c623c8eb28c72 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 20 Sep 2023 15:11:42 -0600 Subject: [PATCH 019/176] Bump actions/checkout from 3 to 4 (#6029) Bumps [actions/checkout](https://github.com/actions/checkout) from 3 to 4. - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](https://github.com/actions/checkout/compare/v3...v4) --- updated-dependencies: - dependency-name: actions/checkout dependency-type: direct:production update-type: version-update:semver-major ... From 347ab462bb24b69ff141ebbcb06a4c8e655a6de7 Mon Sep 17 00:00:00 2001 From: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> Date: Sat, 23 Sep 2023 19:19:40 +0300 Subject: [PATCH 020/176] =?UTF-8?q?=E2=9A=92=20Disable=20Javadocs=20genera?= =?UTF-8?q?tion=20for=20nightly=20docs=20&=20improvements=20(#6059)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Let's see if I am good at GH actions 🤞 * ops! * Use proper docs template reference when possible * Disable nightly javadocs generation with an option Each javadoc is ~50mb, which was causing the big size of the docs! while each docs generation is ~2mb only * Fix building * Revert pull changes They are not what fixed the issue, probably the old PRs aren't syncing for some reason * Update build.gradle --------- Co-authored-by: Moderocky --- .github/workflows/docs/generate-docs/action.yml | 16 +++++++++++++--- .github/workflows/nightly-docs.yml | 6 +++++- src/main/java/ch/njol/skript/SkriptCommand.java | 2 +- .../njol/skript/SkriptCommandTabCompleter.java | 3 ++- src/main/resources/lang/english.lang | 2 +- src/main/resources/lang/french.lang | 2 +- src/main/resources/lang/german.lang | 2 +- src/main/resources/lang/simplifiedchinese.lang | 2 +- 8 files changed, 25 insertions(+), 10 deletions(-) diff --git a/.github/workflows/docs/generate-docs/action.yml b/.github/workflows/docs/generate-docs/action.yml index 84cc2153f86..e033996868e 100644 --- a/.github/workflows/docs/generate-docs/action.yml +++ b/.github/workflows/docs/generate-docs/action.yml @@ -23,6 +23,11 @@ inputs: required: false default: "*" type: string + generate_javadocs: + description: "Designates whether to generate javadocs for this nightly documentation" + required: false + default: false + type: boolean outputs: DOCS_CHANGED: @@ -41,6 +46,7 @@ runs: SKRIPT_REPO_DIR: ${{ inputs.skript_repo_dir }} IS_RELEASE: ${{ inputs.is_release }} CLEANUP_PATTERN: ${{ inputs.cleanup_pattern }} + GENERATE_JAVADOCS: ${{ inputs.generate_javadocs }} run: | replace_in_directory() { find $1 -type f -exec sed -i -e "s/$2/$3/g" {} \; @@ -55,7 +61,7 @@ runs: if [ -d "${DOCS_REPO_DIR}/docs/templates" ] then export SKRIPT_DOCS_TEMPLATE_DIR=${DOCS_REPO_DIR}/docs/templates - else + else # compatibility for older versions export SKRIPT_DOCS_TEMPLATE_DIR=${DOCS_REPO_DIR}/doc-templates fi @@ -64,12 +70,16 @@ runs: cd $SKRIPT_REPO_DIR if [[ "${IS_RELEASE}" == "true" ]]; then ./gradlew genReleaseDocs releaseJavadoc - else + elif [[ "${GENERATE_JAVADOCS}" == "true" ]]; then ./gradlew genNightlyDocs javadoc + else + ./gradlew genNightlyDocs fi if [ -d "${DOCS_OUTPUT_DIR}" ]; then - mkdir -p "${SKRIPT_DOCS_OUTPUT_DIR}/javadocs" && cp -a "./build/docs/javadoc/." "$_" + if [[ "${GENERATE_JAVADOCS}" == "true" ]]; then + mkdir -p "${SKRIPT_DOCS_OUTPUT_DIR}/javadocs" && cp -a "./build/docs/javadoc/." "$_" + fi mkdir -p "/tmp/normalized-output-docs" && cp -a "${DOCS_OUTPUT_DIR}/." "$_" mkdir -p "/tmp/normalized-generated-docs" && cp -a "${SKRIPT_DOCS_OUTPUT_DIR}/." "$_" diff --git a/.github/workflows/nightly-docs.yml b/.github/workflows/nightly-docs.yml index 782b76b9ed5..8bd3d70aaa1 100644 --- a/.github/workflows/nightly-docs.yml +++ b/.github/workflows/nightly-docs.yml @@ -3,7 +3,11 @@ name: Nightly documentation on: push: branches: - - '**' + - 'dev/feature' + - 'dev/patch' + - 'enhancement/**' + - 'feature/**' + - 'fix/**' tags-ignore: - '**' diff --git a/src/main/java/ch/njol/skript/SkriptCommand.java b/src/main/java/ch/njol/skript/SkriptCommand.java index 7f01e3ff331..62261d0e426 100644 --- a/src/main/java/ch/njol/skript/SkriptCommand.java +++ b/src/main/java/ch/njol/skript/SkriptCommand.java @@ -398,7 +398,7 @@ else if (args[0].equalsIgnoreCase("info")) { else if (args[0].equalsIgnoreCase("gen-docs")) { File templateDir = Documentation.getDocsTemplateDirectory(); if (!templateDir.exists()) { - Skript.error(sender, "Cannot generate docs! Documentation templates not found at 'plugins/Skript/doc-templates/'"); + Skript.error(sender, "Cannot generate docs! Documentation templates not found at '" + Documentation.getDocsTemplateDirectory().getPath() + "'"); TestMode.docsFailed = true; return true; } diff --git a/src/main/java/ch/njol/skript/SkriptCommandTabCompleter.java b/src/main/java/ch/njol/skript/SkriptCommandTabCompleter.java index 19588312957..4cd9c445173 100644 --- a/src/main/java/ch/njol/skript/SkriptCommandTabCompleter.java +++ b/src/main/java/ch/njol/skript/SkriptCommandTabCompleter.java @@ -18,6 +18,7 @@ */ package ch.njol.skript; +import ch.njol.skript.doc.Documentation; import ch.njol.skript.test.runner.TestMode; import ch.njol.util.StringUtils; import org.bukkit.command.Command; @@ -116,7 +117,7 @@ public List onTabComplete(CommandSender sender, Command command, String options.add("disable"); options.add("update"); options.add("info"); - if (new File(Skript.getInstance().getDataFolder() + "/doc-templates").exists()) + if (Documentation.getDocsTemplateDirectory().exists()) options.add("gen-docs"); if (TestMode.DEV_MODE) options.add("test"); diff --git a/src/main/resources/lang/english.lang b/src/main/resources/lang/english.lang index 17225590e3b..40db6ddb7a0 100644 --- a/src/main/resources/lang/english.lang +++ b/src/main/resources/lang/english.lang @@ -45,7 +45,7 @@ skript command: changes: Lists all changes since the current version download: Download the newest version info: Prints a message with links to Skript's aliases and documentation - gen-docs: Generates documentation using doc-templates in plugin folder + gen-docs: Generates documentation using docs/templates in plugin folder test: Used for running internal Skript tests invalid script: Can't find the script '%s' in the scripts folder! diff --git a/src/main/resources/lang/french.lang b/src/main/resources/lang/french.lang index 9a548ba8587..6aa7e26342d 100644 --- a/src/main/resources/lang/french.lang +++ b/src/main/resources/lang/french.lang @@ -45,7 +45,7 @@ skript command: changes: Liste toutes les modifications apportées depuis la version actuelle download: Télécharge la dernière version info: Affiche un message contenant les liens vers les alias et la documentation de Skript - gen-docs: Génère la documentation en utilisant doc-templates dans le dossier du plugin + gen-docs: Génère la documentation en utilisant docs/templates dans le dossier du plugin test: Utilisé pour exécuter les tests Skript invalid script: Impossible de trouver le script '%s' dans le dossier des scripts ! diff --git a/src/main/resources/lang/german.lang b/src/main/resources/lang/german.lang index cb9637e9dd7..0a8255f44e8 100644 --- a/src/main/resources/lang/german.lang +++ b/src/main/resources/lang/german.lang @@ -45,7 +45,7 @@ skript command: changes: Listet alle Änderungen seit der aktuellen Version auf (auf englisch) download: Lädt die neueste Version herunter info: Druckt eine Nachricht mit Links zu den Aliases und der Dokumentation von Skript. - gen-docs: Generiert Dokumentation mithilfe von doc-templates im Plugin-Ordner + gen-docs: Generiert Dokumentation mithilfe von docs/templates im Plugin-Ordner test: Wird zum Ausführen von Skript-Tests verwendet invalid script: Das Skript '%s' konnte nicht gefunden werden. diff --git a/src/main/resources/lang/simplifiedchinese.lang b/src/main/resources/lang/simplifiedchinese.lang index e1229106eba..c64b007caba 100644 --- a/src/main/resources/lang/simplifiedchinese.lang +++ b/src/main/resources/lang/simplifiedchinese.lang @@ -45,7 +45,7 @@ skript command: changes: 列出自当前版本以来的所有变化 download: 下载最新的版本 info: 打印一个带有Skript的别名和文档链接的信息 - gen-docs: 使用插件文件夹中的doc-templates生成文档 + gen-docs: 使用插件文件夹中的docs/templates生成文档 test: 用于运行内部的Skript测试 invalid script: 无法在scripts文件夹中找到脚本%s! From 3b4c9aaf4ff76ed7c3f6f732d1d2b05191db0725 Mon Sep 17 00:00:00 2001 From: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> Date: Sun, 24 Sep 2023 04:54:58 -0600 Subject: [PATCH 021/176] Change the target branch of dependabot (#6063) Update dependabot.yml --- .github/dependabot.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 191b0e340d9..5b930003730 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -1,12 +1,14 @@ version: 2 updates: - package-ecosystem: "github-actions" + target-branch: "dev/patch" directory: "/" schedule: interval: "weekly" labels: - "dependencies" - package-ecosystem: "gradle" + target-branch: "dev/patch" directory: "/" schedule: interval: "weekly" From 3922933adb90fd386457df69fa44b2e4fd31f227 Mon Sep 17 00:00:00 2001 From: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> Date: Sun, 24 Sep 2023 18:38:56 +0300 Subject: [PATCH 022/176] =?UTF-8?q?=E2=9A=92=20Fix=20stop=20all=20sounds?= =?UTF-8?q?=20NPE=20(#6067)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/ch/njol/skript/effects/EffStopSound.java | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/src/main/java/ch/njol/skript/effects/EffStopSound.java b/src/main/java/ch/njol/skript/effects/EffStopSound.java index fe0af9ef26c..dc39449a06a 100644 --- a/src/main/java/ch/njol/skript/effects/EffStopSound.java +++ b/src/main/java/ch/njol/skript/effects/EffStopSound.java @@ -80,14 +80,9 @@ public class EffStopSound extends Effect { @SuppressWarnings("unchecked") public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelayed, ParseResult parseResult) { allSounds = parseResult.hasTag("all"); - if (allSounds) { - category = (Expression) exprs[0]; - players = (Expression) exprs[1]; - } else { - sounds = (Expression) exprs[0]; - category = (Expression) exprs[1]; - players = (Expression) exprs[2]; - } + sounds = (Expression) exprs[0]; + category = (Expression) exprs[1]; + players = (Expression) exprs[2]; return true; } From 762100f6ebb64841305276d903e23aafc42b1786 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 24 Sep 2023 23:18:21 -0600 Subject: [PATCH 023/176] Bump actions/checkout from 3 to 4 (#6069) Bumps [actions/checkout](https://github.com/actions/checkout) from 3 to 4. - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](https://github.com/actions/checkout/compare/v3...v4) --- updated-dependencies: - dependency-name: actions/checkout dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> --- .github/workflows/java-17-builds.yml | 2 +- .github/workflows/java-8-builds.yml | 2 +- .github/workflows/junit-17-builds.yml | 2 +- .github/workflows/junit-8-builds.yml | 2 +- .github/workflows/nightly-docs.yml | 2 +- .github/workflows/release-docs.yml | 4 ++-- .github/workflows/repo.yml | 2 +- 7 files changed, 8 insertions(+), 8 deletions(-) diff --git a/.github/workflows/java-17-builds.yml b/.github/workflows/java-17-builds.yml index 67007d76d90..fa432f7f17d 100644 --- a/.github/workflows/java-17-builds.yml +++ b/.github/workflows/java-17-builds.yml @@ -12,7 +12,7 @@ jobs: if: "! contains(toJSON(github.event.commits.*.message), '[ci skip]')" runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 with: submodules: recursive - name: Set up JDK 17 diff --git a/.github/workflows/java-8-builds.yml b/.github/workflows/java-8-builds.yml index adcd71fb09b..4a36e74a44b 100644 --- a/.github/workflows/java-8-builds.yml +++ b/.github/workflows/java-8-builds.yml @@ -12,7 +12,7 @@ jobs: if: "! contains(toJSON(github.event.commits.*.message), '[ci skip]')" runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 with: submodules: recursive - name: Set up JDK 17 diff --git a/.github/workflows/junit-17-builds.yml b/.github/workflows/junit-17-builds.yml index eca1ebb9706..69c5b73f27a 100644 --- a/.github/workflows/junit-17-builds.yml +++ b/.github/workflows/junit-17-builds.yml @@ -12,7 +12,7 @@ jobs: if: "! contains(toJSON(github.event.commits.*.message), '[ci skip]')" runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 with: submodules: recursive - name: Set up JDK 17 diff --git a/.github/workflows/junit-8-builds.yml b/.github/workflows/junit-8-builds.yml index 93971c79624..3aa98f554a7 100644 --- a/.github/workflows/junit-8-builds.yml +++ b/.github/workflows/junit-8-builds.yml @@ -12,7 +12,7 @@ jobs: if: "! contains(toJSON(github.event.commits.*.message), '[ci skip]')" runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 with: submodules: recursive - name: Set up JDK 17 diff --git a/.github/workflows/nightly-docs.yml b/.github/workflows/nightly-docs.yml index 8bd3d70aaa1..0d5cc824ad0 100644 --- a/.github/workflows/nightly-docs.yml +++ b/.github/workflows/nightly-docs.yml @@ -33,7 +33,7 @@ jobs: echo "DOCS_REPO_DIR=${GITHUB_WORKSPACE}/skript-docs" >> $GITHUB_OUTPUT echo "SKRIPT_REPO_DIR=${GITHUB_WORKSPACE}/skript" >> $GITHUB_OUTPUT - name: Checkout Skript - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive path: skript diff --git a/.github/workflows/release-docs.yml b/.github/workflows/release-docs.yml index a8ccb4000bb..06cb5569076 100644 --- a/.github/workflows/release-docs.yml +++ b/.github/workflows/release-docs.yml @@ -17,7 +17,7 @@ jobs: echo "DOCS_REPO_DIR=${GITHUB_WORKSPACE}/skript-docs" >> $GITHUB_OUTPUT echo "SKRIPT_REPO_DIR=${GITHUB_WORKSPACE}/skript" >> $GITHUB_OUTPUT - name: Checkout Skript - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive path: skript @@ -56,7 +56,7 @@ jobs: echo "DOCS_REPO_DIR=${GITHUB_WORKSPACE}/skript-docs" >> $GITHUB_OUTPUT echo "SKRIPT_REPO_DIR=${GITHUB_WORKSPACE}/skript" >> $GITHUB_OUTPUT - name: Checkout Skript - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive path: skript diff --git a/.github/workflows/repo.yml b/.github/workflows/repo.yml index d7639b98a94..3b6640cc765 100644 --- a/.github/workflows/repo.yml +++ b/.github/workflows/repo.yml @@ -8,7 +8,7 @@ jobs: publish: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 with: submodules: recursive - name: Set up JDK 17 From 9934f23081829dc3cfaeb3c36ed2c25f56a13a59 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 25 Sep 2023 00:06:51 -0600 Subject: [PATCH 024/176] Bump org.gradle.toolchains.foojay-resolver-convention from 0.5.0 to 0.7.0 (#6070) Bump org.gradle.toolchains.foojay-resolver-convention Bumps org.gradle.toolchains.foojay-resolver-convention from 0.5.0 to 0.7.0. --- updated-dependencies: - dependency-name: org.gradle.toolchains.foojay-resolver-convention dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> --- settings.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/settings.gradle b/settings.gradle index 0a8d7b2d301..e5432e8214f 100644 --- a/settings.gradle +++ b/settings.gradle @@ -1,6 +1,6 @@ plugins { - id 'org.gradle.toolchains.foojay-resolver-convention' version '0.5.0' + id 'org.gradle.toolchains.foojay-resolver-convention' version '0.7.0' } rootProject.name = 'Skript' From 98c75ed27696e1b7e5aa57210a2e7d6b0bd61bb7 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 25 Sep 2023 00:46:31 -0600 Subject: [PATCH 025/176] Bump org.easymock:easymock from 5.1.0 to 5.2.0 (#6071) Bumps [org.easymock:easymock](https://github.com/easymock/easymock) from 5.1.0 to 5.2.0. - [Release notes](https://github.com/easymock/easymock/releases) - [Changelog](https://github.com/easymock/easymock/blob/master/ReleaseNotes.md) - [Commits](https://github.com/easymock/easymock/compare/easymock-5.1.0...easymock-5.2.0) --- updated-dependencies: - dependency-name: org.easymock:easymock dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> --- build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index 9a525ff1e1d..15505bcbd3e 100644 --- a/build.gradle +++ b/build.gradle @@ -40,7 +40,7 @@ dependencies { implementation fileTree(dir: 'lib', include: '*.jar') testShadow group: 'junit', name: 'junit', version: '4.13.2' - testShadow group: 'org.easymock', name: 'easymock', version: '5.1.0' + testShadow group: 'org.easymock', name: 'easymock', version: '5.2.0' } task checkAliases { From 8603b2b46875d686dd2ca8e35eb390a472965224 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 25 Sep 2023 10:31:17 +0100 Subject: [PATCH 026/176] Bump io.papermc.paper:paper-api from 1.20.1-R0.1-SNAPSHOT to 1.20.2-R0.1-SNAPSHOT (#6072) * Bump io.papermc.paper:paper-api Bumps io.papermc.paper:paper-api from 1.20.1-R0.1-SNAPSHOT to 1.20.2-R0.1-SNAPSHOT. --- updated-dependencies: - dependency-name: io.papermc.paper:paper-api dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] * Apply 1.20.2 to the test runner * Deprecate org.bukkit.util.Consumer usage in EntityData * Adapt against the Java Consumer instead of Bukkit's * Resolve existing method deprecation * Adapt against the Java Consumer instead of Bukkit's * Update developer note * Result in reflection for Bukkit Consumer * Resolve ThrownPotion Consumer * Result in reflection for Bukkit Consumer * Pretty else if * Add common reflective spawn method. * Use common spawn method in potion class. * Remove old suppression! * Whoops I forgot about the consumer * Don't need reflection import anymore :) * Thrown potion class --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> Co-authored-by: TheLimeGlass Co-authored-by: Moderocky --- build.gradle | 5 +- gradle.properties | 2 +- .../ch/njol/skript/entity/EntityData.java | 157 +++++++++++++----- .../njol/skript/entity/FallingBlockData.java | 8 +- .../njol/skript/entity/ThrownPotionData.java | 20 +-- .../java/ch/njol/skript/entity/XpOrbData.java | 6 +- .../ch/njol/skript/sections/EffSecSpawn.java | 29 ++-- src/main/resources/lang/default.lang | 1 + .../{paper-1.20.1.json => paper-1.20.2.json} | 4 +- 9 files changed, 149 insertions(+), 83 deletions(-) rename src/test/skript/environments/java17/{paper-1.20.1.json => paper-1.20.2.json} (85%) diff --git a/build.gradle b/build.gradle index 15505bcbd3e..7ce7614c3b0 100644 --- a/build.gradle +++ b/build.gradle @@ -29,7 +29,7 @@ dependencies { shadow group: 'org.bstats', name: 'bstats-bukkit', version: '3.0.2' shadow group: 'net.kyori', name: 'adventure-text-serializer-bungeecord', version: '4.3.0' - implementation group: 'io.papermc.paper', name: 'paper-api', version: '1.20.1-R0.1-SNAPSHOT' + implementation group: 'io.papermc.paper', name: 'paper-api', version: '1.20.2-R0.1-SNAPSHOT' implementation group: 'org.eclipse.jdt', name: 'org.eclipse.jdt.annotation', version: '2.2.700' implementation group: 'com.google.code.findbugs', name: 'findbugs', version: '3.0.1' implementation group: 'com.sk89q.worldguard', name: 'worldguard-legacy', version: '7.0.0-SNAPSHOT' @@ -246,7 +246,7 @@ void createTestTask(String name, String desc, String environments, int javaVersi } } -def latestEnv = 'java17/paper-1.20.1.json' +def latestEnv = 'java17/paper-1.20.2.json' def latestJava = 17 def oldestJava = 8 @@ -389,7 +389,6 @@ task nightlyRelease(type: ShadowJar) { javadoc { dependsOn nightlyResources - source = sourceSets.main.allJava exclude("ch/njol/skript/conditions/**") diff --git a/gradle.properties b/gradle.properties index a8e8c966957..1d5c2fb3e73 100644 --- a/gradle.properties +++ b/gradle.properties @@ -2,5 +2,5 @@ groupid=ch.njol name=skript version=2.7.1 jarName=Skript.jar -testEnv=java17/paper-1.20.1 +testEnv=java17/paper-1.20.2 testEnvJavaVersion=17 diff --git a/src/main/java/ch/njol/skript/entity/EntityData.java b/src/main/java/ch/njol/skript/entity/EntityData.java index d49668a8af3..ae02901b769 100644 --- a/src/main/java/ch/njol/skript/entity/EntityData.java +++ b/src/main/java/ch/njol/skript/entity/EntityData.java @@ -18,6 +18,28 @@ */ package ch.njol.skript.entity; +import java.io.NotSerializableException; +import java.io.StreamCorruptedException; +import java.lang.reflect.Array; +import java.lang.reflect.InvocationTargetException; +import java.lang.reflect.Method; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Iterator; +import java.util.List; +import java.util.function.Consumer; +import java.util.regex.Pattern; +import java.util.stream.Collectors; + +import org.bukkit.Bukkit; +import org.bukkit.Chunk; +import org.bukkit.Location; +import org.bukkit.RegionAccessor; +import org.bukkit.World; +import org.bukkit.entity.Entity; +import org.bukkit.entity.Player; +import org.eclipse.jdt.annotation.Nullable; + import ch.njol.skript.Skript; import ch.njol.skript.SkriptAPIException; import ch.njol.skript.bukkitutil.EntityUtils; @@ -44,37 +66,40 @@ import ch.njol.util.coll.iterator.SingleItemIterator; import ch.njol.yggdrasil.Fields; import ch.njol.yggdrasil.YggdrasilSerializable.YggdrasilExtendedSerializable; -import org.bukkit.Bukkit; -import org.bukkit.Chunk; -import org.bukkit.Location; -import org.bukkit.World; -import org.bukkit.entity.Entity; -import org.bukkit.entity.Player; -import org.bukkit.util.Consumer; -import org.eclipse.jdt.annotation.Nullable; -import java.io.NotSerializableException; -import java.io.StreamCorruptedException; -import java.lang.reflect.Array; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.Iterator; -import java.util.List; -import java.util.regex.Pattern; -import java.util.stream.Collectors; - -/** - * @author Peter Güttinger - */ @SuppressWarnings("rawtypes") public abstract class EntityData implements SyntaxElement, YggdrasilExtendedSerializable {// TODO extended horse support, zombie villagers // REMIND unit + /* + * In 1.20.2 Spigot deprecated org.bukkit.util.Consumer. + * From the class header: "API methods which use this consumer will be remapped to Java's consumer at runtime, resulting in an error." + * But in 1.13-1.16 the only way to use a consumer was World#spawn(Location, Class, org.bukkit.util.Consumer). + */ + @Nullable + protected static Method WORLD_1_13_CONSUMER_METHOD; + protected static final boolean WORLD_1_13_CONSUMER = Skript.methodExists(World.class, "spawn", Location.class, Class.class, org.bukkit.util.Consumer.class); + + @Nullable + protected static Method WORLD_1_17_CONSUMER_METHOD; + protected static boolean WORLD_1_17_CONSUMER; + + static { + try { + if (WORLD_1_13_CONSUMER) { + WORLD_1_13_CONSUMER_METHOD = World.class.getDeclaredMethod("spawn", Location.class, Class.class, org.bukkit.util.Consumer.class); + } else if (Skript.classExists("org.bukkit.RegionAccessor")) { + if (WORLD_1_17_CONSUMER = Skript.methodExists(RegionAccessor.class, "spawn", Location.class, Class.class, org.bukkit.util.Consumer.class)) + WORLD_1_17_CONSUMER_METHOD = RegionAccessor.class.getDeclaredMethod("spawn", Location.class, Class.class, org.bukkit.util.Consumer.class); + } + } catch (NoSuchMethodException | SecurityException ignored) { /* We already checked if the method exists */ } + } + public final static String LANGUAGE_NODE = "entities"; - + public final static Message m_age_pattern = new Message(LANGUAGE_NODE + ".age pattern"); public final static Adjective m_baby = new Adjective(LANGUAGE_NODE + ".age adjectives.baby"), m_adult = new Adjective(LANGUAGE_NODE + ".age adjectives.adult"); - + // must be here to be initialised before 'new SimpleLiteral' is called in the register block below private final static List>> infos = new ArrayList<>(); @@ -312,7 +337,7 @@ public final boolean init(final Expression[] exprs, final int matchedPattern, /** * Returns the super type of this entity data, e.g. 'wolf' for 'angry wolf'. - * + * * @return The supertype of this entity data. Must not be null. */ public abstract EntityData getSuperType(); @@ -401,7 +426,7 @@ public static EntityDataInfo getInfo(final String codeName) { /** * Prints errors. - * + * * @param s String with optional indefinite article at the beginning * @return The parsed entity data */ @@ -416,11 +441,10 @@ public static EntityData parse(String s) { /** * Prints errors. - * + * * @param s * @return The parsed entity data */ - @SuppressWarnings("null") @Nullable public static EntityData parseWithoutIndefiniteArticle(String s) { if (!REGEX_PATTERN.matcher(s).matches()) @@ -428,11 +452,6 @@ public static EntityData parseWithoutIndefiniteArticle(String s) { Iterator>> it = infos.iterator(); return SkriptParser.parseStatic(s, it, null); } - - @Nullable - public final E spawn(Location loc) { - return spawn(loc, null); - } private E apply(E entity) { if (baby.isTrue()) { @@ -444,24 +463,54 @@ private E apply(E entity) { return entity; } + /** + * Spawn this entity data at a location. + * + * @param location The {@link Location} to spawn the entity at. + * @return The Entity object that is spawned. + */ + @Nullable + public final E spawn(Location location) { + return spawn(location, (Consumer) null); + } + + /** + * Spawn this entity data at a location. + * The consumer allows for modiciation to the entity before it actually gets spawned. + *

+ * Bukkit's own {@link org.bukkit.util.Consumer} is deprecated. + * Use {@link #spawn(Location, Consumer)} + * + * @param location The {@link Location} to spawn the entity at. + * @param consumer A {@link Consumer} to apply the entity changes to. + * @return The Entity object that is spawned. + */ + @Nullable + @Deprecated + @SuppressWarnings("deprecation") + public E spawn(Location location, org.bukkit.util.@Nullable Consumer consumer) { + return spawn(location, (Consumer) e -> consumer.accept(e)); + } + + /** + * Spawn this entity data at a location. + * The consumer allows for modiciation to the entity before it actually gets spawned. + * + * @param location The {@link Location} to spawn the entity at. + * @param consumer A {@link Consumer} to apply the entity changes to. + * @return The Entity object that is spawned. + */ @Nullable - @SuppressWarnings("unchecked") public E spawn(Location location, @Nullable Consumer consumer) { assert location != null; - try { - if (consumer != null) { - return location.getWorld().spawn(location, (Class) getType(), e -> consumer.accept(apply(e))); - } else { - return apply(location.getWorld().spawn(location, getType())); - } - } catch (IllegalArgumentException e) { - if (Skript.testing()) - Skript.error("Can't spawn " + getType().getName()); - return null; + if (consumer != null) { + return EntityData.spawn(location, getType(), e -> consumer.accept(this.apply(e))); + } else { + return apply(location.getWorld().spawn(location, getType())); } } - - @SuppressWarnings({"null", "unchecked"}) + + @SuppressWarnings("unchecked") public E[] getAll(final World... worlds) { assert worlds != null && worlds.length > 0 : Arrays.toString(worlds); final List list = new ArrayList<>(); @@ -598,4 +647,22 @@ protected boolean deserialize(final String s) { return false; } + @SuppressWarnings({"unchecked", "deprecation"}) + protected static @Nullable E spawn(Location location, Class type, Consumer consumer) { + try { + if (WORLD_1_17_CONSUMER) { + return (@Nullable E) WORLD_1_17_CONSUMER_METHOD.invoke(location.getWorld(), location, type, + (org.bukkit.util.Consumer) consumer::accept); + } else if (WORLD_1_13_CONSUMER) { + return (@Nullable E) WORLD_1_13_CONSUMER_METHOD.invoke(location.getWorld(), location, type, + (org.bukkit.util.Consumer) consumer::accept); + } + } catch (InvocationTargetException | IllegalAccessException e) { + if (Skript.testing()) + Skript.exception(e, "Can't spawn " + type.getName()); + return null; + } + return location.getWorld().spawn(location, type, consumer); + } + } diff --git a/src/main/java/ch/njol/skript/entity/FallingBlockData.java b/src/main/java/ch/njol/skript/entity/FallingBlockData.java index b3dcfbbcadf..2f937148fe9 100644 --- a/src/main/java/ch/njol/skript/entity/FallingBlockData.java +++ b/src/main/java/ch/njol/skript/entity/FallingBlockData.java @@ -19,12 +19,13 @@ package ch.njol.skript.entity; import java.util.Arrays; + import java.util.Iterator; +import java.util.function.Consumer; import org.bukkit.Location; import org.bukkit.Material; import org.bukkit.entity.FallingBlock; -import org.bukkit.util.Consumer; import org.eclipse.jdt.annotation.Nullable; import ch.njol.skript.Skript; @@ -42,9 +43,6 @@ import org.skriptlang.skript.lang.converter.Converters; import ch.njol.util.coll.CollectionUtils; -/** - * @author Peter Güttinger - */ public class FallingBlockData extends EntityData { static { EntityData.register(FallingBlockData.class, "falling block", FallingBlock.class, "falling block"); @@ -117,11 +115,11 @@ public FallingBlock spawn(Location loc, @Nullable Consumer consume ItemType t = types == null ? new ItemType(Material.STONE) : CollectionUtils.getRandom(types); assert t != null; Material material = t.getMaterial(); - if (!material.isBlock()) { assert false : t; return null; } + FallingBlock fallingBlock = loc.getWorld().spawnFallingBlock(loc, material.createBlockData()); if (consumer != null) consumer.accept(fallingBlock); diff --git a/src/main/java/ch/njol/skript/entity/ThrownPotionData.java b/src/main/java/ch/njol/skript/entity/ThrownPotionData.java index 2f60014a310..407460d56c5 100644 --- a/src/main/java/ch/njol/skript/entity/ThrownPotionData.java +++ b/src/main/java/ch/njol/skript/entity/ThrownPotionData.java @@ -19,13 +19,13 @@ package ch.njol.skript.entity; import java.util.Arrays; +import java.util.function.Consumer; import org.bukkit.Location; import org.bukkit.entity.LingeringPotion; import org.bukkit.entity.ThrownPotion; import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.meta.ItemMeta; -import org.bukkit.util.Consumer; import org.eclipse.jdt.annotation.Nullable; import ch.njol.skript.Skript; @@ -40,9 +40,6 @@ import org.skriptlang.skript.lang.converter.Converters; import ch.njol.util.coll.CollectionUtils; -/** - * @author Peter Güttinger - */ public class ThrownPotionData extends EntityData { static { EntityData.register(ThrownPotionData.class, "thrown potion", ThrownPotion.class, "thrown potion"); @@ -103,9 +100,9 @@ protected boolean match(ThrownPotion entity) { return true; } - @SuppressWarnings({"unchecked", "rawtypes"}) @Override - public @Nullable ThrownPotion spawn(Location loc, @Nullable Consumer consumer) { + @SuppressWarnings({"unchecked", "rawtypes"}) + public @Nullable ThrownPotion spawn(Location location, @Nullable Consumer consumer) { ItemType t = CollectionUtils.getRandom(types); assert t != null; ItemStack i = t.getRandom(); @@ -114,11 +111,14 @@ protected boolean match(ThrownPotion entity) { Class thrownPotionClass = (Class) (LINGER_POTION.isOfType(i) ? LINGERING_POTION_ENTITY_CLASS : ThrownPotion.class); ThrownPotion potion; - if (consumer != null) - potion = loc.getWorld().spawn(loc, thrownPotionClass, consumer); - else - potion = loc.getWorld().spawn(loc, thrownPotionClass); + if (consumer != null) { + potion = EntityData.spawn(location, thrownPotionClass, consumer); + } else { + potion = location.getWorld().spawn(location, thrownPotionClass); + } + if (potion == null) + return null; potion.setItem(i); return potion; } diff --git a/src/main/java/ch/njol/skript/entity/XpOrbData.java b/src/main/java/ch/njol/skript/entity/XpOrbData.java index 8582d513c33..69aa7d8c9f2 100644 --- a/src/main/java/ch/njol/skript/entity/XpOrbData.java +++ b/src/main/java/ch/njol/skript/entity/XpOrbData.java @@ -18,18 +18,16 @@ */ package ch.njol.skript.entity; +import java.util.function.Consumer; + import org.bukkit.Location; import org.bukkit.entity.ExperienceOrb; -import org.bukkit.util.Consumer; import org.eclipse.jdt.annotation.Nullable; import ch.njol.skript.lang.Literal; import ch.njol.skript.lang.SkriptParser.ParseResult; import ch.njol.skript.localization.ArgsMessage; -/** - * @author Peter Güttinger - */ public class XpOrbData extends EntityData { static { EntityData.register(XpOrbData.class, "xporb", ExperienceOrb.class, "xp-orb"); diff --git a/src/main/java/ch/njol/skript/sections/EffSecSpawn.java b/src/main/java/ch/njol/skript/sections/EffSecSpawn.java index 878fe70d1db..04e1bd2ad62 100644 --- a/src/main/java/ch/njol/skript/sections/EffSecSpawn.java +++ b/src/main/java/ch/njol/skript/sections/EffSecSpawn.java @@ -18,6 +18,17 @@ */ package ch.njol.skript.sections; +import java.util.List; +import java.util.concurrent.atomic.AtomicBoolean; +import java.util.function.Consumer; + +import org.bukkit.Location; +import org.bukkit.entity.Entity; +import org.bukkit.event.Event; +import org.bukkit.event.HandlerList; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + import ch.njol.skript.Skript; import ch.njol.skript.config.SectionNode; import ch.njol.skript.doc.Description; @@ -35,16 +46,6 @@ import ch.njol.skript.util.Getter; import ch.njol.skript.variables.Variables; import ch.njol.util.Kleenean; -import org.bukkit.Location; -import org.bukkit.entity.Entity; -import org.bukkit.event.Event; -import org.bukkit.event.HandlerList; -import org.bukkit.util.Consumer; -import org.eclipse.jdt.annotation.Nullable; -import org.jetbrains.annotations.NotNull; - -import java.util.List; -import java.util.concurrent.atomic.AtomicBoolean; @Name("Spawn") @Description({ @@ -93,16 +94,18 @@ public Entity get(SpawnEvent spawnEvent) { }, EventValues.TIME_NOW); } - @Nullable - public static Entity lastSpawned = null; - @SuppressWarnings("NotNullFieldNotInitialized") private Expression locations; + @SuppressWarnings("NotNullFieldNotInitialized") private Expression types; + @Nullable private Expression amount; + @Nullable + public static Entity lastSpawned; + @Nullable private Trigger trigger; diff --git a/src/main/resources/lang/default.lang b/src/main/resources/lang/default.lang index 00236cd6d6b..89130449b8c 100644 --- a/src/main/resources/lang/default.lang +++ b/src/main/resources/lang/default.lang @@ -1910,6 +1910,7 @@ attribute types: generic_follow_range: generic follow range, follow range generic_knockback_resistance: generic knockback resistance, knockback resistance generic_luck: generic luck, luck + generic_max_absorption: generic max absorption, max absorption generic_max_health: generic max health, max health generic_movement_speed: generic movement speed, movement speed horse_jump_strength: horse jump strength diff --git a/src/test/skript/environments/java17/paper-1.20.1.json b/src/test/skript/environments/java17/paper-1.20.2.json similarity index 85% rename from src/test/skript/environments/java17/paper-1.20.1.json rename to src/test/skript/environments/java17/paper-1.20.2.json index 3a117b97397..0512ae142b0 100644 --- a/src/test/skript/environments/java17/paper-1.20.1.json +++ b/src/test/skript/environments/java17/paper-1.20.2.json @@ -1,11 +1,11 @@ { - "name": "paper-1.20.1", + "name": "paper-1.20.2", "resources": [ {"source": "server.properties.generic", "target": "server.properties"} ], "paperDownloads": [ { - "version": "1.20.1", + "version": "1.20.2", "target": "paperclip.jar" } ], From 78116e75cd4b19b5211f260f5d91af81765c2302 Mon Sep 17 00:00:00 2001 From: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> Date: Mon, 25 Sep 2023 06:11:49 -0600 Subject: [PATCH 027/176] Pull request template defaults (#5665) Update pull_request_template.md --- .github/pull_request_template.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/pull_request_template.md b/.github/pull_request_template.md index ce87d77a996..698a65a0554 100644 --- a/.github/pull_request_template.md +++ b/.github/pull_request_template.md @@ -2,6 +2,6 @@ --- -**Target Minecraft Versions:** -**Requirements:** -**Related Issues:** +**Target Minecraft Versions:** any +**Requirements:** none +**Related Issues:** none From 9d5211cff1f286af25bd3d7a80fbc32f6f2fd3d2 Mon Sep 17 00:00:00 2001 From: DelayedGaming <72163224+DelayedGaming@users.noreply.github.com> Date: Tue, 26 Sep 2023 00:45:10 +0800 Subject: [PATCH 028/176] Fix EvtPlayerChunkEnter Comparison & Cleanup (#5965) Initial (cherry picked from commit 389c0022ed177c3124cfd1884165c5c697becaac) Co-authored-by: Moderocky --- .../classes/data/BukkitEventValues.java | 39 ++++++++++++------- .../skript/events/EvtPlayerChunkEnter.java | 7 ++-- 2 files changed, 27 insertions(+), 19 deletions(-) diff --git a/src/main/java/ch/njol/skript/classes/data/BukkitEventValues.java b/src/main/java/ch/njol/skript/classes/data/BukkitEventValues.java index c47d5ab2885..2b3fa65af5b 100644 --- a/src/main/java/ch/njol/skript/classes/data/BukkitEventValues.java +++ b/src/main/java/ch/njol/skript/classes/data/BukkitEventValues.java @@ -845,6 +845,30 @@ public Block get(PlayerMoveEvent event) { return event.getTo().clone().subtract(0, 0.5, 0).getBlock(); } }, EventValues.TIME_NOW); + EventValues.registerEventValue(PlayerMoveEvent.class, Location.class, new Getter() { + @Override + public Location get(PlayerMoveEvent event) { + return event.getFrom(); + } + }, EventValues.TIME_PAST); + EventValues.registerEventValue(PlayerMoveEvent.class, Location.class, new Getter() { + @Override + public Location get(PlayerMoveEvent event) { + return event.getTo(); + } + }, EventValues.TIME_NOW); + EventValues.registerEventValue(PlayerMoveEvent.class, Chunk.class, new Getter() { + @Override + public Chunk get(PlayerMoveEvent event) { + return event.getFrom().getChunk(); + } + }, EventValues.TIME_PAST); + EventValues.registerEventValue(PlayerMoveEvent.class, Chunk.class, new Getter() { + @Override + public Chunk get(PlayerMoveEvent event) { + return event.getTo().getChunk(); + } + }, EventValues.TIME_NOW); // PlayerItemDamageEvent EventValues.registerEventValue(PlayerItemDamageEvent.class, ItemStack.class, new Getter() { @Override @@ -1425,21 +1449,6 @@ public TeleportCause get(final PlayerTeleportEvent e) { return e.getCause(); } }, 0); - //PlayerMoveEvent - EventValues.registerEventValue(PlayerMoveEvent.class, Location.class, new Getter() { - @Override - @Nullable - public Location get(PlayerMoveEvent e) { - return e.getFrom(); - } - }, EventValues.TIME_PAST); - EventValues.registerEventValue(PlayerMoveEvent.class, Location.class, new Getter() { - @Override - @Nullable - public Location get(PlayerMoveEvent e) { - return e.getTo(); - } - }, EventValues.TIME_NOW); //EntityMoveEvent if (Skript.classExists("io.papermc.paper.event.entity.EntityMoveEvent")) { EventValues.registerEventValue(EntityMoveEvent.class, Location.class, new Getter() { diff --git a/src/main/java/ch/njol/skript/events/EvtPlayerChunkEnter.java b/src/main/java/ch/njol/skript/events/EvtPlayerChunkEnter.java index e79030c1553..d3caf6d325b 100644 --- a/src/main/java/ch/njol/skript/events/EvtPlayerChunkEnter.java +++ b/src/main/java/ch/njol/skript/events/EvtPlayerChunkEnter.java @@ -22,11 +22,9 @@ import ch.njol.skript.lang.Literal; import ch.njol.skript.lang.SkriptEvent; import ch.njol.skript.lang.SkriptParser.ParseResult; - import org.bukkit.event.Event; import org.bukkit.event.player.PlayerMoveEvent; - -import org.eclipse.jdt.annotation.Nullable; +import org.jetbrains.annotations.Nullable; public class EvtPlayerChunkEnter extends SkriptEvent { @@ -46,7 +44,8 @@ public boolean init(Literal[] args, int matchedPattern, ParseResult parseResu @Override public boolean check(Event event) { - return ((PlayerMoveEvent) event).getFrom().getChunk() != ((PlayerMoveEvent) event).getTo().getChunk(); + PlayerMoveEvent moveEvent = ((PlayerMoveEvent) event); + return !moveEvent.getFrom().getChunk().equals(moveEvent.getTo().getChunk()); } @Override From d021f1a3cb0d9519b60771e558e25858dfe69b79 Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Mon, 25 Sep 2023 09:54:37 -0700 Subject: [PATCH 029/176] Fixes EffSecSpawn not properly handling local variables created within the section (#6033) Communicate local variables between consumer calls thanks pickle Co-authored-by: Moderocky --- src/main/java/ch/njol/skript/sections/EffSecSpawn.java | 5 ++--- .../regressions/6032-local-vars-created-in-effsecspawn.sk | 5 +++++ 2 files changed, 7 insertions(+), 3 deletions(-) create mode 100644 src/test/skript/tests/regressions/6032-local-vars-created-in-effsecspawn.sk diff --git a/src/main/java/ch/njol/skript/sections/EffSecSpawn.java b/src/main/java/ch/njol/skript/sections/EffSecSpawn.java index 04e1bd2ad62..320b4d63c39 100644 --- a/src/main/java/ch/njol/skript/sections/EffSecSpawn.java +++ b/src/main/java/ch/njol/skript/sections/EffSecSpawn.java @@ -140,16 +140,15 @@ public boolean init(Expression[] exprs, protected TriggerItem walk(Event event) { lastSpawned = null; - Object localVars = Variables.copyLocalVariables(event); - Consumer consumer; if (trigger != null) { consumer = o -> { lastSpawned = o; SpawnEvent spawnEvent = new SpawnEvent(o); // Copy the local variables from the calling code to this section - Variables.setLocalVariables(spawnEvent, localVars); + Variables.setLocalVariables(spawnEvent, Variables.copyLocalVariables(event)); TriggerItem.walk(trigger, spawnEvent); + // And copy our (possibly modified) local variables back to the calling code Variables.setLocalVariables(event, Variables.copyLocalVariables(spawnEvent)); // Clear spawnEvent's local variables as it won't be done automatically Variables.removeLocals(spawnEvent); diff --git a/src/test/skript/tests/regressions/6032-local-vars-created-in-effsecspawn.sk b/src/test/skript/tests/regressions/6032-local-vars-created-in-effsecspawn.sk new file mode 100644 index 00000000000..23033b01db0 --- /dev/null +++ b/src/test/skript/tests/regressions/6032-local-vars-created-in-effsecspawn.sk @@ -0,0 +1,5 @@ +test "local vars created in EffSecSpawn": + set {_spawn} to spawn of world "world" + spawn 4 zombies at {_spawn}: + add 1 to {_test} + assert {_test} is 4 with "local var created in EffSecSpawn was not properly incremented" From d1f73b8d075bb70979496eb86935c760cca19d34 Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Tue, 26 Sep 2023 10:05:13 -0700 Subject: [PATCH 030/176] Remove PlayerPreprocessCommandEvent listener and clean up Commands (#5966) * Remove PPCE listener and clean up Commands * Apply suggestions from code review Co-authored-by: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> * Update Commands.java * we hate breaking changes --------- Co-authored-by: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> Co-authored-by: Moderocky --- src/main/java/ch/njol/skript/Skript.java | 138 ++++++++------- .../java/ch/njol/skript/SkriptConfig.java | 12 +- .../java/ch/njol/skript/command/Commands.java | 161 +++++++----------- .../conditions/CondIsSkriptCommand.java | 4 +- src/main/resources/config.sk | 9 +- 5 files changed, 142 insertions(+), 182 deletions(-) diff --git a/src/main/java/ch/njol/skript/Skript.java b/src/main/java/ch/njol/skript/Skript.java index 45d076b7846..9740ee27efa 100644 --- a/src/main/java/ch/njol/skript/Skript.java +++ b/src/main/java/ch/njol/skript/Skript.java @@ -18,76 +18,9 @@ */ package ch.njol.skript; -import java.io.File; -import java.io.IOException; -import java.io.InputStream; -import java.lang.Thread.UncaughtExceptionHandler; -import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.net.URL; -import java.nio.charset.StandardCharsets; -import java.nio.file.Files; -import java.nio.file.Path; -import java.nio.file.Paths; -import java.nio.file.StandardOpenOption; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.HashMap; -import java.util.HashSet; -import java.util.Iterator; -import java.util.List; -import java.util.Locale; -import java.util.Map; -import java.util.Map.Entry; -import java.util.Set; -import java.util.jar.JarEntry; -import java.util.jar.JarFile; -import java.util.logging.Filter; -import java.util.logging.Level; -import java.util.regex.Matcher; -import java.util.regex.Pattern; -import java.util.stream.Collectors; -import java.util.zip.ZipEntry; -import java.util.zip.ZipException; -import java.util.zip.ZipFile; - -import org.bstats.bukkit.Metrics; -import org.bstats.charts.SimplePie; -import org.bukkit.Bukkit; -import org.bukkit.ChatColor; -import org.bukkit.Material; -import org.bukkit.Server; -import org.bukkit.command.CommandSender; -import org.bukkit.command.PluginCommand; -import org.bukkit.entity.Player; -import org.bukkit.event.Event; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.player.PlayerCommandPreprocessEvent; -import org.bukkit.event.player.PlayerJoinEvent; -import org.bukkit.event.server.PluginDisableEvent; -import org.bukkit.event.server.ServerCommandEvent; -import org.bukkit.plugin.Plugin; -import org.bukkit.plugin.PluginDescriptionFile; -import org.bukkit.plugin.java.JavaPlugin; -import org.eclipse.jdt.annotation.Nullable; -import org.junit.runner.JUnitCore; -import org.junit.runner.Result; -import org.skriptlang.skript.lang.entry.EntryValidator; -import org.skriptlang.skript.lang.script.Script; -import org.skriptlang.skript.lang.structure.Structure; -import org.skriptlang.skript.lang.structure.StructureInfo; - -import com.google.common.collect.Lists; -import com.google.gson.Gson; - import ch.njol.skript.aliases.Aliases; import ch.njol.skript.bukkitutil.BurgerHelper; import ch.njol.skript.classes.ClassInfo; -import org.skriptlang.skript.lang.comparator.Comparator; -import org.skriptlang.skript.lang.converter.Converter; import ch.njol.skript.classes.data.BukkitClasses; import ch.njol.skript.classes.data.BukkitEventValues; import ch.njol.skript.classes.data.DefaultComparators; @@ -124,8 +57,6 @@ import ch.njol.skript.log.SkriptLogger; import ch.njol.skript.log.Verbosity; import ch.njol.skript.registrations.Classes; -import org.skriptlang.skript.lang.comparator.Comparators; -import org.skriptlang.skript.lang.converter.Converters; import ch.njol.skript.registrations.EventValues; import ch.njol.skript.test.runner.EffObjectives; import ch.njol.skript.test.runner.SkriptJUnitTest; @@ -153,6 +84,73 @@ import ch.njol.util.StringUtils; import ch.njol.util.coll.iterator.CheckedIterator; import ch.njol.util.coll.iterator.EnumerationIterable; +import com.google.common.collect.Lists; +import com.google.gson.Gson; +import org.bstats.bukkit.Metrics; +import org.bstats.charts.SimplePie; +import org.bukkit.Bukkit; +import org.bukkit.ChatColor; +import org.bukkit.Material; +import org.bukkit.Server; +import org.bukkit.command.CommandSender; +import org.bukkit.command.PluginCommand; +import org.bukkit.entity.Player; +import org.bukkit.event.Event; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.player.PlayerCommandPreprocessEvent; +import org.bukkit.event.player.PlayerJoinEvent; +import org.bukkit.event.server.PluginDisableEvent; +import org.bukkit.event.server.ServerCommandEvent; +import org.bukkit.plugin.Plugin; +import org.bukkit.plugin.PluginDescriptionFile; +import org.bukkit.plugin.java.JavaPlugin; +import org.eclipse.jdt.annotation.Nullable; +import org.junit.runner.JUnitCore; +import org.junit.runner.Result; +import org.skriptlang.skript.lang.comparator.Comparator; +import org.skriptlang.skript.lang.comparator.Comparators; +import org.skriptlang.skript.lang.converter.Converter; +import org.skriptlang.skript.lang.converter.Converters; +import org.skriptlang.skript.lang.entry.EntryValidator; +import org.skriptlang.skript.lang.script.Script; +import org.skriptlang.skript.lang.structure.Structure; +import org.skriptlang.skript.lang.structure.StructureInfo; + +import java.io.File; +import java.io.IOException; +import java.io.InputStream; +import java.lang.Thread.UncaughtExceptionHandler; +import java.lang.reflect.InvocationTargetException; +import java.lang.reflect.Method; +import java.lang.reflect.Modifier; +import java.net.URL; +import java.nio.charset.StandardCharsets; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; +import java.nio.file.StandardOpenOption; +import java.util.ArrayList; +import java.util.Collection; +import java.util.Collections; +import java.util.HashMap; +import java.util.HashSet; +import java.util.Iterator; +import java.util.List; +import java.util.Locale; +import java.util.Map; +import java.util.Map.Entry; +import java.util.Set; +import java.util.jar.JarEntry; +import java.util.jar.JarFile; +import java.util.logging.Filter; +import java.util.logging.Level; +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import java.util.stream.Collectors; +import java.util.zip.ZipEntry; +import java.util.zip.ZipException; +import java.util.zip.ZipFile; // TODO meaningful error if someone uses an %expression with percent signs% outside of text or a variable @@ -770,7 +768,7 @@ protected void afterErrors() { SkriptConfig.defaultEventPriority.value().name().toLowerCase(Locale.ENGLISH).replace('_', ' ') )); metrics.addCustomChart(new SimplePie("logPlayerCommands", () -> - SkriptConfig.logPlayerCommands.value().toString() + String.valueOf((SkriptConfig.logEffectCommands.value() || SkriptConfig.logPlayerCommands.value())) )); metrics.addCustomChart(new SimplePie("maxTargetDistance", () -> SkriptConfig.maxTargetBlockDistance.value().toString() diff --git a/src/main/java/ch/njol/skript/SkriptConfig.java b/src/main/java/ch/njol/skript/SkriptConfig.java index 552debddd5c..d3803407f2c 100644 --- a/src/main/java/ch/njol/skript/SkriptConfig.java +++ b/src/main/java/ch/njol/skript/SkriptConfig.java @@ -126,7 +126,14 @@ public class SkriptConfig { public static final Option enableEffectCommands = new Option<>("enable effect commands", false); public static final Option effectCommandToken = new Option<>("effect command token", "!"); public static final Option allowOpsToUseEffectCommands = new Option<>("allow ops to use effect commands", false); - + + /* + * @deprecated Will be removed in 2.8.0. Use {@link #logEffectCommands} instead. + */ + @Deprecated + public static final Option logPlayerCommands = new Option<>("log player commands", false).optional(true); + public static final Option logEffectCommands = new Option<>("log effect commands", false); + // everything handled by Variables public static final OptionSection databases = new OptionSection("databases"); @@ -164,8 +171,7 @@ public static String formatDate(final long timestamp) { return null; } }); - - public static final Option logPlayerCommands = new Option("log player commands", false); + /** * Maximum number of digits to display after the period for floats and doubles diff --git a/src/main/java/ch/njol/skript/command/Commands.java b/src/main/java/ch/njol/skript/command/Commands.java index 90a3f5d740a..35e12057bb1 100644 --- a/src/main/java/ch/njol/skript/command/Commands.java +++ b/src/main/java/ch/njol/skript/command/Commands.java @@ -21,9 +21,7 @@ import ch.njol.skript.ScriptLoader; import ch.njol.skript.Skript; import ch.njol.skript.SkriptConfig; -import ch.njol.skript.config.validate.SectionValidator; import ch.njol.skript.lang.Effect; -import org.skriptlang.skript.lang.script.Script; import ch.njol.skript.lang.TriggerItem; import ch.njol.skript.lang.parser.ParserInstance; import ch.njol.skript.localization.ArgsMessage; @@ -39,17 +37,17 @@ import org.bukkit.command.CommandSender; import org.bukkit.command.ConsoleCommandSender; import org.bukkit.command.SimpleCommandMap; -import org.bukkit.entity.Player; import org.bukkit.event.EventHandler; import org.bukkit.event.EventPriority; import org.bukkit.event.Listener; import org.bukkit.event.player.AsyncPlayerChatEvent; -import org.bukkit.event.player.PlayerCommandPreprocessEvent; import org.bukkit.event.server.ServerCommandEvent; import org.bukkit.help.HelpMap; import org.bukkit.help.HelpTopic; import org.bukkit.plugin.SimplePluginManager; import org.eclipse.jdt.annotation.Nullable; +import org.jetbrains.annotations.NotNull; +import org.skriptlang.skript.lang.script.Script; import java.io.File; import java.lang.reflect.Field; @@ -59,7 +57,6 @@ import java.util.Locale; import java.util.Map; import java.util.Set; -import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; import java.util.regex.Pattern; @@ -106,24 +103,24 @@ public static SimpleCommandMap getCommandMap(){ private static void init() { try { if (Bukkit.getPluginManager() instanceof SimplePluginManager) { - final Field commandMapField = SimplePluginManager.class.getDeclaredField("commandMap"); + Field commandMapField = SimplePluginManager.class.getDeclaredField("commandMap"); commandMapField.setAccessible(true); commandMap = (SimpleCommandMap) commandMapField.get(Bukkit.getPluginManager()); - final Field knownCommandsField = SimpleCommandMap.class.getDeclaredField("knownCommands"); + Field knownCommandsField = SimpleCommandMap.class.getDeclaredField("knownCommands"); knownCommandsField.setAccessible(true); cmKnownCommands = (Map) knownCommandsField.get(commandMap); try { - final Field aliasesField = SimpleCommandMap.class.getDeclaredField("aliases"); + Field aliasesField = SimpleCommandMap.class.getDeclaredField("aliases"); aliasesField.setAccessible(true); cmAliases = (Set) aliasesField.get(commandMap); - } catch (final NoSuchFieldException e) {} + } catch (NoSuchFieldException ignored) {} } - } catch (final SecurityException e) { + } catch (SecurityException e) { Skript.error("Please disable the security manager"); commandMap = null; - } catch (final Exception e) { + } catch (Exception e) { Skript.outdatedError(e); commandMap = null; } @@ -137,71 +134,33 @@ private static void init() { @SuppressWarnings("null") private final static Pattern unescape = Pattern.compile("\\\\[" + Pattern.quote("(|)<>%\\") + "]"); - public static String escape(String s) { - return "" + escape.matcher(s).replaceAll("\\\\$0"); + public static String escape(String string) { + return "" + escape.matcher(string).replaceAll("\\\\$0"); } - public static String unescape(String s) { - return "" + unescape.matcher(s).replaceAll("$0"); + public static String unescape(String string) { + return "" + unescape.matcher(string).replaceAll("$0"); } private final static Listener commandListener = new Listener() { - @SuppressWarnings("null") - @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) - public void onPlayerCommand(final PlayerCommandPreprocessEvent e) { - if (handleCommand(e.getPlayer(), e.getMessage().substring(1))) - e.setCancelled(true); - } - @SuppressWarnings("null") @EventHandler(priority = EventPriority.HIGHEST) - public void onServerCommand(final ServerCommandEvent e) { - if (e.getCommand() == null || e.getCommand().isEmpty() || e.isCancelled()) - return; - if ((Skript.testing() || SkriptConfig.enableEffectCommands.value()) && e.getCommand().startsWith(SkriptConfig.effectCommandToken.value())) { - if (handleEffectCommand(e.getSender(), e.getCommand())) { - e.setCancelled(true); - } + public void onServerCommand(ServerCommandEvent event) { + if (event.getCommand().isEmpty() || event.isCancelled()) return; + if ((Skript.testing() || SkriptConfig.enableEffectCommands.value()) && event.getCommand().startsWith(SkriptConfig.effectCommandToken.value())) { + if (handleEffectCommand(event.getSender(), event.getCommand())) + event.setCancelled(true); } } }; - - /** - * @param sender - * @param command full command string without the slash - * @return whether to cancel the event - */ - static boolean handleCommand(final CommandSender sender, final String command) { - final String[] cmd = command.split("\\s+", 2); - cmd[0] = cmd[0].toLowerCase(Locale.ENGLISH); - if (cmd[0].endsWith("?")) { - final ScriptCommand c = commands.get(cmd[0].substring(0, cmd[0].length() - 1)); - if (c != null) { - c.sendHelp(sender); - return true; - } - } - final ScriptCommand c = commands.get(cmd[0]); - if (c != null) { -// if (cmd.length == 2 && cmd[1].equals("?")) { -// c.sendHelp(sender); -// return true; -// } - if (SkriptConfig.logPlayerCommands.value() && sender instanceof Player) - SkriptLogger.LOGGER.info(sender.getName() + " [" + ((Player) sender).getUniqueId() + "]: /" + command); - c.execute(sender, "" + cmd[0], cmd.length == 1 ? "" : "" + cmd[1]); - return true; - } - return false; - } - static boolean handleEffectCommand(final CommandSender sender, String command) { + static boolean handleEffectCommand(CommandSender sender, String command) { if (!(sender instanceof ConsoleCommandSender || sender.hasPermission("skript.effectcommands") || SkriptConfig.allowOpsToUseEffectCommands.value() && sender.isOp())) return false; try { command = "" + command.substring(SkriptConfig.effectCommandToken.value().length()).trim(); - final RetainingLogHandler log = SkriptLogger.startRetainingLog(); + RetainingLogHandler log = SkriptLogger.startRetainingLog(); try { // Call the event on the Bukkit API for addon developers. EffectCommandEvent effectCommand = new EffectCommandEvent(sender, command); @@ -217,7 +176,8 @@ static boolean handleEffectCommand(final CommandSender sender, String command) { log.printLog(); if (!effectCommand.isCancelled()) { sender.sendMessage(ChatColor.GRAY + "executing '" + SkriptColor.replaceColorChar(command) + "'"); - if (SkriptConfig.logPlayerCommands.value() && !(sender instanceof ConsoleCommandSender)) + // TODO: remove logPlayerCommands for 2.8.0 + if ((SkriptConfig.logEffectCommands.value() || SkriptConfig.logPlayerCommands.value()) && !(sender instanceof ConsoleCommandSender)) Skript.info(sender.getName() + " issued effect command: " + SkriptColor.replaceColorChar(command)); TriggerItem.walk(effect, effectCommand); Variables.removeLocals(effectCommand); @@ -235,7 +195,7 @@ static boolean handleEffectCommand(final CommandSender sender, String command) { log.stop(); } return true; - } catch (final Exception e) { + } catch (Exception e) { Skript.exception(e, "Unexpected error while executing effect command '" + SkriptColor.replaceColorChar(command) + "' by '" + sender.getName() + "'"); sender.sendMessage(ChatColor.RED + "An internal error occurred while executing this effect. Please refer to the server log for details."); return true; @@ -246,15 +206,23 @@ static boolean handleEffectCommand(final CommandSender sender, String command) { public static ScriptCommand getScriptCommand(String key) { return commands.get(key); } - - public static boolean skriptCommandExists(final String command) { - final ScriptCommand c = commands.get(command); - return c != null && c.getName().equals(command); + + /* + * @deprecated Use {@link #scriptCommandExists(String)} instead. + */ + @Deprecated + public static boolean skriptCommandExists(String command) { + return scriptCommandExists(command); + } + + public static boolean scriptCommandExists(String command) { + ScriptCommand scriptCommand = commands.get(command); + return scriptCommand != null && scriptCommand.getName().equals(command); } - public static void registerCommand(final ScriptCommand command) { + public static void registerCommand(ScriptCommand command) { // Validate that there are no duplicates - final ScriptCommand existingCommand = commands.get(command.getLabel()); + ScriptCommand existingCommand = commands.get(command.getLabel()); if (existingCommand != null && existingCommand.getLabel().equals(command.getLabel())) { Script script = existingCommand.getScript(); Skript.error("A command with the name /" + existingCommand.getName() + " is already defined" @@ -268,7 +236,7 @@ public static void registerCommand(final ScriptCommand command) { command.register(commandMap, cmKnownCommands, cmAliases); } commands.put(command.getLabel(), command); - for (final String alias : command.getActiveAliases()) { + for (String alias : command.getActiveAliases()) { commands.put(alias.toLowerCase(Locale.ENGLISH), command); } command.registerHelp(); @@ -303,30 +271,25 @@ public static void registerListeners() { Bukkit.getPluginManager().registerEvents(new Listener() { @EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true) - public void onPlayerChat(final AsyncPlayerChatEvent e) { - if (!SkriptConfig.enableEffectCommands.value() || !e.getMessage().startsWith(SkriptConfig.effectCommandToken.value())) + public void onPlayerChat(AsyncPlayerChatEvent event) { + if (!SkriptConfig.enableEffectCommands.value() || !event.getMessage().startsWith(SkriptConfig.effectCommandToken.value())) return; - if (!e.isAsynchronous()) { - if (handleEffectCommand(e.getPlayer(), e.getMessage())) - e.setCancelled(true); + if (!event.isAsynchronous()) { + if (handleEffectCommand(event.getPlayer(), event.getMessage())) + event.setCancelled(true); } else { - final Future f = Bukkit.getScheduler().callSyncMethod(Skript.getInstance(), new Callable() { - @Override - public Boolean call() throws Exception { - return handleEffectCommand(e.getPlayer(), e.getMessage()); - } - }); + Future f = Bukkit.getScheduler().callSyncMethod(Skript.getInstance(), () -> handleEffectCommand(event.getPlayer(), event.getMessage())); try { while (true) { try { if (f.get()) - e.setCancelled(true); + event.setCancelled(true); break; - } catch (final InterruptedException e1) { + } catch (InterruptedException ignored) { } } - } catch (final ExecutionException e1) { - Skript.exception(e1); + } catch (ExecutionException e) { + Skript.exception(e); } } } @@ -344,7 +307,7 @@ public static final class CommandAliasHelpTopic extends HelpTopic { private final String aliasFor; private final HelpMap helpMap; - public CommandAliasHelpTopic(final String alias, final String aliasFor, final HelpMap helpMap) { + public CommandAliasHelpTopic(String alias, String aliasFor, HelpMap helpMap) { this.aliasFor = aliasFor.startsWith("/") ? aliasFor : "/" + aliasFor; this.helpMap = helpMap; name = alias.startsWith("/") ? alias : "/" + alias; @@ -353,29 +316,23 @@ public CommandAliasHelpTopic(final String alias, final String aliasFor, final He } @Override - public String getFullText(final CommandSender forWho) { - final StringBuilder sb = new StringBuilder(shortText); - final HelpTopic aliasForTopic = helpMap.getHelpTopic(aliasFor); + @NotNull + public String getFullText(CommandSender forWho) { + StringBuilder fullText = new StringBuilder(shortText); + HelpTopic aliasForTopic = helpMap.getHelpTopic(aliasFor); if (aliasForTopic != null) { - sb.append("\n"); - sb.append(aliasForTopic.getFullText(forWho)); + fullText.append("\n"); + fullText.append(aliasForTopic.getFullText(forWho)); } - return "" + sb.toString(); + return "" + fullText; } @Override - public boolean canSee(final CommandSender commandSender) { - if (amendedPermission == null) { - final HelpTopic aliasForTopic = helpMap.getHelpTopic(aliasFor); - if (aliasForTopic != null) { - return aliasForTopic.canSee(commandSender); - } else { - return false; - } - } else { - assert amendedPermission != null; + public boolean canSee(CommandSender commandSender) { + if (amendedPermission != null) return commandSender.hasPermission(amendedPermission); - } + HelpTopic aliasForTopic = helpMap.getHelpTopic(aliasFor); + return aliasForTopic != null && aliasForTopic.canSee(commandSender); } } diff --git a/src/main/java/ch/njol/skript/conditions/CondIsSkriptCommand.java b/src/main/java/ch/njol/skript/conditions/CondIsSkriptCommand.java index f8a6a2f7327..4c4f8097ba4 100644 --- a/src/main/java/ch/njol/skript/conditions/CondIsSkriptCommand.java +++ b/src/main/java/ch/njol/skript/conditions/CondIsSkriptCommand.java @@ -18,7 +18,7 @@ */ package ch.njol.skript.conditions; -import static ch.njol.skript.command.Commands.skriptCommandExists; +import static ch.njol.skript.command.Commands.scriptCommandExists; import ch.njol.skript.conditions.base.PropertyCondition; import ch.njol.skript.doc.Description; @@ -44,7 +44,7 @@ public class CondIsSkriptCommand extends PropertyCondition { @Override public boolean check(String cmd) { - return skriptCommandExists(cmd); + return scriptCommandExists(cmd); } @Override diff --git a/src/main/resources/config.sk b/src/main/resources/config.sk index a95cfe461b1..54a9bb7a070 100644 --- a/src/main/resources/config.sk +++ b/src/main/resources/config.sk @@ -76,6 +76,10 @@ allow ops to use effect commands: false # Whether server operators which do not have the permission "skript.effectcommands" should have access to effect commands. # This setting is mainly useful for servers that do not run any permissions plugin. +log effect commands: false +# Whether Skript should log the usage of effect commands. +# They will be logged as [INFORMATION] in this format: ' issued effect command: ' + player variable fix: true # Whether to enable the player variable fix if a player has rejoined and was reciding inside a variable. # Player objects inside a variable(list or normal) are not updated to the new player object @@ -119,11 +123,6 @@ plugin priority: high # Skript removes drops it shouldn't => decrease priority or specify which item types to remove -log player commands: false -# Whether Skript should log the usage of custom commands. -# They will be logged as [INFORMATION] in this format: ': / ' - - number accuracy: 2 # How many digits should be displayed after the dot at maximum when displaying numbers. # Zeroes will never be displayed at all, so this setting only applies to numbers that actually have a decimal part with one or more non-zero digits. From 58f1c9f5ff1ab3bf38c9960699e9c15738081dc4 Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Tue, 29 Aug 2023 23:40:50 -0700 Subject: [PATCH 031/176] Clean up vector classes and fix a few bugs. --- .../effects/EffVectorRotateAroundAnother.java | 15 ++--- .../skript/effects/EffVectorRotateXYZ.java | 25 ++++---- .../expressions/ExprVectorAngleBetween.java | 13 ++-- .../expressions/ExprVectorArithmetic.java | 16 ++--- .../ExprVectorBetweenLocations.java | 13 ++-- .../expressions/ExprVectorCrossProduct.java | 13 ++-- .../expressions/ExprVectorCylindrical.java | 21 +++---- .../expressions/ExprVectorDotProduct.java | 20 ++---- .../skript/expressions/ExprVectorFromXYZ.java | 15 ++--- .../ExprVectorFromYawAndPitch.java | 13 ++-- .../skript/expressions/ExprVectorLength.java | 38 ++++++----- .../expressions/ExprVectorNormalize.java | 11 ++-- .../expressions/ExprVectorOfLocation.java | 11 ++-- .../expressions/ExprVectorSpherical.java | 21 +++---- .../expressions/ExprVectorSquaredLength.java | 12 ++-- .../skript/expressions/ExprVectorXYZ.java | 63 ++++++++++--------- 16 files changed, 134 insertions(+), 186 deletions(-) diff --git a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java index ad94cfa9ad2..5b49c1a0888 100644 --- a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java +++ b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java @@ -33,9 +33,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.VectorMath; -/** - * @author bi0qaw - */ @Name("Vectors - Rotate Around Vector") @Description("Rotates a vector around another vector") @Examples({"rotate {_v} around vector 1, 0, 0 by 90"}) @@ -63,18 +60,18 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean kleenean @SuppressWarnings("null") @Override - protected void execute(Event e) { - Vector v2 = second.getSingle(e); - Number d = degree.getSingle(e); + protected void execute(Event event) { + Vector v2 = second.getSingle(event); + Number d = degree.getSingle(event); if (v2 == null || d == null) return; - for (Vector v1 : first.getArray(e)) + for (Vector v1 : first.getArray(event)) VectorMath.rot(v1, v2, d.doubleValue()); } @Override - public String toString(@Nullable Event e, boolean debug) { - return "rotate " + first.toString(e, debug) + " around " + second.toString(e, debug) + " by " + degree + "degrees"; + public String toString(@Nullable Event event, boolean debug) { + return "rotate " + first.toString(event, debug) + " around " + second.toString(event, debug) + " by " + degree.toString(event, debug) + "degrees"; } } diff --git a/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java b/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java index 2c3cd5d3d94..06d4b3d98e2 100644 --- a/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java +++ b/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java @@ -33,9 +33,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.VectorMath; -/** - * @author bi0qaw - */ @Name("Vectors - Rotate around XYZ") @Description("Rotates a vector around x, y, or z axis by some degrees") @Examples({"rotate {_v} around x-axis by 90", @@ -45,7 +42,7 @@ public class EffVectorRotateXYZ extends Effect { static { - Skript.registerEffect(EffVectorRotateXYZ.class, "rotate %vectors% around (1¦x|2¦y|3¦z)(-| )axis by %number% [degrees]"); + Skript.registerEffect(EffVectorRotateXYZ.class, "rotate %vectors% around (0¦x|1¦y|2¦z)(-| )axis by %number% [degrees]"); } private final static Character[] axes = new Character[] {'x', 'y', 'z'}; @@ -68,28 +65,28 @@ public boolean init(Expression[] expressions, int matchedPattern, Kleenean is @Override @SuppressWarnings("null") - protected void execute(Event e) { - Number d = degree.getSingle(e); + protected void execute(Event event) { + Number d = degree.getSingle(event); if (d == null) return; switch (axis) { - case 1: - for (Vector v : vectors.getArray(e)) + case 0: + for (Vector v : vectors.getArray(event)) VectorMath.rotX(v, d.doubleValue()); break; - case 2: - for (Vector v : vectors.getArray(e)) + case 1: + for (Vector v : vectors.getArray(event)) VectorMath.rotY(v, d.doubleValue()); break; - case 3: - for (Vector v : vectors.getArray(e)) + case 2: + for (Vector v : vectors.getArray(event)) VectorMath.rotZ(v, d.doubleValue()); } } @Override - public String toString(@Nullable Event e, boolean debug) { - return "rotate " + vectors.toString(e, debug) + " around " + axes[axis] + "-axis" + " by " + degree + "degrees"; + public String toString(@Nullable Event event, boolean debug) { + return "rotate " + vectors.toString(event, debug) + " around " + axes[axis] + "-axis" + " by " + degree.toString(event, debug) + "degrees"; } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java index 07d3cb2867d..831ee61de67 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java @@ -35,9 +35,6 @@ import ch.njol.util.VectorMath; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Angle Between") @Description("Gets the angle between two vectors.") @Examples({"send \"%the angle between vector 1, 0, 0 and vector 0, 1, 1%\""}) @@ -62,9 +59,9 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Number[] get(Event e) { - Vector v1 = first.getSingle(e); - Vector v2 = second.getSingle(e); + protected Number[] get(Event event) { + Vector v1 = first.getSingle(event); + Vector v2 = second.getSingle(event); if (v1 == null || v2 == null) return null; return CollectionUtils.array(v1.angle(v2) * (float) VectorMath.RAD_TO_DEG); @@ -81,8 +78,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "the angle between " + first.toString(e, debug) + " and " + second.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "the angle between " + first.toString(event, debug) + " and " + second.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java b/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java index 1dc75efd574..4d1c7cf89ea 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java @@ -35,9 +35,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Arithmetic") @Description("Arithmetic expressions for vectors.") @Examples({"set {_v} to vector 1, 2, 3 // 5", @@ -119,12 +116,9 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye } @Override - protected Vector[] get(Event e) { - Vector v1 = first.getSingle(e), v2 = second.getSingle(e); - if (v1 == null) - v1 = new Vector(); - if (v2 == null) - v2 = new Vector(); + protected Vector[] get(Event event) { + Vector v1 = first.getOptionalSingle(event).orElse(new Vector()); + Vector v2 = second.getOptionalSingle(event).orElse(new Vector()); return CollectionUtils.array(op.calculate(v1, v2)); } @@ -139,8 +133,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return first.toString(e, debug) + " " + op + " " + second.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return first.toString(event, debug) + " " + op + " " + second.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java b/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java index 8b407c38dd2..11572102eed 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java @@ -35,9 +35,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Vector Between Locations") @Description("Creates a vector between two locations.") @Examples({"set {_v} to vector between {_loc1} and {_loc2}"}) @@ -62,9 +59,9 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Location l1 = from.getSingle(e); - Location l2 = to.getSingle(e); + protected Vector[] get(Event event) { + Location l1 = from.getSingle(event); + Location l2 = to.getSingle(event); if (l1 == null || l2 == null) return null; return CollectionUtils.array(new Vector(l2.getX() - l1.getX(), l2.getY() - l1.getY(), l2.getZ() - l1.getZ())); @@ -80,8 +77,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "vector from " + from.toString(e, debug) + " to " + to.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "vector from " + from.toString(event, debug) + " to " + to.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java index 11d040f2855..8bb22ffd59a 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java @@ -34,9 +34,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Cross Product") @Description("Gets the cross product between two vectors.") @Examples({"send \"%vector 1, 0, 0 cross vector 0, 1, 0%\""}) @@ -60,9 +57,9 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Vector v1 = first.getSingle(e); - Vector v2 = second.getSingle(e); + protected Vector[] get(Event event) { + Vector v1 = first.getSingle(event); + Vector v2 = second.getSingle(event); if (v1 == null || v2 == null) return null; return CollectionUtils.array(v1.clone().crossProduct(v2)); @@ -79,8 +76,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return first.toString(e, debug) + " cross " + second.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return first.toString(event, debug) + " cross " + second.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java b/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java index 65d4fc5134c..48e940a2450 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java @@ -35,9 +35,6 @@ import ch.njol.util.VectorMath; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Cylindrical Shape") @Description("Forms a 'cylindrical shaped' vector using yaw to manipulate the current point.") @Examples({"loop 360 times:", @@ -65,13 +62,13 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Number r = radius.getSingle(e); - Number y = yaw.getSingle(e); - Number h = height.getSingle(e); - if (r == null || y == null || h == null) + protected Vector[] get(Event event) { + Number radius = this.radius.getSingle(event); + Number yaw = this.yaw.getSingle(event); + Number height = this.height.getSingle(event); + if (radius == null || yaw == null || height == null) return null; - return CollectionUtils.array(VectorMath.fromCylindricalCoordinates(r.doubleValue(), VectorMath.fromSkriptYaw(y.floatValue()), h.doubleValue())); + return CollectionUtils.array(VectorMath.fromCylindricalCoordinates(radius.doubleValue(), VectorMath.fromSkriptYaw(yaw.floatValue()), height.doubleValue())); } @Override @@ -85,9 +82,9 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "cylindrical vector with radius " + radius.toString(e, debug) + ", yaw " + - yaw.toString(e, debug) + " and height " + height.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "cylindrical vector with radius " + radius.toString(event, debug) + ", yaw " + + yaw.toString(event, debug) + " and height " + height.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java index d5eb0a5c911..a02dacc5d94 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java @@ -34,20 +34,10 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Dot Product") @Description("Gets the dot product between two vectors.") @Examples({"set {_v} to {_v2} dot {_v3}"}) @Since("2.2-dev28") -/** - * NOTE vector 1, 2, 3 dot vector 1, 2, 3 does NOT work! - * it returns a new vector: 1, 2, 18. This should not happen - * and I have no idea why it does. I have also no idea why - * "z" takes the value 18. There must be some black magic - * going on. - */ public class ExprVectorDotProduct extends SimpleExpression { static { @@ -67,9 +57,9 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Number[] get(Event e) { - Vector v1 = first.getSingle(e); - Vector v2 = second.getSingle(e); + protected Number[] get(Event event) { + Vector v1 = first.getSingle(event); + Vector v2 = second.getSingle(event); if (v1 == null || v2 == null) return null; return CollectionUtils.array(v1.getX() * v2.getX() + v1.getY() * v2.getY() + v1.getZ() * v2.getZ()); @@ -86,8 +76,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return first.toString(e, debug) + " dot " + second.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return first.toString(event, debug) + " dot " + second.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java b/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java index 71896818d71..53ab07108dc 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java @@ -34,9 +34,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Create from XYZ") @Description("Creates a vector from x, y and z values.") @Examples({"set {_v} to vector 0, 1, 0"}) @@ -62,10 +59,10 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Number x = this.x.getSingle(e); - Number y = this.y.getSingle(e); - Number z = this.z.getSingle(e); + protected Vector[] get(Event event) { + Number x = this.x.getSingle(event); + Number y = this.y.getSingle(event); + Number z = this.z.getSingle(event); if (x == null || y == null || z == null) return null; return CollectionUtils.array(new Vector(x.doubleValue(), y.doubleValue(), z.doubleValue())); @@ -82,8 +79,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "vector from x " + x.toString(e, debug) + ", y " + y.toString(e, debug) + ", z " + z.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "vector from x " + x.toString(event, debug) + ", y " + y.toString(event, debug) + ", z " + z.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java b/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java index 75a65274d0d..16c8590a1a4 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java @@ -35,9 +35,6 @@ import ch.njol.util.VectorMath; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Vector from Pitch and Yaw") @Description("Creates a vector from a yaw and pitch value.") @Examples({"set {_v} to vector from yaw 45 and pitch 45"}) @@ -62,9 +59,9 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Number y = yaw.getSingle(e); - Number p = pitch.getSingle(e); + protected Vector[] get(Event event) { + Number y = yaw.getSingle(event); + Number p = pitch.getSingle(event); if (y == null || p == null) return null; float yaw = VectorMath.fromSkriptYaw(VectorMath.wrapAngleDeg(y.floatValue())); @@ -83,8 +80,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "vector from yaw " + yaw.toString(e, debug) + " and pitch " + pitch.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "vector from yaw " + yaw.toString(event, debug) + " and pitch " + pitch.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java b/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java index 8c2d1094141..193e3efd809 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java @@ -30,9 +30,6 @@ import ch.njol.skript.expressions.base.SimplePropertyExpression; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Length") @Description("Gets or sets the length of a vector.") @Examples({"send \"%standard length of vector 1, 2, 3%\"", @@ -61,43 +58,44 @@ public Class[] acceptChange(ChangeMode mode) { } @Override - public void change(Event e, @Nullable Object[] delta, ChangeMode mode) { + public void change(Event event, @Nullable Object[] delta, ChangeMode mode) { assert delta != null; - final Vector v = getExpr().getSingle(e); + final Vector v = getExpr().getSingle(event); if (v == null) return; - double n = ((Number) delta[0]).doubleValue(); + double deltaLength = ((Number) delta[0]).doubleValue(); switch (mode) { + case REMOVE: + deltaLength = -deltaLength; + //$FALL-THROUGH$ case ADD: - if (n < 0 && v.lengthSquared() < n * n) { + if (deltaLength < 0 && v.lengthSquared() < deltaLength * deltaLength) { v.zero(); } else { - double l = n + v.length(); + double l = deltaLength + v.length(); v.normalize().multiply(l); } - getExpr().change(e, new Vector[]{v}, ChangeMode.SET); + getExpr().change(event, new Vector[]{v}, ChangeMode.SET); break; - case REMOVE: - n = -n; - //$FALL-THROUGH$ case SET: - if (n < 0) + if (deltaLength < 0) { v.zero(); - else - v.normalize().multiply(n); - getExpr().change(e, new Vector[]{v}, ChangeMode.SET); + } else { + v.normalize().multiply(deltaLength); + } + getExpr().change(event, new Vector[]{v}, ChangeMode.SET); break; } } @Override - protected String getPropertyName() { - return "vector length"; + public Class getReturnType() { + return Number.class; } @Override - public Class getReturnType() { - return Number.class; + protected String getPropertyName() { + return "vector length"; } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java index c450c074ddd..53a79531bc1 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java @@ -34,9 +34,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Normalized") @Description("Returns the same vector but with length 1.") @Examples({"set {_v} to normalized {_v}"}) @@ -61,8 +58,8 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Vector v = vector.getSingle(e); + protected Vector[] get(Event event) { + Vector v = vector.getSingle(event); if (v == null) return null; return CollectionUtils.array(v.clone().normalize()); @@ -79,8 +76,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "normalized " + vector.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "normalized " + vector.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java b/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java index 21f71a3bef8..9ec6e643868 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java @@ -35,9 +35,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Vector from Location") @Description("Creates a vector from a location.") @Examples({"set {_v} to vector of {_loc}"}) @@ -62,8 +59,8 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Location l = location.getSingle(e); + protected Vector[] get(Event event) { + Location l = location.getSingle(event); if (l == null) return null; return CollectionUtils.array(l.toVector()); @@ -80,8 +77,8 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "vector from " + location.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "vector from " + location.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java b/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java index 493c023eb95..4da884bf48e 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java @@ -35,9 +35,6 @@ import ch.njol.util.VectorMath; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - Spherical Shape") @Description("Forms a 'spherical shaped' vector using yaw and pitch to manipulate the current point.") @Examples({"loop 360 times:", @@ -65,13 +62,13 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") - protected Vector[] get(Event e) { - Number r = radius.getSingle(e); - Number y = yaw.getSingle(e); - Number p = pitch.getSingle(e); - if (r == null || y == null || p == null) + protected Vector[] get(Event event) { + Number radius = this.radius.getSingle(event); + Number yaw = this.yaw.getSingle(event); + Number pitch = this.pitch.getSingle(event); + if (radius == null || yaw == null || pitch == null) return null; - return CollectionUtils.array(VectorMath.fromSphericalCoordinates(r.doubleValue(), VectorMath.fromSkriptYaw(y.floatValue()), p.floatValue() + 90)); + return CollectionUtils.array(VectorMath.fromSphericalCoordinates(radius.doubleValue(), VectorMath.fromSkriptYaw(yaw.floatValue()), pitch.floatValue() + 90)); } @Override @@ -85,9 +82,9 @@ public Class getReturnType() { } @Override - public String toString(@Nullable Event e, boolean debug) { - return "spherical vector with radius " + radius.toString(e, debug) + ", yaw " + yaw.toString(e, debug) + - " and pitch" + pitch.toString(e, debug); + public String toString(@Nullable Event event, boolean debug) { + return "spherical vector with radius " + radius.toString(event, debug) + ", yaw " + yaw.toString(event, debug) + + " and pitch" + pitch.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java b/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java index ef5444347ca..fd81a40a9cf 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java @@ -26,9 +26,6 @@ import ch.njol.skript.doc.Since; import ch.njol.skript.expressions.base.SimplePropertyExpression; -/** - * @author bi0qaw - */ @Name("Vectors - Squared Length") @Description("Gets the squared length of a vector.") @Examples({"send \"%squared length of vector 1, 2, 3%\""}) @@ -46,13 +43,14 @@ public Number convert(Vector vector) { } @Override - protected String getPropertyName() { - return "squared length of vector"; + public Class getReturnType() { + return Number.class; } @Override - public Class getReturnType() { - return Number.class; + protected String getPropertyName() { + return "squared length of vector"; } + } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java b/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java index 76b5ab59fe2..95cbcff1645 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java @@ -34,9 +34,6 @@ import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; -/** - * @author bi0qaw - */ @Name("Vectors - XYZ Component") @Description("Gets or changes the x, y or z component of a vector.") @Examples({"set {_v} to vector 1, 2, 3", @@ -76,50 +73,54 @@ public Number convert(Vector v) { @SuppressWarnings("null") public Class[] acceptChange(ChangeMode mode) { if ((mode == ChangeMode.ADD || mode == ChangeMode.REMOVE || mode == ChangeMode.SET) - && getExpr().isSingle() && Changer.ChangerUtils.acceptsChange(getExpr(), ChangeMode.SET, Vector.class)) + && Changer.ChangerUtils.acceptsChange(getExpr(), ChangeMode.SET, Vector.class)) return CollectionUtils.array(Number.class); return null; } @Override - public void change(Event e, @Nullable Object[] delta, ChangeMode mode) { + public void change(Event event, @Nullable Object[] delta, ChangeMode mode) { assert delta != null; - final Vector v = getExpr().getSingle(e); - if (v == null) - return; - double n = ((Number) delta[0]).doubleValue(); + Vector[] vectors = getExpr().getArray(event); + double deltaValue = ((Number) delta[0]).doubleValue(); switch (mode) { case REMOVE: - n = -n; + deltaValue = -deltaValue; //$FALL-THROUGH$ case ADD: - if (axis == 0) - v.setX(v.getX() + n); - else if (axis == 1) - v.setY(v.getY() + n); - else - v.setZ(v.getZ() + n); - getExpr().change(e, new Vector[] {v}, ChangeMode.SET); + for (Vector v : vectors) { + if (axis == 0) + v.setX(v.getX() + deltaValue); + else if (axis == 1) + v.setY(v.getY() + deltaValue); + else + v.setZ(v.getZ() + deltaValue); + } break; case SET: - if (axis == 0) - v.setX(n); - else if (axis == 1) - v.setY(n); - else - v.setZ(n); - getExpr().change(e, new Vector[] {v}, ChangeMode.SET); + for (Vector v : vectors) { + if (axis == 0) + v.setX(deltaValue); + else if (axis == 1) + v.setY(deltaValue); + else + v.setZ(deltaValue); + } + break; + default: + assert false; + return; } + getExpr().change(event, vectors, ChangeMode.SET); } - - @Override - protected String getPropertyName() { - return axes[axis] + " component"; - } - + @Override public Class getReturnType() { return Number.class; } - + + @Override + protected String getPropertyName() { + return axes[axis] + " component"; + } } From 50f0f3c6f46f8e715fa698470082f46e5abc52ce Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Wed, 30 Aug 2023 19:10:08 -0700 Subject: [PATCH 032/176] More improvements --- .../effects/EffVectorRotateAroundAnother.java | 14 +++--- .../skript/effects/EffVectorRotateXYZ.java | 20 +++++---- .../expressions/ExprVectorAngleBetween.java | 4 +- .../expressions/ExprVectorArithmetic.java | 24 +++++------ .../ExprVectorBetweenLocations.java | 12 +++--- .../expressions/ExprVectorCrossProduct.java | 4 +- .../expressions/ExprVectorCylindrical.java | 8 ++-- .../expressions/ExprVectorDotProduct.java | 4 +- .../skript/expressions/ExprVectorFromXYZ.java | 4 +- .../ExprVectorFromYawAndPitch.java | 14 +++--- .../skript/expressions/ExprVectorLength.java | 43 +++++++++++-------- .../expressions/ExprVectorNormalize.java | 9 +++- .../expressions/ExprVectorOfLocation.java | 10 +++-- .../expressions/ExprVectorSpherical.java | 8 ++-- .../expressions/ExprVectorSquaredLength.java | 4 +- .../skript/expressions/ExprVectorXYZ.java | 22 +++++----- 16 files changed, 120 insertions(+), 84 deletions(-) diff --git a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java index 5b49c1a0888..1fba62a7ab8 100644 --- a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java +++ b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java @@ -34,8 +34,10 @@ import ch.njol.util.VectorMath; @Name("Vectors - Rotate Around Vector") -@Description("Rotates a vector around another vector") -@Examples({"rotate {_v} around vector 1, 0, 0 by 90"}) +@Description("Rotates one or more vectors around another vector") +@Examples({ + "rotate {_v} around vector 1, 0, 0 by 90" +}) @Since("2.2-dev28") public class EffVectorRotateAroundAnother extends Effect { @@ -61,12 +63,12 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean kleenean @SuppressWarnings("null") @Override protected void execute(Event event) { - Vector v2 = second.getSingle(event); - Number d = degree.getSingle(event); - if (v2 == null || d == null) + Vector axis = second.getSingle(event); + Number angle = degree.getSingle(event); + if (axis == null || angle == null) return; for (Vector v1 : first.getArray(event)) - VectorMath.rot(v1, v2, d.doubleValue()); + VectorMath.rot(v1, axis, angle.doubleValue()); } @Override diff --git a/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java b/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java index 06d4b3d98e2..0e95f79ca6f 100644 --- a/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java +++ b/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java @@ -34,10 +34,12 @@ import ch.njol.util.VectorMath; @Name("Vectors - Rotate around XYZ") -@Description("Rotates a vector around x, y, or z axis by some degrees") -@Examples({"rotate {_v} around x-axis by 90", - "rotate {_v} around y-axis by 90", - "rotate {_v} around z-axis by 90 degrees"}) +@Description("Rotates one or more vectors around the x, y, or z axis by some amount of degrees") +@Examples({ + "rotate {_v} around x-axis by 90", + "rotate {_v} around y-axis by 90", + "rotate {_v} around z-axis by 90 degrees" +}) @Since("2.2-dev28") public class EffVectorRotateXYZ extends Effect { @@ -66,21 +68,21 @@ public boolean init(Expression[] expressions, int matchedPattern, Kleenean is @Override @SuppressWarnings("null") protected void execute(Event event) { - Number d = degree.getSingle(event); - if (d == null) + Number angle = degree.getSingle(event); + if (angle == null) return; switch (axis) { case 0: for (Vector v : vectors.getArray(event)) - VectorMath.rotX(v, d.doubleValue()); + VectorMath.rotX(v, angle.doubleValue()); break; case 1: for (Vector v : vectors.getArray(event)) - VectorMath.rotY(v, d.doubleValue()); + VectorMath.rotY(v, angle.doubleValue()); break; case 2: for (Vector v : vectors.getArray(event)) - VectorMath.rotZ(v, d.doubleValue()); + VectorMath.rotZ(v, angle.doubleValue()); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java index 831ee61de67..d6675ca2712 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java @@ -37,7 +37,9 @@ @Name("Vectors - Angle Between") @Description("Gets the angle between two vectors.") -@Examples({"send \"%the angle between vector 1, 0, 0 and vector 0, 1, 1%\""}) +@Examples({ + "send \"%the angle between vector 1, 0, 0 and vector 0, 1, 1%\"" +}) @Since("2.2-dev28") public class ExprVectorAngleBetween extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java b/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java index 4d1c7cf89ea..7cfc91f6948 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java @@ -37,15 +37,13 @@ @Name("Vectors - Arithmetic") @Description("Arithmetic expressions for vectors.") -@Examples({"set {_v} to vector 1, 2, 3 // 5", - "set {_v} to {_v} ++ {_v}", - "set {_v} to {_v} ++ 5", - "set {_v} to {_v} -- {_v}", - "set {_v} to {_v} -- 5", - "set {_v} to {_v} ** {_v}", - "set {_v} to {_v} ** 5", - "set {_v} to {_v} // {_v}", - "set {_v} to {_v} // 5"}) +@Examples({ + "set {_v} to vector 1, 2, 3 // vector 5, 5, 5", + "set {_v} to {_v} ++ {_v}", + "set {_v} to {_v} -- {_v}", + "set {_v} to {_v} ** {_v}", + "set {_v} to {_v} // {_v}" +}) @Since("2.2-dev28") public class ExprVectorArithmetic extends SimpleExpression { @@ -104,14 +102,14 @@ public String toString() { private Expression first, second; @SuppressWarnings("null") - private Operator op; + private Operator operator; @Override @SuppressWarnings({"unchecked", "null"}) public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelayed, ParseResult parseResult) { first = (Expression) exprs[0]; second = (Expression) exprs[1]; - op = patterns.getInfo(matchedPattern); + operator = patterns.getInfo(matchedPattern); return true; } @@ -119,7 +117,7 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye protected Vector[] get(Event event) { Vector v1 = first.getOptionalSingle(event).orElse(new Vector()); Vector v2 = second.getOptionalSingle(event).orElse(new Vector()); - return CollectionUtils.array(op.calculate(v1, v2)); + return CollectionUtils.array(operator.calculate(v1, v2)); } @Override @@ -134,7 +132,7 @@ public Class getReturnType() { @Override public String toString(@Nullable Event event, boolean debug) { - return first.toString(event, debug) + " " + op + " " + second.toString(event, debug); + return first.toString(event, debug) + " " + operator + " " + second.toString(event, debug); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java b/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java index 11572102eed..346e1f4e386 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java @@ -37,7 +37,9 @@ @Name("Vectors - Vector Between Locations") @Description("Creates a vector between two locations.") -@Examples({"set {_v} to vector between {_loc1} and {_loc2}"}) +@Examples({ + "set {_v} to vector between {_loc1} and {_loc2}" +}) @Since("2.2-dev28") public class ExprVectorBetweenLocations extends SimpleExpression { @@ -60,11 +62,11 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") protected Vector[] get(Event event) { - Location l1 = from.getSingle(event); - Location l2 = to.getSingle(event); - if (l1 == null || l2 == null) + Location from = this.from.getSingle(event); + Location to = this.to.getSingle(event); + if (from == null || to == null) return null; - return CollectionUtils.array(new Vector(l2.getX() - l1.getX(), l2.getY() - l1.getY(), l2.getZ() - l1.getZ())); + return CollectionUtils.array(new Vector(to.getX() - from.getX(), to.getY() - from.getY(), to.getZ() - from.getZ())); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java index 8bb22ffd59a..4afa99e2e02 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java @@ -36,7 +36,9 @@ @Name("Vectors - Cross Product") @Description("Gets the cross product between two vectors.") -@Examples({"send \"%vector 1, 0, 0 cross vector 0, 1, 0%\""}) +@Examples({ + "send \"%vector 1, 0, 0 cross vector 0, 1, 0%\"" +}) @Since("2.2-dev28") public class ExprVectorCrossProduct extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java b/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java index 48e940a2450..40cd9edd963 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorCylindrical.java @@ -37,9 +37,11 @@ @Name("Vectors - Cylindrical Shape") @Description("Forms a 'cylindrical shaped' vector using yaw to manipulate the current point.") -@Examples({"loop 360 times:", - " set {_v} to cylindrical vector radius 1, yaw loop-value, height 2", - "set {_v} to cylindrical vector radius 1, yaw 90, height 2"}) +@Examples({ + "loop 360 times:", + "\tset {_v} to cylindrical vector radius 1, yaw loop-value, height 2", + "set {_v} to cylindrical vector radius 1, yaw 90, height 2" +}) @Since("2.2-dev28") public class ExprVectorCylindrical extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java index a02dacc5d94..d1f9154a254 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java @@ -36,7 +36,9 @@ @Name("Vectors - Dot Product") @Description("Gets the dot product between two vectors.") -@Examples({"set {_v} to {_v2} dot {_v3}"}) +@Examples({ + "set {_dot} to {_v1} dot {_v2}" +}) @Since("2.2-dev28") public class ExprVectorDotProduct extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java b/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java index 53ab07108dc..ff05bb78fb6 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java @@ -36,7 +36,9 @@ @Name("Vectors - Create from XYZ") @Description("Creates a vector from x, y and z values.") -@Examples({"set {_v} to vector 0, 1, 0"}) +@Examples({ + "set {_v} to vector 0, 1, 0" +}) @Since("2.2-dev28") public class ExprVectorFromXYZ extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java b/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java index 16c8590a1a4..e3fa1989f9f 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java @@ -37,7 +37,9 @@ @Name("Vectors - Vector from Pitch and Yaw") @Description("Creates a vector from a yaw and pitch value.") -@Examples({"set {_v} to vector from yaw 45 and pitch 45"}) +@Examples({ + "set {_v} to vector from yaw 45 and pitch 45" +}) @Since("2.2-dev28") public class ExprVectorFromYawAndPitch extends SimpleExpression { @@ -60,12 +62,12 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") protected Vector[] get(Event event) { - Number y = yaw.getSingle(event); - Number p = pitch.getSingle(event); - if (y == null || p == null) + Number skriptYaw = yaw.getSingle(event); + Number skriptPitch = pitch.getSingle(event); + if (skriptYaw == null || skriptPitch == null) return null; - float yaw = VectorMath.fromSkriptYaw(VectorMath.wrapAngleDeg(y.floatValue())); - float pitch = VectorMath.fromSkriptPitch(VectorMath.wrapAngleDeg(p.floatValue())); + float yaw = VectorMath.fromSkriptYaw(VectorMath.wrapAngleDeg(skriptYaw.floatValue())); + float pitch = VectorMath.fromSkriptPitch(VectorMath.wrapAngleDeg(skriptPitch.floatValue())); return CollectionUtils.array(VectorMath.fromYawAndPitch(yaw, pitch)); } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java b/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java index 193e3efd809..490294384a5 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java @@ -32,10 +32,12 @@ @Name("Vectors - Length") @Description("Gets or sets the length of a vector.") -@Examples({"send \"%standard length of vector 1, 2, 3%\"", - "set {_v} to vector 1, 2, 3", - "set standard length of {_v} to 2", - "send \"%standard length of {_v}%\""}) +@Examples({ + "send \"%standard length of vector 1, 2, 3%\"", + "set {_v} to vector 1, 2, 3", + "set standard length of {_v} to 2", + "send \"%standard length of {_v}%\"" +}) @Since("2.2-dev28") public class ExprVectorLength extends SimplePropertyExpression { @@ -60,32 +62,37 @@ public Class[] acceptChange(ChangeMode mode) { @Override public void change(Event event, @Nullable Object[] delta, ChangeMode mode) { assert delta != null; - final Vector v = getExpr().getSingle(event); - if (v == null) - return; + final Vector[] vectors = getExpr().getArray(event); double deltaLength = ((Number) delta[0]).doubleValue(); switch (mode) { case REMOVE: deltaLength = -deltaLength; //$FALL-THROUGH$ case ADD: - if (deltaLength < 0 && v.lengthSquared() < deltaLength * deltaLength) { - v.zero(); - } else { - double l = deltaLength + v.length(); - v.normalize().multiply(l); + for (Vector v : vectors) { + if (deltaLength < 0 && v.lengthSquared() < deltaLength * deltaLength) { + v.zero(); + } else { + double newLength = deltaLength + v.length(); + if (!v.isNormalized()) + v.normalize(); + v.multiply(newLength); + } } - getExpr().change(event, new Vector[]{v}, ChangeMode.SET); break; case SET: - if (deltaLength < 0) { - v.zero(); - } else { - v.normalize().multiply(deltaLength); + for (Vector v : vectors) { + if (deltaLength < 0) { + v.zero(); + } else { + if (!v.isNormalized()) + v.normalize(); + v.multiply(deltaLength); + } } - getExpr().change(event, new Vector[]{v}, ChangeMode.SET); break; } + getExpr().change(event, vectors, ChangeMode.SET); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java index 53a79531bc1..f734cc46956 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java @@ -36,7 +36,9 @@ @Name("Vectors - Normalized") @Description("Returns the same vector but with length 1.") -@Examples({"set {_v} to normalized {_v}"}) +@Examples({ + "set {_v} to normalized {_v}" +}) @Since("2.2-dev28") public class ExprVectorNormalize extends SimpleExpression { @@ -62,7 +64,10 @@ protected Vector[] get(Event event) { Vector v = vector.getSingle(event); if (v == null) return null; - return CollectionUtils.array(v.clone().normalize()); + v = v.clone(); + if (!v.isNormalized()) + v.normalize(); + return CollectionUtils.array(v); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java b/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java index 9ec6e643868..a0f50881f4f 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java @@ -37,7 +37,9 @@ @Name("Vectors - Vector from Location") @Description("Creates a vector from a location.") -@Examples({"set {_v} to vector of {_loc}"}) +@Examples({ + "set {_v} to vector of {_loc}" +}) @Since("2.2-dev28") public class ExprVectorOfLocation extends SimpleExpression { @@ -60,10 +62,10 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") protected Vector[] get(Event event) { - Location l = location.getSingle(event); - if (l == null) + Location location = this.location.getSingle(event); + if (location == null) return null; - return CollectionUtils.array(l.toVector()); + return CollectionUtils.array(location.toVector()); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java b/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java index 4da884bf48e..3507f8ab25a 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorSpherical.java @@ -37,9 +37,11 @@ @Name("Vectors - Spherical Shape") @Description("Forms a 'spherical shaped' vector using yaw and pitch to manipulate the current point.") -@Examples({"loop 360 times:", - " set {_v} to spherical vector radius 1, yaw loop-value, pitch loop-value", - "set {_v} to spherical vector radius 1, yaw 45, pitch 90"}) +@Examples({ + "loop 360 times:", + "\tset {_v} to spherical vector radius 1, yaw loop-value, pitch loop-value", + "set {_v} to spherical vector radius 1, yaw 45, pitch 90" +}) @Since("2.2-dev28") public class ExprVectorSpherical extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java b/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java index fd81a40a9cf..e5119fd09fe 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java @@ -28,7 +28,9 @@ @Name("Vectors - Squared Length") @Description("Gets the squared length of a vector.") -@Examples({"send \"%squared length of vector 1, 2, 3%\""}) +@Examples({ + "send \"%squared length of vector 1, 2, 3%\"" +}) @Since("2.2-dev28") public class ExprVectorSquaredLength extends SimplePropertyExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java b/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java index 95cbcff1645..90df3c546c8 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java @@ -36,16 +36,18 @@ @Name("Vectors - XYZ Component") @Description("Gets or changes the x, y or z component of a vector.") -@Examples({"set {_v} to vector 1, 2, 3", - "send \"%x of {_v}%, %y of {_v}%, %z of {_v}%\"", - "add 1 to x of {_v}", - "add 2 to y of {_v}", - "add 3 to z of {_v}", - "send \"%x of {_v}%, %y of {_v}%, %z of {_v}%\"", - "set x component of {_v} to 1", - "set y component of {_v} to 2", - "set z component of {_v} to 3", - "send \"%x component of {_v}%, %y component of {_v}%, %z component of {_v}%\"",}) +@Examples({ + "set {_v} to vector 1, 2, 3", + "send \"%x of {_v}%, %y of {_v}%, %z of {_v}%\"", + "add 1 to x of {_v}", + "add 2 to y of {_v}", + "add 3 to z of {_v}", + "send \"%x of {_v}%, %y of {_v}%, %z of {_v}%\"", + "set x component of {_v::*} to 1", + "set y component of {_v::*} to 2", + "set z component of {_v::*} to 3", + "send \"%x component of {_v::*}%, %y component of {_v::*}%, %z component of {_v::*}%\"" +}) @Since("2.2-dev28") public class ExprVectorXYZ extends SimplePropertyExpression { From 4a7c510859749bf3b79583e6c590f09b121ae29b Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Thu, 31 Aug 2023 09:20:07 -0700 Subject: [PATCH 033/176] Apply suggestions from code review Co-authored-by: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> --- .../ch/njol/skript/effects/EffVectorRotateAroundAnother.java | 4 +--- .../ch/njol/skript/expressions/ExprVectorAngleBetween.java | 4 +--- .../ch/njol/skript/expressions/ExprVectorCrossProduct.java | 4 +--- .../java/ch/njol/skript/expressions/ExprVectorDotProduct.java | 4 +--- .../ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java | 4 +--- .../java/ch/njol/skript/expressions/ExprVectorNormalize.java | 4 +--- .../java/ch/njol/skript/expressions/ExprVectorOfLocation.java | 4 +--- .../ch/njol/skript/expressions/ExprVectorSquaredLength.java | 4 +--- 8 files changed, 8 insertions(+), 24 deletions(-) diff --git a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java index 1fba62a7ab8..a82f95977a0 100644 --- a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java +++ b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java @@ -35,9 +35,7 @@ @Name("Vectors - Rotate Around Vector") @Description("Rotates one or more vectors around another vector") -@Examples({ - "rotate {_v} around vector 1, 0, 0 by 90" -}) +@Examples("rotate {_v} around vector 1, 0, 0 by 90") @Since("2.2-dev28") public class EffVectorRotateAroundAnother extends Effect { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java index d6675ca2712..8f03b6684f5 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java @@ -37,9 +37,7 @@ @Name("Vectors - Angle Between") @Description("Gets the angle between two vectors.") -@Examples({ - "send \"%the angle between vector 1, 0, 0 and vector 0, 1, 1%\"" -}) +@Examples("send \"%the angle between vector 1, 0, 0 and vector 0, 1, 1%\"") @Since("2.2-dev28") public class ExprVectorAngleBetween extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java index 4afa99e2e02..d2c59b63989 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java @@ -36,9 +36,7 @@ @Name("Vectors - Cross Product") @Description("Gets the cross product between two vectors.") -@Examples({ - "send \"%vector 1, 0, 0 cross vector 0, 1, 0%\"" -}) +@Examples("send \"%vector 1, 0, 0 cross vector 0, 1, 0%\"") @Since("2.2-dev28") public class ExprVectorCrossProduct extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java index d1f9154a254..0403e64e541 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java @@ -36,9 +36,7 @@ @Name("Vectors - Dot Product") @Description("Gets the dot product between two vectors.") -@Examples({ - "set {_dot} to {_v1} dot {_v2}" -}) +@Examples("set {_dot} to {_v1} dot {_v2}") @Since("2.2-dev28") public class ExprVectorDotProduct extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java b/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java index e3fa1989f9f..8f7179e7d26 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorFromYawAndPitch.java @@ -37,9 +37,7 @@ @Name("Vectors - Vector from Pitch and Yaw") @Description("Creates a vector from a yaw and pitch value.") -@Examples({ - "set {_v} to vector from yaw 45 and pitch 45" -}) +@Examples("set {_v} to vector from yaw 45 and pitch 45") @Since("2.2-dev28") public class ExprVectorFromYawAndPitch extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java index f734cc46956..b1a25debf3c 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java @@ -36,9 +36,7 @@ @Name("Vectors - Normalized") @Description("Returns the same vector but with length 1.") -@Examples({ - "set {_v} to normalized {_v}" -}) +@Examples("set {_v} to normalized {_v}") @Since("2.2-dev28") public class ExprVectorNormalize extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java b/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java index a0f50881f4f..e15974b78a7 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorOfLocation.java @@ -37,9 +37,7 @@ @Name("Vectors - Vector from Location") @Description("Creates a vector from a location.") -@Examples({ - "set {_v} to vector of {_loc}" -}) +@Examples("set {_v} to vector of {_loc}") @Since("2.2-dev28") public class ExprVectorOfLocation extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java b/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java index e5119fd09fe..bdfeeb33b74 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorSquaredLength.java @@ -28,9 +28,7 @@ @Name("Vectors - Squared Length") @Description("Gets the squared length of a vector.") -@Examples({ - "send \"%squared length of vector 1, 2, 3%\"" -}) +@Examples("send \"%squared length of vector 1, 2, 3%\"") @Since("2.2-dev28") public class ExprVectorSquaredLength extends SimplePropertyExpression { From 729b0ecd55477bdfd2a24c7438209a2c8efbd2b2 Mon Sep 17 00:00:00 2001 From: sovdee <10354869+sovdeeth@users.noreply.github.com> Date: Thu, 31 Aug 2023 16:57:55 -0700 Subject: [PATCH 034/176] Budget Expansion --- .../effects/EffVectorRotateAroundAnother.java | 14 +++++----- .../skript/effects/EffVectorRotateXYZ.java | 12 ++++----- .../expressions/ExprVectorAngleBetween.java | 8 +++--- .../expressions/ExprVectorArithmetic.java | 26 +++++++++---------- .../ExprVectorBetweenLocations.java | 4 +-- .../expressions/ExprVectorCrossProduct.java | 8 +++--- .../expressions/ExprVectorDotProduct.java | 8 +++--- .../skript/expressions/ExprVectorFromXYZ.java | 4 +-- .../skript/expressions/ExprVectorLength.java | 24 ++++++++--------- .../expressions/ExprVectorNormalize.java | 12 ++++----- .../skript/expressions/ExprVectorXYZ.java | 20 +++++++------- 11 files changed, 68 insertions(+), 72 deletions(-) diff --git a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java index a82f95977a0..10b83986f4d 100644 --- a/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java +++ b/src/main/java/ch/njol/skript/effects/EffVectorRotateAroundAnother.java @@ -44,7 +44,7 @@ public class EffVectorRotateAroundAnother extends Effect { } @SuppressWarnings("null") - private Expression first, second; + private Expression vectors, axis; @SuppressWarnings("null") private Expression degree; @@ -52,8 +52,8 @@ public class EffVectorRotateAroundAnother extends Effect { @SuppressWarnings({"unchecked", "null"}) @Override public boolean init(Expression[] exprs, int matchedPattern, Kleenean kleenean, ParseResult parseResult) { - first = (Expression) exprs[0]; - second = (Expression) exprs[1]; + vectors = (Expression) exprs[0]; + axis = (Expression) exprs[1]; degree = (Expression) exprs[2]; return true; } @@ -61,17 +61,17 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean kleenean @SuppressWarnings("null") @Override protected void execute(Event event) { - Vector axis = second.getSingle(event); + Vector axis = this.axis.getSingle(event); Number angle = degree.getSingle(event); if (axis == null || angle == null) return; - for (Vector v1 : first.getArray(event)) - VectorMath.rot(v1, axis, angle.doubleValue()); + for (Vector vector : vectors.getArray(event)) + VectorMath.rot(vector, axis, angle.doubleValue()); } @Override public String toString(@Nullable Event event, boolean debug) { - return "rotate " + first.toString(event, debug) + " around " + second.toString(event, debug) + " by " + degree.toString(event, debug) + "degrees"; + return "rotate " + vectors.toString(event, debug) + " around " + axis.toString(event, debug) + " by " + degree.toString(event, debug) + "degrees"; } } diff --git a/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java b/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java index 0e95f79ca6f..6e24d2882bb 100644 --- a/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java +++ b/src/main/java/ch/njol/skript/effects/EffVectorRotateXYZ.java @@ -73,16 +73,16 @@ protected void execute(Event event) { return; switch (axis) { case 0: - for (Vector v : vectors.getArray(event)) - VectorMath.rotX(v, angle.doubleValue()); + for (Vector vector : vectors.getArray(event)) + VectorMath.rotX(vector, angle.doubleValue()); break; case 1: - for (Vector v : vectors.getArray(event)) - VectorMath.rotY(v, angle.doubleValue()); + for (Vector vector : vectors.getArray(event)) + VectorMath.rotY(vector, angle.doubleValue()); break; case 2: - for (Vector v : vectors.getArray(event)) - VectorMath.rotZ(v, angle.doubleValue()); + for (Vector vector : vectors.getArray(event)) + VectorMath.rotZ(vector, angle.doubleValue()); } } diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java index 8f03b6684f5..1cdf3626c8e 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorAngleBetween.java @@ -60,11 +60,11 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") protected Number[] get(Event event) { - Vector v1 = first.getSingle(event); - Vector v2 = second.getSingle(event); - if (v1 == null || v2 == null) + Vector first = this.first.getSingle(event); + Vector second = this.second.getSingle(event); + if (first == null || second == null) return null; - return CollectionUtils.array(v1.angle(v2) * (float) VectorMath.RAD_TO_DEG); + return CollectionUtils.array(first.angle(second) * (float) VectorMath.RAD_TO_DEG); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java b/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java index 7cfc91f6948..41c81c2d8d4 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorArithmetic.java @@ -44,32 +44,32 @@ "set {_v} to {_v} ** {_v}", "set {_v} to {_v} // {_v}" }) -@Since("2.2-dev28") +@Since("2.2-desecond8") public class ExprVectorArithmetic extends SimpleExpression { private enum Operator { PLUS("++") { @Override - public Vector calculate(final Vector v1, final Vector v2) { - return v1.clone().add(v2); + public Vector calculate(final Vector first, final Vector second) { + return first.clone().add(second); } }, MINUS("--") { @Override - public Vector calculate(final Vector v1, final Vector v2) { - return v1.clone().subtract(v2); + public Vector calculate(final Vector first, final Vector second) { + return first.clone().subtract(second); } }, MULT("**") { @Override - public Vector calculate(final Vector v1, final Vector v2) { - return v1.clone().multiply(v2); + public Vector calculate(final Vector first, final Vector second) { + return first.clone().multiply(second); } }, DIV("//") { @Override - public Vector calculate(final Vector v1, final Vector v2) { - return v1.clone().divide(v2); + public Vector calculate(final Vector first, final Vector second) { + return first.clone().divide(second); } }; @@ -79,7 +79,7 @@ public Vector calculate(final Vector v1, final Vector v2) { this.sign = sign; } - public abstract Vector calculate(Vector v1, Vector v2); + public abstract Vector calculate(Vector first, Vector second); @Override public String toString() { @@ -115,9 +115,9 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override protected Vector[] get(Event event) { - Vector v1 = first.getOptionalSingle(event).orElse(new Vector()); - Vector v2 = second.getOptionalSingle(event).orElse(new Vector()); - return CollectionUtils.array(operator.calculate(v1, v2)); + Vector first = this.first.getOptionalSingle(event).orElse(new Vector()); + Vector second = this.second.getOptionalSingle(event).orElse(new Vector()); + return CollectionUtils.array(operator.calculate(first, second)); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java b/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java index 346e1f4e386..75412c017b2 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorBetweenLocations.java @@ -37,9 +37,7 @@ @Name("Vectors - Vector Between Locations") @Description("Creates a vector between two locations.") -@Examples({ - "set {_v} to vector between {_loc1} and {_loc2}" -}) +@Examples("set {_v} to vector between {_loc1} and {_loc2}") @Since("2.2-dev28") public class ExprVectorBetweenLocations extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java index d2c59b63989..ae8ebe990e1 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorCrossProduct.java @@ -58,11 +58,11 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") protected Vector[] get(Event event) { - Vector v1 = first.getSingle(event); - Vector v2 = second.getSingle(event); - if (v1 == null || v2 == null) + Vector first = this.first.getSingle(event); + Vector second = this.second.getSingle(event); + if (first == null || second == null) return null; - return CollectionUtils.array(v1.clone().crossProduct(v2)); + return CollectionUtils.array(first.clone().crossProduct(second)); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java index 0403e64e541..50ef5e9ea15 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorDotProduct.java @@ -58,11 +58,11 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") protected Number[] get(Event event) { - Vector v1 = first.getSingle(event); - Vector v2 = second.getSingle(event); - if (v1 == null || v2 == null) + Vector first = this.first.getSingle(event); + Vector second = this.second.getSingle(event); + if (first == null || second == null) return null; - return CollectionUtils.array(v1.getX() * v2.getX() + v1.getY() * v2.getY() + v1.getZ() * v2.getZ()); + return CollectionUtils.array(first.getX() * second.getX() + first.getY() * second.getY() + first.getZ() * second.getZ()); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java b/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java index ff05bb78fb6..6b553e6f50b 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorFromXYZ.java @@ -36,9 +36,7 @@ @Name("Vectors - Create from XYZ") @Description("Creates a vector from x, y and z values.") -@Examples({ - "set {_v} to vector 0, 1, 0" -}) +@Examples("set {_v} to vector 0, 1, 0") @Since("2.2-dev28") public class ExprVectorFromXYZ extends SimpleExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java b/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java index 490294384a5..62f2a695e85 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorLength.java @@ -69,25 +69,25 @@ public void change(Event event, @Nullable Object[] delta, ChangeMode mode) { deltaLength = -deltaLength; //$FALL-THROUGH$ case ADD: - for (Vector v : vectors) { - if (deltaLength < 0 && v.lengthSquared() < deltaLength * deltaLength) { - v.zero(); + for (Vector vector : vectors) { + if (deltaLength < 0 && vector.lengthSquared() < deltaLength * deltaLength) { + vector.zero(); } else { - double newLength = deltaLength + v.length(); - if (!v.isNormalized()) - v.normalize(); - v.multiply(newLength); + double newLength = deltaLength + vector.length(); + if (!vector.isNormalized()) + vector.normalize(); + vector.multiply(newLength); } } break; case SET: - for (Vector v : vectors) { + for (Vector vector : vectors) { if (deltaLength < 0) { - v.zero(); + vector.zero(); } else { - if (!v.isNormalized()) - v.normalize(); - v.multiply(deltaLength); + if (!vector.isNormalized()) + vector.normalize(); + vector.multiply(deltaLength); } } break; diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java index b1a25debf3c..00b80f7d109 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorNormalize.java @@ -59,13 +59,13 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye @Override @SuppressWarnings("null") protected Vector[] get(Event event) { - Vector v = vector.getSingle(event); - if (v == null) + Vector vector = this.vector.getSingle(event); + if (vector == null) return null; - v = v.clone(); - if (!v.isNormalized()) - v.normalize(); - return CollectionUtils.array(v); + vector = vector.clone(); + if (!vector.isNormalized()) + vector.normalize(); + return CollectionUtils.array(vector); } @Override diff --git a/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java b/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java index 90df3c546c8..2955fef5b97 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java +++ b/src/main/java/ch/njol/skript/expressions/ExprVectorXYZ.java @@ -67,8 +67,8 @@ public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelaye } @Override - public Number convert(Vector v) { - return axis == 0 ? v.getX() : (axis == 1 ? v.getY() : v.getZ()); + public Number convert(Vector vector) { + return axis == 0 ? vector.getX() : (axis == 1 ? vector.getY() : vector.getZ()); } @Override @@ -90,23 +90,23 @@ public void change(Event event, @Nullable Object[] delta, ChangeMode mode) { deltaValue = -deltaValue; //$FALL-THROUGH$ case ADD: - for (Vector v : vectors) { + for (Vector vector : vectors) { if (axis == 0) - v.setX(v.getX() + deltaValue); + vector.setX(vector.getX() + deltaValue); else if (axis == 1) - v.setY(v.getY() + deltaValue); + vector.setY(vector.getY() + deltaValue); else - v.setZ(v.getZ() + deltaValue); + vector.setZ(vector.getZ() + deltaValue); } break; case SET: - for (Vector v : vectors) { + for (Vector vector : vectors) { if (axis == 0) - v.setX(deltaValue); + vector.setX(deltaValue); else if (axis == 1) - v.setY(deltaValue); + vector.setY(deltaValue); else - v.setZ(deltaValue); + vector.setZ(deltaValue); } break; default: From be7701516edb3233465954898af7922aa7a69e73 Mon Sep 17 00:00:00 2001 From: Patrick Miller Date: Sun, 1 Oct 2023 02:26:19 -0400 Subject: [PATCH 035/176] Fix Logging Issues In ExpressionEntryData (#6081) Fix duplicate logging --- .../skriptlang/skript/lang/entry/util/ExpressionEntryData.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/org/skriptlang/skript/lang/entry/util/ExpressionEntryData.java b/src/main/java/org/skriptlang/skript/lang/entry/util/ExpressionEntryData.java index e707d3337d3..42e964918f9 100644 --- a/src/main/java/org/skriptlang/skript/lang/entry/util/ExpressionEntryData.java +++ b/src/main/java/org/skriptlang/skript/lang/entry/util/ExpressionEntryData.java @@ -69,7 +69,7 @@ public ExpressionEntryData( @SuppressWarnings("unchecked") protected Expression getValue(String value) { Expression expression; - try (ParseLogHandler log = new ParseLogHandler()) { + try (ParseLogHandler log = new ParseLogHandler().start()) { expression = new SkriptParser(value, flags, ParseContext.DEFAULT) .parseExpression(returnType); if (expression == null) // print an error if it couldn't parse From 8a624652d0526483fd656b5ff4e6219ae65e88f5 Mon Sep 17 00:00:00 2001 From: Patrick Miller Date: Sun, 1 Oct 2023 14:20:44 -0400 Subject: [PATCH 036/176] Prepare For Release 2.7.1 (#6082) --- skript-aliases | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/skript-aliases b/skript-aliases index fb9c3044e55..1ee77d8573a 160000 --- a/skript-aliases +++ b/skript-aliases @@ -1 +1 @@ -Subproject commit fb9c3044e555667b4dc5558467608bd55fa32df0 +Subproject commit 1ee77d8573aa37456f1b49fe12aec7bb410d1dd7 From 886fb67dbdd829979a7a343dd9ab3def4e24a90f Mon Sep 17 00:00:00 2001 From: Spongecade Date: Mon, 2 Oct 2023 09:08:31 -0500 Subject: [PATCH 037/176] Update Minecraft wiki links to new domain (#6078) --- src/main/java/ch/njol/skript/classes/data/BukkitClasses.java | 4 ++-- src/main/java/ch/njol/skript/conditions/CondIsSlimeChunk.java | 2 +- src/main/java/ch/njol/skript/effects/EffExplosion.java | 2 +- src/main/java/ch/njol/skript/expressions/ExprAge.java | 2 +- .../java/ch/njol/skript/expressions/ExprExplosionYield.java | 2 +- .../java/ch/njol/skript/expressions/ExprExplosiveYield.java | 2 +- .../java/ch/njol/skript/expressions/ExprGlidingState.java | 2 +- .../java/ch/njol/skript/expressions/ExprScoreboardTags.java | 2 +- 8 files changed, 9 insertions(+), 9 deletions(-) diff --git a/src/main/java/ch/njol/skript/classes/data/BukkitClasses.java b/src/main/java/ch/njol/skript/classes/data/BukkitClasses.java index ccf12240d29..d674a18890d 100644 --- a/src/main/java/ch/njol/skript/classes/data/BukkitClasses.java +++ b/src/main/java/ch/njol/skript/classes/data/BukkitClasses.java @@ -1410,7 +1410,7 @@ public String toVariableNameString(FireworkEffect effect) { .user("(panda )?genes?") .name("Gene") .description("Represents a Panda's main or hidden gene. " + - "See genetics for more info.") + "See genetics for more info.") .since("2.4") .requiredPlugins("Minecraft 1.14 or newer")); } @@ -1486,7 +1486,7 @@ public String toVariableNameString(EnchantmentOffer eo) { .user("attribute ?types?") .name("Attribute Type") .description("Represents the type of an attribute. Note that this type does not contain any numerical values." - + "See attribute types for more info.") + + "See attribute types for more info.") .since("2.5")); Classes.registerClass(new EnumClassInfo<>(Environment.class, "environment", "environments") diff --git a/src/main/java/ch/njol/skript/conditions/CondIsSlimeChunk.java b/src/main/java/ch/njol/skript/conditions/CondIsSlimeChunk.java index 71dbbea2dcc..1b71258482b 100755 --- a/src/main/java/ch/njol/skript/conditions/CondIsSlimeChunk.java +++ b/src/main/java/ch/njol/skript/conditions/CondIsSlimeChunk.java @@ -35,7 +35,7 @@ @Name("Is Slime Chunk") @Description({"Tests whether a chunk is a so-called slime chunk.", "Slimes can generally spawn in the swamp biome and in slime chunks.", - "For more info, see the Minecraft wiki."}) + "For more info, see the Minecraft wiki."}) @Examples({"command /slimey:", "\ttrigger:", "\t\tif chunk at player is a slime chunk:", diff --git a/src/main/java/ch/njol/skript/effects/EffExplosion.java b/src/main/java/ch/njol/skript/effects/EffExplosion.java index 4f0de85dd86..192119a54d6 100644 --- a/src/main/java/ch/njol/skript/effects/EffExplosion.java +++ b/src/main/java/ch/njol/skript/effects/EffExplosion.java @@ -37,7 +37,7 @@ * @author Peter Güttinger */ @Name("Explosion") -@Description({"Creates an explosion of a given force. The Minecraft Wiki has an article on explosions " + +@Description({"Creates an explosion of a given force. The Minecraft Wiki has an article on explosions " + "which lists the explosion forces of TNT, creepers, etc.", "Hint: use a force of 0 to create a fake explosion that does no damage whatsoever, or use the explosion effect introduced in Skript 2.0.", "Starting with Bukkit 1.4.5 and Skript 2.0 you can use safe explosions which will damage entities but won't destroy any blocks."}) diff --git a/src/main/java/ch/njol/skript/expressions/ExprAge.java b/src/main/java/ch/njol/skript/expressions/ExprAge.java index 2a29300beb0..1be159daf08 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprAge.java +++ b/src/main/java/ch/njol/skript/expressions/ExprAge.java @@ -119,7 +119,7 @@ public void change(Event event, @Nullable Object[] delta, ChangeMode mode) { setAge(obj, newValue); break; case RESET: - // baby animals takes 20 minutes to grow up - ref: https://minecraft.fandom.com/wiki/Breeding + // baby animals takes 20 minutes to grow up - ref: https://minecraft.wiki/w/Breeding if (obj instanceof org.bukkit.entity.Ageable) // it might change later on so removing entity age reset would be better unless // bukkit adds a method returning the default age diff --git a/src/main/java/ch/njol/skript/expressions/ExprExplosionYield.java b/src/main/java/ch/njol/skript/expressions/ExprExplosionYield.java index eea0c5fdd0a..cb0227ec419 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprExplosionYield.java +++ b/src/main/java/ch/njol/skript/expressions/ExprExplosionYield.java @@ -40,7 +40,7 @@ @Name("Explosion Yield") @Description({"The yield of the explosion in an explosion prime event. This is how big the explosion is.", " When changing the yield, values less than 0 will be ignored.", - " Read this wiki page for more information"}) + " Read this wiki page for more information"}) @Examples({"on explosion prime:", "\tset the yield of the explosion to 10"}) @Events("explosion prime") diff --git a/src/main/java/ch/njol/skript/expressions/ExprExplosiveYield.java b/src/main/java/ch/njol/skript/expressions/ExprExplosiveYield.java index b66b2f4e60d..3fa35bc76c7 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprExplosiveYield.java +++ b/src/main/java/ch/njol/skript/expressions/ExprExplosiveYield.java @@ -36,7 +36,7 @@ @Name("Explosive Yield") @Description({"The yield of an explosive (creeper, primed tnt, fireball, etc.). This is how big of an explosion is caused by the entity.", - "Read this wiki page for more information"}) + "Read this wiki page for more information"}) @Examples({"on spawn of a creeper:", "\tset the explosive yield of the event-entity to 10"}) @RequiredPlugins("Minecraft 1.12 or newer for creepers") diff --git a/src/main/java/ch/njol/skript/expressions/ExprGlidingState.java b/src/main/java/ch/njol/skript/expressions/ExprGlidingState.java index 6334e1af835..901ff127079 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprGlidingState.java +++ b/src/main/java/ch/njol/skript/expressions/ExprGlidingState.java @@ -31,7 +31,7 @@ import ch.njol.skript.expressions.base.SimplePropertyExpression; @Name("Gliding State") -@Description("Sets of gets gliding state of player. It allows you to set gliding state of entity even if they do not have an Elytra equipped.") +@Description("Sets of gets gliding state of player. It allows you to set gliding state of entity even if they do not have an Elytra equipped.") @Examples({"set gliding of player to off"}) @Since("2.2-dev21") public class ExprGlidingState extends SimplePropertyExpression { diff --git a/src/main/java/ch/njol/skript/expressions/ExprScoreboardTags.java b/src/main/java/ch/njol/skript/expressions/ExprScoreboardTags.java index 14da4e073ca..47f4f4e5712 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprScoreboardTags.java +++ b/src/main/java/ch/njol/skript/expressions/ExprScoreboardTags.java @@ -41,7 +41,7 @@ @Name("Scoreboard Tags") @Description({"Scoreboard tags are simple list of texts stored directly in the data of an entity.", "So this is a Minecraft related thing, not Bukkit, so the tags will not get removed when the server stops. " + - "You can visit visit Minecraft Wiki for more info.", + "You can visit visit Minecraft Wiki for more info.", "This is changeable and valid for any type of entity. " + "Also you can use use the Has Scoreboard Tag condition to check whether an entity has the given tags.", "", From 1789a95925a5291166b8a645544d74fd655ba127 Mon Sep 17 00:00:00 2001 From: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> Date: Tue, 3 Oct 2023 10:10:26 +0300 Subject: [PATCH 038/176] =?UTF-8?q?=E2=9A=92=20Fix=20fake=20player=20count?= =?UTF-8?q?=20paper=20check=20error=20(#6090)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../expressions/ExprOnlinePlayersCount.java | 38 ++++++++++--------- 1 file changed, 20 insertions(+), 18 deletions(-) diff --git a/src/main/java/ch/njol/skript/expressions/ExprOnlinePlayersCount.java b/src/main/java/ch/njol/skript/expressions/ExprOnlinePlayersCount.java index ad4a6055125..5fd03a7e9d8 100644 --- a/src/main/java/ch/njol/skript/expressions/ExprOnlinePlayersCount.java +++ b/src/main/java/ch/njol/skript/expressions/ExprOnlinePlayersCount.java @@ -18,18 +18,12 @@ */ package ch.njol.skript.expressions; -import org.bukkit.Bukkit; -import org.bukkit.event.Event; -import org.bukkit.event.server.ServerListPingEvent; -import org.eclipse.jdt.annotation.Nullable; - -import com.destroystokyo.paper.event.server.PaperServerListPingEvent; import ch.njol.skript.Skript; -import ch.njol.skript.bukkitutil.PlayerUtils; import ch.njol.skript.classes.Changer.ChangeMode; import ch.njol.skript.doc.Description; import ch.njol.skript.doc.Examples; import ch.njol.skript.doc.Name; +import ch.njol.skript.doc.RequiredPlugins; import ch.njol.skript.doc.Since; import ch.njol.skript.lang.Expression; import ch.njol.skript.lang.ExpressionType; @@ -37,23 +31,31 @@ import ch.njol.skript.lang.util.SimpleExpression; import ch.njol.util.Kleenean; import ch.njol.util.coll.CollectionUtils; +import com.destroystokyo.paper.event.server.PaperServerListPingEvent; +import org.bukkit.Bukkit; +import org.bukkit.event.Event; +import org.bukkit.event.server.ServerListPingEvent; +import org.eclipse.jdt.annotation.Nullable; @Name("Online Player Count") -@Description({"The amount of online players. This can be changed in a", +@Description({ + "The amount of online players. This can be changed in a " + "server list ping event only to show fake online player amount.", - "'real online player count' always returns the real count of online players and can't be changed.", - "", - "Fake online player count requires PaperSpigot 1.12.2+."}) -@Examples({"on server list ping:", - " # This will make the max players count 5 if there are 4 players online.", - " set the fake max players count to (online players count + 1)"}) + "real online player count always return the real count of online players and can't be changed." +}) +@Examples({ + "on server list ping:", + "\t# This will make the max players count 5 if there are 4 players online.", + "\tset the fake max players count to (online player count + 1)" +}) +@RequiredPlugins("Paper (fake count)") @Since("2.3") public class ExprOnlinePlayersCount extends SimpleExpression { static { Skript.registerExpression(ExprOnlinePlayersCount.class, Long.class, ExpressionType.PROPERTY, - "[the] [(1¦(real|default)|2¦(fake|shown|displayed))] [online] player (count|amount|number)", - "[the] [(1¦(real|default)|2¦(fake|shown|displayed))] (count|amount|number|size) of online players"); + "[the] [(1:(real|default)|2:(fake|shown|displayed))] [online] player (count|amount|number)", + "[the] [(1:(real|default)|2:(fake|shown|displayed))] (count|amount|number|size) of online players"); } private static final boolean PAPER_EVENT_EXISTS = Skript.classExists("com.destroystokyo.paper.event.server.PaperServerListPingEvent"); @@ -64,7 +66,7 @@ public class ExprOnlinePlayersCount extends SimpleExpression { public boolean init(Expression[] exprs, int matchedPattern, Kleenean isDelayed, ParseResult parseResult) { boolean isPaperEvent = PAPER_EVENT_EXISTS && getParser().isCurrentEvent(PaperServerListPingEvent.class); if (parseResult.mark == 2) { - if (getParser().isCurrentEvent(ServerListPingEvent.class)) { + if (!PAPER_EVENT_EXISTS && getParser().isCurrentEvent(ServerListPingEvent.class)) { Skript.error("The 'fake' online players count expression requires Paper 1.12.2 or newer"); return false; } else if (!isPaperEvent) { @@ -146,4 +148,4 @@ public String toString(@Nullable Event e, boolean debug) { return "the count of " + (isReal ? "real max players" : "max players"); } -} \ No newline at end of file +} From b774cafc88dac177df042fea550813c4f0a56a62 Mon Sep 17 00:00:00 2001 From: _tud Date: Tue, 3 Oct 2023 11:42:47 +0300 Subject: [PATCH 039/176] Fix Command Help (#6080) Fix issues and cleanup CommandHelp class Co-authored-by: Moderocky --- .../ch/njol/skript/command/CommandHelp.java | 152 +++++++++--------- 1 file changed, 77 insertions(+), 75 deletions(-) diff --git a/src/main/java/ch/njol/skript/command/CommandHelp.java b/src/main/java/ch/njol/skript/command/CommandHelp.java index 8fcf6f0a3b4..4732ba2cde5 100644 --- a/src/main/java/ch/njol/skript/command/CommandHelp.java +++ b/src/main/java/ch/njol/skript/command/CommandHelp.java @@ -23,6 +23,7 @@ import java.util.LinkedHashMap; import java.util.Locale; +import java.util.Map; import java.util.Map.Entry; import org.bukkit.command.CommandSender; @@ -33,118 +34,119 @@ import ch.njol.skript.localization.Message; import ch.njol.skript.util.SkriptColor; -/** - * @author Peter Güttinger - */ public class CommandHelp { - + private final static String DEFAULTENTRY = "description"; - + private final static ArgsMessage m_invalid_argument = new ArgsMessage("commands.invalid argument"); private final static Message m_usage = new Message("skript command.usage"); - + + private final String actualCommand, actualNode, argsColor; private String command; + private String langNode; @Nullable - private Message description = null; - private final String argsColor; - - @Nullable - private String langNode = null; - - private final LinkedHashMap arguments = new LinkedHashMap<>(); - + private Message description; + + private final Map arguments = new LinkedHashMap<>(); + @Nullable - private Message wildcardArg = null; - - public CommandHelp(final String command, final SkriptColor argsColor, final String langNode) { - this.command = command; - this.argsColor = "" + argsColor.getFormattedChat(); - this.langNode = langNode; - description = new Message(langNode + "." + DEFAULTENTRY); + private ArgumentHolder wildcardArg = null; + + public CommandHelp(String command, SkriptColor argsColor, String langNode) { + this(command, argsColor.getFormattedChat(), langNode, new Message(langNode + "." + DEFAULTENTRY)); } - - public CommandHelp(final String command, final SkriptColor argsColor) { - this.command = command; - this.argsColor = "" + argsColor.getFormattedChat(); + + public CommandHelp(String command, SkriptColor argsColor) { + this(command, argsColor.getFormattedChat(), command, null); } - - public CommandHelp add(final String argument) { - if (langNode == null) { - if (argument.startsWith("<") && argument.endsWith(">")) { - final String carg = GRAY + "<" + argsColor + argument.substring(1, argument.length() - 1) + GRAY + ">"; - arguments.put(carg, argument); - } else { - arguments.put(argument, null); - } - } else { - if (argument.startsWith("<") && argument.endsWith(">")) { - final String carg = GRAY + "<" + argsColor + argument.substring(1, argument.length() - 1) + GRAY + ">"; - wildcardArg = new Message(langNode + "." + argument); - arguments.put(carg, wildcardArg); - } else { - arguments.put(argument, new Message(langNode + "." + argument)); - } + + private CommandHelp(String command, String argsColor, String node, @Nullable Message description) { + this.actualCommand = this.command = command; + this.actualNode = this.langNode = node; + this.argsColor = argsColor; + this.description = description; + } + + public CommandHelp add(String argument) { + ArgumentHolder holder = new ArgumentHolder(argument); + if (argument.startsWith("<") && argument.endsWith(">")) { + argument = GRAY + "<" + argsColor + argument.substring(1, argument.length() - 1) + GRAY + ">"; + wildcardArg = holder; } + arguments.put(argument, holder); return this; } - - public CommandHelp add(final CommandHelp help) { + + public CommandHelp add(CommandHelp help) { arguments.put(help.command, help); help.onAdd(this); return this; } - - protected void onAdd(final CommandHelp parent) { - langNode = parent.langNode + "." + command; + + protected void onAdd(CommandHelp parent) { + langNode = parent.langNode + "." + actualNode; description = new Message(langNode + "." + DEFAULTENTRY); - command = parent.command + " " + parent.argsColor + command; - for (final Entry e : arguments.entrySet()) { - if (e.getValue() instanceof CommandHelp) { - ((CommandHelp) e.getValue()).onAdd(this); - } else { - if (e.getValue() != null) { // wildcard arg - wildcardArg = new Message(langNode + "." + e.getValue()); - e.setValue(wildcardArg); - } else { - e.setValue(new Message(langNode + "." + e.getKey())); - } + command = parent.command + " " + parent.argsColor + actualCommand; + for (Entry entry : arguments.entrySet()) { + if (entry.getValue() instanceof CommandHelp) { + ((CommandHelp) entry.getValue()).onAdd(this); + continue; } + ((ArgumentHolder) entry.getValue()).update(); } } - - public boolean test(final CommandSender sender, final String[] args) { + + public boolean test(CommandSender sender, String[] args) { return test(sender, args, 0); } - - private boolean test(final CommandSender sender, final String[] args, final int index) { + + private boolean test(CommandSender sender, String[] args, int index) { if (index >= args.length) { showHelp(sender); return false; } - final Object help = arguments.get(args[index].toLowerCase(Locale.ENGLISH)); + Object help = arguments.get(args[index].toLowerCase(Locale.ENGLISH)); if (help == null && wildcardArg == null) { showHelp(sender, m_invalid_argument.toString(argsColor + args[index])); return false; } - if (help instanceof CommandHelp) - return ((CommandHelp) help).test(sender, args, index + 1); - return true; + return !(help instanceof CommandHelp) || ((CommandHelp) help).test(sender, args, index + 1); } - - public void showHelp(final CommandSender sender) { + + public void showHelp(CommandSender sender) { showHelp(sender, m_usage.toString()); } - - private void showHelp(final CommandSender sender, final String pre) { + + private void showHelp(CommandSender sender, String pre) { Skript.message(sender, pre + " " + command + " " + argsColor + "..."); - for (final Entry e : arguments.entrySet()) { - Skript.message(sender, " " + argsColor + e.getKey() + " " + GRAY + "-" + RESET + " " + e.getValue()); - } + for (Entry entry : arguments.entrySet()) + Skript.message(sender, " " + argsColor + entry.getKey() + " " + GRAY + "-" + RESET + " " + entry.getValue()); } - + @Override public String toString() { return "" + description; } - + + private class ArgumentHolder { + + private final String argument; + private Message description; + + private ArgumentHolder(String argument) { + this.argument = argument; + this.description = new Message(langNode + "." + argument); + } + + private void update() { + description = new Message(langNode + "." + argument); + } + + @Override + public String toString() { + return description.toString(); + } + + } + } From 71b05eb4588bcec387074edf14e19476e25648bc Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Thu, 5 Oct 2023 17:18:58 -0600 Subject: [PATCH 040/176] Bump net.kyori:adventure-text-serializer-bungeecord from 4.3.0 to 4.3.1 (#6084) Bumps [net.kyori:adventure-text-serializer-bungeecord](https://github.com/KyoriPowered/adventure-platform) from 4.3.0 to 4.3.1. - [Release notes](https://github.com/KyoriPowered/adventure-platform/releases) - [Commits](https://github.com/KyoriPowered/adventure-platform/compare/v4.3.0...v4.3.1) --- updated-dependencies: - dependency-name: net.kyori:adventure-text-serializer-bungeecord dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Ayham Al Ali <20037329+AyhamAl-Ali@users.noreply.github.com> --- build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index 7ce7614c3b0..761244001d9 100644 --- a/build.gradle +++ b/build.gradle @@ -27,7 +27,7 @@ allprojects { dependencies { shadow group: 'io.papermc', name: 'paperlib', version: '1.0.8' shadow group: 'org.bstats', name: 'bstats-bukkit', version: '3.0.2' - shadow group: 'net.kyori', name: 'adventure-text-serializer-bungeecord', version: '4.3.0' + shadow group: 'net.kyori', name: 'adventure-text-serializer-bungeecord', version: '4.3.1' implementation group: 'io.papermc.paper', name: 'paper-api', version: '1.20.2-R0.1-SNAPSHOT' implementation group: 'org.eclipse.jdt', name: 'org.eclipse.jdt.annotation', version: '2.2.700' From 83a41f6cd5a8b7d788efe93826639e86af57dec7 Mon Sep 17 00:00:00 2001 From: LimeGlass <16087552+TheLimeGlass@users.noreply.github.com> Date: Fri, 6 Oct 2023 23:14:40 -0600 Subject: [PATCH 041/176] Add WILL to property condition (#5955) --- .../conditions/base/PropertyCondition.java | 86 +++++++++++-------- 1 file changed, 49 insertions(+), 37 deletions(-) diff --git a/src/main/java/ch/njol/skript/conditions/base/PropertyCondition.java b/src/main/java/ch/njol/skript/conditions/base/PropertyCondition.java index 7a99c659d5d..8e73bf83d56 100644 --- a/src/main/java/ch/njol/skript/conditions/base/PropertyCondition.java +++ b/src/main/java/ch/njol/skript/conditions/base/PropertyCondition.java @@ -53,7 +53,7 @@ * the first one needs to be a non-negated one and a negated one. */ public abstract class PropertyCondition extends Condition implements Checker { - + /** * See {@link PropertyCondition} for more info */ @@ -74,100 +74,112 @@ public enum PropertyType { * Indicates that the condition is in a form of something has/have something, * also possibly in the negated form */ - HAVE + HAVE, + + /** + * Indicates that the condition is in a form of something will/be something, + * also possibly in the negated form + */ + WILL } - - @SuppressWarnings("null") + private Expression expr; - + /** - * @param c the class to register + * @param condition the class to register * @param property the property name, for example fly in players can fly * @param type must be plural, for example players in players can fly */ - public static void register(final Class c, final String property, final String type) { - register(c, PropertyType.BE, property, type); + public static void register(Class condition, String property, String type) { + register(condition, PropertyType.BE, property, type); } - + /** - * @param c the class to register + * @param condition the class to register * @param propertyType the property type, see {@link PropertyType} * @param property the property name, for example fly in players can fly * @param type must be plural, for example players in players can fly */ - public static void register(final Class c, final PropertyType propertyType, final String property, final String type) { - if (type.contains("%")) { + public static void register(Class condition, PropertyType propertyType, String property, String type) { + if (type.contains("%")) throw new SkriptAPIException("The type argument must not contain any '%'s"); - } + switch (propertyType) { case BE: - Skript.registerCondition(c, + Skript.registerCondition(condition, "%" + type + "% (is|are) " + property, "%" + type + "% (isn't|is not|aren't|are not) " + property); break; case CAN: - Skript.registerCondition(c, + Skript.registerCondition(condition, "%" + type + "% can " + property, "%" + type + "% (can't|cannot|can not) " + property); break; case HAVE: - Skript.registerCondition(c, + Skript.registerCondition(condition, "%" + type + "% (has|have) " + property, "%" + type + "% (doesn't|does not|do not|don't) have " + property); break; + case WILL: + Skript.registerCondition(condition, + "%" + type + "% will " + property, + "%" + type + "% (will (not|neither)|won't) " + property); + break; default: assert false; } } - - @SuppressWarnings({"unchecked", "null"}) + @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) { expr = (Expression) exprs[0]; setNegated(matchedPattern == 1); return true; } - + @Override - public final boolean check(final Event e) { - return expr.check(e, this, isNegated()); + public final boolean check(Event event) { + return expr.check(event, this, isNegated()); } - + @Override public abstract boolean check(T t); - + protected abstract String getPropertyName(); - + protected PropertyType getPropertyType() { return PropertyType.BE; } - + /** * Sets the expression this condition checks a property of. No reference to the expression should be kept. * - * @param expr + * @param expr The expression property of this property condition. */ - protected final void setExpr(final Expression expr) { + protected final void setExpr(Expression expr) { this.expr = expr; } - + @Override - public String toString(final @Nullable Event e, final boolean debug) { - return toString(this, getPropertyType(), e, debug, expr, getPropertyName()); + public String toString(@Nullable Event event, boolean debug) { + return toString(this, getPropertyType(), event, debug, expr, getPropertyName()); } - - public static String toString(Condition condition, PropertyType propertyType, @Nullable Event e, + + public static String toString(Condition condition, PropertyType propertyType, @Nullable Event event, boolean debug, Expression expr, String property) { switch (propertyType) { case BE: - return expr.toString(e, debug) + (expr.isSingle() ? " is " : " are ") + (condition.isNegated() ? "not " : "") + property; + return expr.toString(event, debug) + (expr.isSingle() ? " is " : " are ") + (condition.isNegated() ? "not " : "") + property; case CAN: - return expr.toString(e, debug) + (condition.isNegated() ? " can't " : " can ") + property; + return expr.toString(event, debug) + (condition.isNegated() ? " can't " : " can ") + property; case HAVE: if (expr.isSingle()) - return expr.toString(e, debug) + (condition.isNegated() ? " doesn't have " : " has ") + property; + return expr.toString(event, debug) + (condition.isNegated() ? " doesn't have " : " has ") + property; else - return expr.toString(e, debug) + (condition.isNegated() ? " don't have " : " have ") + property; + return expr.toString(event, debug) + (condition.isNegated() ? " don't have " : " have ") + property; + case WILL: + return expr.toString(event, debug) + (condition.isNegated() ? " won't " : " will ") + "be " + property; default: assert false; throw new AssertionError(); From da97d3eebd7eea94cdbf3f781b8196d54d5d4dc1 Mon Sep 17 00:00:00 2001 From: Moderocky Date: Sun, 8 Oct 2023 11:09:38 +0100 Subject: [PATCH 042/176] Fix unloading/reloading a directory in the scripts effect (#6106) * Moved unloading to a common method. * Accidental double space :grimacing: --- .../ch/njol/skript/effects/EffScriptFile.java | 24 +++++++++++++------ 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/src/main/java/ch/njol/skript/effects/EffScriptFile.java b/src/main/java/ch/njol/skript/effects/EffScriptFile.java index 0a38111c5ce..ed15f625d2f 100644 --- a/src/main/java/ch/njol/skript/effects/EffScriptFile.java +++ b/src/main/java/ch/njol/skript/effects/EffScriptFile.java @@ -37,6 +37,7 @@ import java.io.File; import java.io.IOException; +import java.util.Set; @Name("Enable/Disable/Reload Script File") @Description("Enables, disables, or reloads a script file.") @@ -102,10 +103,8 @@ protected void execute(Event e) { case RELOAD: { if (ScriptLoader.getDisabledScriptsFilter().accept(scriptFile)) return; - - Script script = ScriptLoader.getScript(scriptFile); - if (script != null) - ScriptLoader.unloadScript(script); + + this.unloadScripts(scriptFile); ScriptLoader.loadScripts(scriptFile, OpenCloseable.EMPTY); break; @@ -114,9 +113,7 @@ protected void execute(Event e) { if (ScriptLoader.getDisabledScriptsFilter().accept(scriptFile)) return; - Script script = ScriptLoader.getScript(scriptFile); - if (script != null) - ScriptLoader.unloadScript(script); + this.unloadScripts(scriptFile); try { FileUtils.move( @@ -135,6 +132,19 @@ protected void execute(Event e) { assert false; } } + + private void unloadScripts(File file) { + if (file.isDirectory()) { + Set