From 07538396992cf53035f9e5f6a9b646ec15fcb967 Mon Sep 17 00:00:00 2001 From: Sekwah Date: Wed, 29 Nov 2023 03:18:25 +0000 Subject: [PATCH] feat: add the ability to have multiple values for a tag --- README.md | 5 +- .../portal/CreatePortalSubCommand.java | 10 +++- .../core/destination/Destination.java | 40 ++++++++----- .../core/portal/AdvancedPortal.java | 43 ++++++++------ .../core/registry/TagRegistry.java | 58 +++++++------------ .../core/registry/TagTarget.java | 34 +++++++++++ .../core/serializeddata/DataTag.java | 11 +++- .../core/services/DestinationServices.java | 2 +- .../core/tags/activation/DestiTag.java | 31 ++++++++++ .../advancedportals/core/util/TagReader.java | 29 +++++++++- .../warphandler/{TagHandler.java => Tag.java} | 57 +++++++++++------- 11 files changed, 220 insertions(+), 100 deletions(-) create mode 100644 core/src/main/java/com/sekwah/advancedportals/core/registry/TagTarget.java create mode 100644 core/src/main/java/com/sekwah/advancedportals/core/tags/activation/DestiTag.java rename core/src/main/java/com/sekwah/advancedportals/core/warphandler/{TagHandler.java => Tag.java} (61%) diff --git a/README.md b/README.md index 699bbd6c..a9f8044f 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,10 @@ Also I will set up release please to work with the below types for pretty change The re-code is based off a mix of the original version, and the original re-code that was abandoned [see here](https://github.com/sekwah41/Advanced-Portals/tree/recode/src/main/java/com/sekwah/advancedportals). -There were no issues with this approach, though for a number of reasons outside of the codebase progress was not made fast enough. +Part of this are currently a mess in terms of package organising, though any API changes will be documented in the changelog as well as the main registry classes should be relatively solid. + +The goal of this rewrite is to make it easier to port to other platforms as well as add extra tags. + # Contributing Please ensure that your commits are in the following style for PR's diff --git a/core/src/main/java/com/sekwah/advancedportals/core/commands/subcommands/portal/CreatePortalSubCommand.java b/core/src/main/java/com/sekwah/advancedportals/core/commands/subcommands/portal/CreatePortalSubCommand.java index 1737b1af..a1883ebb 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/commands/subcommands/portal/CreatePortalSubCommand.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/commands/subcommands/portal/CreatePortalSubCommand.java @@ -36,7 +36,14 @@ public void onCommand(CommandSenderContainer sender, String[] args) { sender.sendMessage(Lang.translate("command.create.tags")); sender.sendMessage("\u00A7a" + "triggerBlock\u00A77:\u00A7e" + Arrays.toString(portal.getTriggerBlocks())); for (DataTag tag: portal.getArgs()) { - sender.sendMessage("\u00A7a" + tag.NAME + "\u00A77:\u00A7e" + tag.VALUE); + if(tag.VALUES.length == 1) { + sender.sendMessage("\u00A7a" + tag.NAME + "\u00A77:\u00A7e" + tag.VALUES[0]); + } else { + // Output in the format tag.NAME(index): value + for (int i = 0; i < tag.VALUES.length; i++) { + sender.sendMessage("\u00A7a" + tag.NAME + "(" + i + ")\u00A77:\u00A7e" + tag.VALUES[i]); + } + } } } sender.sendMessage(Lang.translate("messageprefix.negative") + Lang.translate("command.create.error")); @@ -53,6 +60,7 @@ public boolean hasPermission(CommandSenderContainer sender) { @Override public List onTabComplete(CommandSenderContainer sender, String[] args) { + // TODO add tab complete for tags return null; } diff --git a/core/src/main/java/com/sekwah/advancedportals/core/destination/Destination.java b/core/src/main/java/com/sekwah/advancedportals/core/destination/Destination.java index 0ec1ee86..8b56fe6e 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/destination/Destination.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/destination/Destination.java @@ -3,11 +3,12 @@ import com.google.gson.annotations.SerializedName; import com.google.inject.Inject; import com.sekwah.advancedportals.core.connector.containers.PlayerContainer; +import com.sekwah.advancedportals.core.registry.TagTarget; import com.sekwah.advancedportals.core.serializeddata.DataTag; import com.sekwah.advancedportals.core.serializeddata.PlayerLocation; import com.sekwah.advancedportals.core.registry.TagRegistry; import com.sekwah.advancedportals.core.warphandler.ActivationData; -import com.sekwah.advancedportals.core.warphandler.TagHandler; +import com.sekwah.advancedportals.core.warphandler.Tag; import java.util.ArrayList; import java.util.HashMap; @@ -23,7 +24,7 @@ * * @author sekwah41 */ -public class Destination { +public class Destination implements TagTarget { @Inject TagRegistry tagRegistry; @@ -32,7 +33,7 @@ public class Destination { private PlayerLocation loc; @SerializedName("a") - private HashMap args = new HashMap<>(); + private HashMap args = new HashMap<>(); private transient Set argsCol; @@ -40,16 +41,23 @@ public Destination(PlayerLocation loc) { this.loc = loc; } - public String getArg(String argName) { + @Override + public String[] getArgValues(String argName) { return this.args.get(argName); } - public void setArg(String argName, String argValue) { + @Override + public void setArgValues(String argName, String[] argValue) { this.args.put(argName, argValue); } - public void setArg(DataTag portalTag) { - this.setArg(portalTag.NAME, portalTag.VALUE); + @Override + public void addArg(String argName, String argValues) { + + } + + public void setArgValues(DataTag portalTag) { + this.setArgValues(portalTag.NAME, portalTag.VALUES); } public void removeArg(String arg) { @@ -66,19 +74,19 @@ public boolean activate(PlayerContainer player) { public boolean portalActivate(PlayerContainer player, ActivationData data) { DataTag[] destiTags = new DataTag[args.size()]; int i = 0; - for(Map.Entry entry : args.entrySet()) { + for(Map.Entry entry : args.entrySet()) { destiTags[i++] = new DataTag(entry.getKey(), entry.getValue()); } for(DataTag destiTag : destiTags) { - TagHandler.Activation activationHandler = tagRegistry.getActivationHandler(destiTag.NAME); + Tag.Activation activationHandler = tagRegistry.getActivationHandler(destiTag.NAME); if(activationHandler != null) { - activationHandler.preActivated(this, player, data, this.getArg(destiTag.NAME)); + activationHandler.preActivated(this, player, data, this.getArgValues(destiTag.NAME)); } } for(DataTag destiTag : destiTags) { - TagHandler.Activation activationHandler = tagRegistry.getActivationHandler(destiTag.NAME); + Tag.Activation activationHandler = tagRegistry.getActivationHandler(destiTag.NAME); if(activationHandler != null) { - activationHandler.activated(this, player, data, this.getArg(destiTag.NAME)); + activationHandler.activated(this, player, data, this.getArgValues(destiTag.NAME)); } } return true; @@ -87,20 +95,20 @@ public boolean portalActivate(PlayerContainer player, ActivationData data) { public void postActivate(PlayerContainer player, ActivationData data) { DataTag[] destiTags = new DataTag[args.size()]; int i = 0; - for(Map.Entry entry : args.entrySet()) { + for(Map.Entry entry : args.entrySet()) { destiTags[i++] = new DataTag(entry.getKey(), entry.getValue()); } for(DataTag destiTag : destiTags) { - TagHandler.Activation activationHandler = tagRegistry.getActivationHandler(destiTag.NAME); + Tag.Activation activationHandler = tagRegistry.getActivationHandler(destiTag.NAME); if(activationHandler != null) { - activationHandler.postActivated(this, player, data, this.getArg(destiTag.NAME)); + activationHandler.postActivated(this, player, data, this.getArgValues(destiTag.NAME)); } } } public ArrayList getArgs() { ArrayList tagList = new ArrayList<>(); - for(Map.Entry entry : this.args.entrySet()){ + for(Map.Entry entry : this.args.entrySet()){ tagList.add(new DataTag(entry.getKey(), entry.getValue())); } return tagList; diff --git a/core/src/main/java/com/sekwah/advancedportals/core/portal/AdvancedPortal.java b/core/src/main/java/com/sekwah/advancedportals/core/portal/AdvancedPortal.java index 47f93c8f..359ac163 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/portal/AdvancedPortal.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/portal/AdvancedPortal.java @@ -3,11 +3,12 @@ import com.google.gson.annotations.SerializedName; import com.google.inject.Inject; import com.sekwah.advancedportals.core.connector.containers.PlayerContainer; +import com.sekwah.advancedportals.core.registry.TagTarget; import com.sekwah.advancedportals.core.serializeddata.DataTag; import com.sekwah.advancedportals.core.serializeddata.WorldLocation; import com.sekwah.advancedportals.core.registry.TagRegistry; import com.sekwah.advancedportals.core.warphandler.ActivationData; -import com.sekwah.advancedportals.core.warphandler.TagHandler; +import com.sekwah.advancedportals.core.warphandler.Tag; import java.util.ArrayList; import java.util.HashMap; @@ -16,10 +17,10 @@ /** * @author sekwah41 */ -public class AdvancedPortal { +public class AdvancedPortal implements TagTarget { @Inject - TagRegistry tagRegistry; + transient TagRegistry tagRegistry; @SerializedName("max") private WorldLocation maxLoc; @@ -31,7 +32,7 @@ public class AdvancedPortal { private String[] triggerBlocks = {"PORTAL"}; @SerializedName("a") - private HashMap args = new HashMap<>(); + private HashMap args = new HashMap<>(); public AdvancedPortal(WorldLocation maxLoc, WorldLocation minLoc) { this.maxLoc = maxLoc; @@ -46,14 +47,22 @@ public WorldLocation getMinLoc() { return this.minLoc; } - public String getArg(String argName) { + @Override + public String[] getArgValues(String argName) { return this.args.get(argName); } - public void setArg(String argName, String argValue) { - this.args.put(argName, argValue); + @Override + public void setArgValues(String argName, String[] argValues) { + this.args.put(argName, argValues); } + @Override + public void addArg(String argName, String argValues) { + + } + + @Override public void removeArg(String arg) { this.args.remove(arg); } @@ -71,38 +80,38 @@ public boolean activate(PlayerContainer player) { ActivationData data = new ActivationData(); DataTag[] portalTags = new DataTag[args.size()]; int i = 0; - for(Map.Entry entry : args.entrySet()) { + for(Map.Entry entry : args.entrySet()) { portalTags[i++] = new DataTag(entry.getKey(), entry.getValue()); } for(DataTag portalTag : portalTags) { - TagHandler.Activation activationHandler = tagRegistry.getActivationHandler(portalTag.NAME); + Tag.Activation activationHandler = tagRegistry.getActivationHandler(portalTag.NAME); if(activationHandler != null) { - activationHandler.preActivated(this, player, data, this.getArg(portalTag.NAME)); + activationHandler.preActivated(this, player, data, this.getArgValues(portalTag.NAME)); } } for(DataTag portalTag : portalTags) { - TagHandler.Activation activationHandler = tagRegistry.getActivationHandler(portalTag.NAME); + Tag.Activation activationHandler = tagRegistry.getActivationHandler(portalTag.NAME); if(activationHandler != null) { - activationHandler.activated(this, player, data, this.getArg(portalTag.NAME)); + activationHandler.activated(this, player, data, this.getArgValues(portalTag.NAME)); } } for(DataTag portalTag : portalTags) { - TagHandler.Activation activationHandler = tagRegistry.getActivationHandler(portalTag.NAME); + Tag.Activation activationHandler = tagRegistry.getActivationHandler(portalTag.NAME); if(activationHandler != null) { - activationHandler.postActivated(this, player, data, this.getArg(portalTag.NAME)); + activationHandler.postActivated(this, player, data, this.getArgValues(portalTag.NAME)); } } return true; } - public void setArg(DataTag portalTag) { - this.setArg(portalTag.NAME, portalTag.VALUE); + public void setArgValues(DataTag portalTag) { + this.setArgValues(portalTag.NAME, portalTag.VALUES); } public ArrayList getArgs() { ArrayList tagList = new ArrayList<>(); - for(Map.Entry entry : this.args.entrySet()){ + for(Map.Entry entry : this.args.entrySet()){ tagList.add(new DataTag(entry.getKey(), entry.getValue())); } return tagList; diff --git a/core/src/main/java/com/sekwah/advancedportals/core/registry/TagRegistry.java b/core/src/main/java/com/sekwah/advancedportals/core/registry/TagRegistry.java index 0cb8bf3b..f6612644 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/registry/TagRegistry.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/registry/TagRegistry.java @@ -2,7 +2,8 @@ import com.google.inject.Inject; import com.sekwah.advancedportals.core.AdvancedPortalsCore; -import com.sekwah.advancedportals.core.warphandler.TagHandler; +import com.sekwah.advancedportals.core.portal.AdvancedPortal; +import com.sekwah.advancedportals.core.warphandler.Tag; import java.util.ArrayList; import java.util.Collections; @@ -25,19 +26,21 @@ public class TagRegistry { */ private ArrayList tags = new ArrayList(); /** - * Description of tags for help commands + * Description of tags for help commands (will try to use translation strings before rendering + * Possibly add a way to allow addons to supply extra info to the Lang class in the future. */ private Map tagDesc = new HashMap(); - private Map> activationHandlers = new HashMap(); - private Map> creationHandlers = new HashMap(); - private Map> statusHandlers = new HashMap(); + private Map activationHandlers = new HashMap(); + private Map creationHandlers = new HashMap(); + private Map statusHandlers = new HashMap(); /** + * Portals to trigger when a portal is activated * * @param arg * @return */ - public TagHandler.Activation getActivationHandler(String arg) { + public Tag.Activation getActivationHandler(String arg) { return this.activationHandlers.get(arg); } @@ -46,7 +49,7 @@ public TagHandler.Activation getActivationHandler(String arg) { * @param arg * @return */ - public TagHandler.Creation getCreationHandler(String arg) { + public Tag.Creation getCreationHandler(String arg) { return this.creationHandlers.get(arg); } @@ -55,24 +58,10 @@ public TagHandler.Creation getCreationHandler(String arg) { * @param arg * @return */ - public TagHandler.TagStatus getTagStatusHandler(String arg) { + public Tag.TagStatus getTagStatusHandler(String arg) { return this.statusHandlers.get(arg); } - /** - * - * @param tag - * @param desc - * @param tagHandler - * @return if the tag was registered - */ - public boolean registerTag(String tag, String desc, TagHandler tagHandler) { - if (registerTag(tag, tagHandler)) { - this.tagDesc.put(tag, desc); - } - return false; - } - /** * It is reccomended that you use the taghandlers to add tag functionality. However @@ -81,7 +70,7 @@ public boolean registerTag(String tag, String desc, TagHandler tagHandler) { * @param tag * @return if the tag was registered */ - public boolean registerTag(String tag) { + private boolean registerTag(String tag) { if (tag.contains(" ")) { this.portalsCore.getInfoLogger().logWarning("The tag '" + tag + "' is invalid as it contains spaces."); @@ -97,14 +86,7 @@ public boolean registerTag(String tag) { return true; } - /** - * Same as registerTag(String tag) but allows a description to be added. - * - * @param tag Tag to be used on command line - * @param desc - * @return if the tag was registered - */ - public boolean registerTag(String tag, String desc) { + private boolean registerTag(String tag, String desc) { if (registerTag(tag)) { this.tagDesc.put(tag, desc); return true; @@ -130,7 +112,7 @@ public boolean isTagRegistered(String tag){ * File must extend * @return if the tag has been registered or if it already exists. */ - public boolean registerTag(String tag, Object tagHandler) { + public boolean registerTag(String tag, Tag tagHandler) { if (tag == null) { this.portalsCore.getInfoLogger().logWarning("A tag cannot be null."); @@ -141,14 +123,14 @@ public boolean registerTag(String tag, Object tagHandler) { return false; } - if (tagHandler instanceof TagHandler.Activation) { - this.activationHandlers.put(tag, (TagHandler.Activation) tagHandler); + if (tagHandler instanceof Tag.Activation tagActivation) { + this.activationHandlers.put(tag, tagActivation); } - if (tagHandler instanceof TagHandler.TagStatus) { - this.statusHandlers.put(tag, (TagHandler.TagStatus) tagHandler); + if (tagHandler instanceof Tag.TagStatus tagStatus) { + this.statusHandlers.put(tag, tagStatus); } - if (tagHandler instanceof TagHandler.Creation) { - this.creationHandlers.put(tag, (TagHandler.Creation) tagHandler); + if (tagHandler instanceof Tag.Creation tagCreation) { + this.creationHandlers.put(tag, tagCreation); } return true; } diff --git a/core/src/main/java/com/sekwah/advancedportals/core/registry/TagTarget.java b/core/src/main/java/com/sekwah/advancedportals/core/registry/TagTarget.java new file mode 100644 index 00000000..eeffa89b --- /dev/null +++ b/core/src/main/java/com/sekwah/advancedportals/core/registry/TagTarget.java @@ -0,0 +1,34 @@ +package com.sekwah.advancedportals.core.registry; + +/** + * Something that a tag can be executed on. + */ +public interface TagTarget { + + /** + * Get the values for the arg + * @param argName + * @return + */ + String[] getArgValues(String argName); + + /** + * Set the values for the arg + * @param argName + * @param argValues + */ + void setArgValues(String argName, String[] argValues); + + /** + * Add a new arg to the tag + * @param argName + * @param argValues + */ + void addArg(String argName, String argValues); + + /** + * Remove the arg entirely from the target + * @param arg + */ + void removeArg(String arg); +} diff --git a/core/src/main/java/com/sekwah/advancedportals/core/serializeddata/DataTag.java b/core/src/main/java/com/sekwah/advancedportals/core/serializeddata/DataTag.java index db1761fb..7e1e5b83 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/serializeddata/DataTag.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/serializeddata/DataTag.java @@ -3,11 +3,16 @@ public class DataTag { public final String NAME; - public final String VALUE; + public final String[] VALUES; - public DataTag(String argName, String value) { + public DataTag(String argName, String values) { this.NAME = argName; - this.VALUE = value; + this.VALUES = new String[]{values}; + } + + public DataTag(String argName, String[] values) { + this.NAME = argName; + this.VALUES = values; } } diff --git a/core/src/main/java/com/sekwah/advancedportals/core/services/DestinationServices.java b/core/src/main/java/com/sekwah/advancedportals/core/services/DestinationServices.java index 0948765d..a97b4fe4 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/services/DestinationServices.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/services/DestinationServices.java @@ -71,7 +71,7 @@ else if(this.destinationRepository.containsKey(name)) { Destination desti = new Destination(playerLocation); for(DataTag portalTag : tags) { - desti.setArg(portalTag); + desti.setArgValues(portalTag); } for(DataTag destiTag : tags) { // TODO sort tag handle registry diff --git a/core/src/main/java/com/sekwah/advancedportals/core/tags/activation/DestiTag.java b/core/src/main/java/com/sekwah/advancedportals/core/tags/activation/DestiTag.java new file mode 100644 index 00000000..f9d7265b --- /dev/null +++ b/core/src/main/java/com/sekwah/advancedportals/core/tags/activation/DestiTag.java @@ -0,0 +1,31 @@ +package com.sekwah.advancedportals.core.tags.activation; + +import com.sekwah.advancedportals.core.connector.containers.PlayerContainer; +import com.sekwah.advancedportals.core.registry.TagTarget; +import com.sekwah.advancedportals.core.warphandler.ActivationData; +import com.sekwah.advancedportals.core.warphandler.Tag; + +public class DestiTag implements Tag.Activation { + + private final TagType[] tagTypes = new TagType[]{ TagType.PORTAL }; + + @Override + public TagType[] getTagTypes() { + return tagTypes; + } + + @Override + public boolean preActivated(TagTarget target, PlayerContainer player, ActivationData activeData, String[] argData) { + return false; + } + + @Override + public void postActivated(TagTarget target, PlayerContainer player, ActivationData activeData, String[] argData) { + + } + + @Override + public boolean activated(TagTarget target, PlayerContainer player, ActivationData activeData, String[] argData) { + return false; + } +} diff --git a/core/src/main/java/com/sekwah/advancedportals/core/util/TagReader.java b/core/src/main/java/com/sekwah/advancedportals/core/util/TagReader.java index a39433b4..627e2331 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/util/TagReader.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/util/TagReader.java @@ -3,11 +3,12 @@ import com.sekwah.advancedportals.core.serializeddata.DataTag; import java.util.ArrayList; +import java.util.HashMap; public class TagReader { public static ArrayList getTagsFromArgs(String[] args) { - ArrayList tags = new ArrayList<>(); + HashMap> tagMap = new HashMap<>(); StringBuilder currentValue = new StringBuilder(); String currentIdentifier = null; boolean inQuotes = false; @@ -15,7 +16,15 @@ public static ArrayList getTagsFromArgs(String[] args) { for (String arg : args) { if (arg.contains(":") && !inQuotes) { if (currentIdentifier != null) { - tags.add(new DataTag(currentIdentifier, currentValue.toString())); + ArrayList tags; + if(tagMap.containsKey(currentIdentifier)) { + tags = tagMap.get(currentIdentifier); + } + else { + tags = new ArrayList<>(); + tagMap.put(currentIdentifier, tags); + } + tags.add(currentValue.toString()); } int colonIndex = arg.indexOf(':'); currentIdentifier = arg.substring(0, colonIndex); @@ -34,7 +43,21 @@ public static ArrayList getTagsFromArgs(String[] args) { } if (currentIdentifier != null) { - tags.add(new DataTag(currentIdentifier, currentValue.toString().replace("\"", ""))); + ArrayList tags; + if(tagMap.containsKey(currentIdentifier)) { + tags = tagMap.get(currentIdentifier); + } + else { + tags = new ArrayList<>(); + tagMap.put(currentIdentifier, tags); + } + tags.add(currentValue.toString().replace("\"", "")); + } + + // Loop over values in the map and create the tags + ArrayList tags = new ArrayList<>(); + for (String key : tagMap.keySet()) { + tags.add(new DataTag(key, tagMap.get(key).toArray(new String[0]))); } return tags; diff --git a/core/src/main/java/com/sekwah/advancedportals/core/warphandler/TagHandler.java b/core/src/main/java/com/sekwah/advancedportals/core/warphandler/Tag.java similarity index 61% rename from core/src/main/java/com/sekwah/advancedportals/core/warphandler/TagHandler.java rename to core/src/main/java/com/sekwah/advancedportals/core/warphandler/Tag.java index a8997224..8b4dd19d 100644 --- a/core/src/main/java/com/sekwah/advancedportals/core/warphandler/TagHandler.java +++ b/core/src/main/java/com/sekwah/advancedportals/core/warphandler/Tag.java @@ -1,25 +1,37 @@ package com.sekwah.advancedportals.core.warphandler; import com.sekwah.advancedportals.core.connector.containers.PlayerContainer; +import com.sekwah.advancedportals.core.registry.TagTarget; /** - * If a tag can be used for any of them then either make it cast the target or if it doesnt need a target + * If a tag can be used for any of them then either make it cast the target or if it doesn't need a target * then the exact same tag can be registered into both and ignore the portal info. * * Will probably make better documentation on how to do so or some tutorial videos though take a look at the source code - * on github for how the current tags are added. + * on GitHub for how the current tags are added. * - * Also not sure if its good practice or not in java however these all extend TagHandler so they can be accepted in 1 + * Also, not sure if its good practice or not in java however these all extend TagHandler, so they can be accepted in 1 * method nicer than if they didn't * * @author sekwah41 */ -public interface TagHandler { +public interface Tag { + + enum TagType { + PORTAL, + DESTINATION + } + + /** + * Used to flag where the auto complete should show more or less info. + * @return + */ + TagType[] getTagTypes(); /** * The events for portal creation and destroying */ - interface Creation extends TagHandler { + interface Creation extends Tag { /** * Example if the player does not have access to use the tag. @@ -27,7 +39,7 @@ interface Creation extends TagHandler { * @param player if null then created by the server or a plugin * @param argData */ - void created(T target, PlayerContainer player, String argData); + void created(TagTarget target, PlayerContainer player, String[] argData); /** * Example if the player does not have access to remove the portal or destination. @@ -35,7 +47,7 @@ interface Creation extends TagHandler { * @param player if null then removed by the server or a plugin * @param argData */ - void destroyed(T target, PlayerContainer player, String argData); + void destroyed(TagTarget target, PlayerContainer player, String[] argData); } @@ -53,10 +65,8 @@ interface Creation extends TagHandler { * - Desti.activate * Portal.postActivate - when desti tag is hit (if listed) then the next action is activated * - Desti.postActivate - * - * @param */ - interface Activation extends TagHandler { + interface Activation extends Tag { /** * Activates before the main part of activation. This should be for prechecks e.g. if the player has enough @@ -68,7 +78,7 @@ interface Activation extends TagHandler { * * @return If the tag has allowed the warp */ - boolean preActivated(T target, PlayerContainer player, ActivationData activeData, String argData); + boolean preActivated(TagTarget target, PlayerContainer player, ActivationData activeData, String[] argData); /** * Activates after activation, should be used for actions such as removing money for a teleport. @@ -79,7 +89,7 @@ interface Activation extends TagHandler { * @param activeData * @param argData */ - void postActivated(T target, PlayerContainer player, ActivationData activeData, String argData); + void postActivated(TagTarget target, PlayerContainer player, ActivationData activeData, String[] argData); /** * Activates if the portal is allowed from preActivating. Should be used to set the intended warp location @@ -95,29 +105,36 @@ interface Activation extends TagHandler { * * @return If the tag has allowed the warp */ - boolean activated(T target, PlayerContainer player, ActivationData activeData, String argData); + boolean activated(TagTarget target, PlayerContainer player, ActivationData activeData, String[] argData); } - interface TagStatus extends TagHandler { + /** + * Triggers when a tag is added or removed from a portal or destination + */ + interface TagStatus extends Tag { /** * If the user has access to add the tag (this does not include being added on creation) * - * @param player - * @param argData + * @param target the target of the tag + * @param player if null then removed by the server or a plugin + * @param argData the data for the tag + * @param index the index of the tag in the list (if it is the only tag it will be 0) * @return if the tag will be added. */ - boolean tagAdded(T target, PlayerContainer player, String argData); + boolean tagAdded(TagTarget target, PlayerContainer player, int index, String argData); /** * If the user has access to remove the tag (this does not include being added on destruction) * - * @param player - * @param argData + * @param target the target of the tag + * @param player if null then removed by the server or a plugin + * @param argData the data of the tag to be removed + * @param index the index of the tag in the list (if it is the only tag it will be 0) * @return if the tag will be removed. */ - boolean tagRemoved(T target, PlayerContainer player, String argData); + boolean tagRemoved(TagTarget target, PlayerContainer player, int index, String argData); }