aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/Danker/commands/warp
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/me/Danker/commands/warp')
-rw-r--r--src/main/java/me/Danker/commands/warp/WarpCommand.java79
-rw-r--r--src/main/java/me/Danker/commands/warp/WarpCommandHandler.java94
2 files changed, 173 insertions, 0 deletions
diff --git a/src/main/java/me/Danker/commands/warp/WarpCommand.java b/src/main/java/me/Danker/commands/warp/WarpCommand.java
new file mode 100644
index 0000000..730e7cd
--- /dev/null
+++ b/src/main/java/me/Danker/commands/warp/WarpCommand.java
@@ -0,0 +1,79 @@
+package me.Danker.commands.warp;
+
+import me.Danker.utils.Utils;
+import net.minecraft.client.Minecraft;
+import net.minecraft.command.CommandBase;
+import net.minecraft.command.CommandException;
+import net.minecraft.command.ICommandSender;
+
+public class WarpCommand extends CommandBase {
+
+
+ private boolean custom_command = false;
+ public String name;
+ public String destination;
+
+ /**
+ * A Command blueprint extending CommandBase that uses the name and sends the destination as "/warp {@link #destination}"
+ * @param name the name that the command is called as
+ * @param destination the location name that is sent
+ */
+ public WarpCommand(String name, String destination) {
+ this.name = name;
+ this.destination = destination;
+ }
+
+ /**
+ * A Command blueprint extending CommandBase that uses the name and sends the destination as "/warp {@link #destination}"
+ * @param name the name that the command is called as
+ * @param destination the location name that is sent
+ * @param custom_command is the custom command should use the /warp format or send a custom command.
+ * Adds the "/" to the destination.
+ */
+ public WarpCommand(String name, String destination, boolean custom_command) {
+ this.name = name;
+ this.destination = destination;
+ this.custom_command = custom_command;
+ }
+
+ /**
+ * Returns the commands name that is set in the constructor
+ */
+ @Override
+ public String getCommandName() {
+ return name;
+ }
+
+ /**
+ * Returns the command usage for the builtin help
+ * @param sender the command sender
+ * @return "/" + the command name
+ */
+ @Override
+ public String getCommandUsage(ICommandSender sender) {
+ return "/" + getCommandName();
+ }
+
+ @Override
+ public int getRequiredPermissionLevel() {
+ return 0;
+ }
+
+ /**
+ * The logic that is called when the command is executed
+ * Sends a message as the player containing "/warp {@link #destination}"
+ * @param sender the command sender
+ * @param args what is written after the command
+ */
+ @Override
+ public void processCommand(ICommandSender sender, String[] args) throws CommandException {
+ if (!Utils.inSkyblock) return;
+ if (custom_command) {
+ Minecraft.getMinecraft().thePlayer.sendChatMessage("/" + this.destination);
+ return;
+ }
+ Minecraft.getMinecraft().thePlayer.sendChatMessage("/warp " + this.destination);
+
+ }
+
+}
diff --git a/src/main/java/me/Danker/commands/warp/WarpCommandHandler.java b/src/main/java/me/Danker/commands/warp/WarpCommandHandler.java
new file mode 100644
index 0000000..6cdf840
--- /dev/null
+++ b/src/main/java/me/Danker/commands/warp/WarpCommandHandler.java
@@ -0,0 +1,94 @@
+package me.Danker.commands.warp;
+
+import net.minecraftforge.client.ClientCommandHandler;
+
+import java.util.ArrayList;
+import java.util.List;
+
+public class WarpCommandHandler {
+
+ private List<WarpCommand> commands;
+
+ /**
+ * Constructor of the WarpCommandHandler, it will register all commands when it is created
+ */
+ public WarpCommandHandler() {
+ this.commands = new ArrayList<WarpCommand>();
+ registerCommands();
+ }
+
+
+ /**
+ * @return List of all registered commands
+ */
+ public List<WarpCommand> getCommands() {
+ return this.commands;
+ }
+
+ /**
+ * Registers a command to the handler
+ * @param warpCommand WarpCommand to register
+ */
+ public void registerCommand(WarpCommand warpCommand) {
+ this.commands.add(warpCommand);
+ ClientCommandHandler.instance.registerCommand(warpCommand);
+ }
+
+ /**
+ * Get a command by its name
+ * @param name Name of the command
+ * @return WarpCommand with the given name
+ */
+ public WarpCommand getCommand(String name) {
+ for (WarpCommand command : this.commands) {
+ if (command.getCommandName().equalsIgnoreCase(name)) {
+ return command;
+ }
+ }
+ return null;
+ }
+
+ /**
+ * Get a command by the class it extends from
+ * @param clazz Class to get the command from
+ * @return WarpCommand with the given class
+ */
+ public WarpCommand getCommand(Class<? extends WarpCommand> clazz) {
+ for (WarpCommand command : this.commands) {
+ if (command.getClass() == clazz) {
+ return command;
+ }
+ }
+ return null;
+ }
+
+ /**
+ * Register all commands
+ */
+ private void registerCommands() {
+ registerCommand(new WarpCommand("deep", "deep"));
+ registerCommand(new WarpCommand("nether", "nether"));
+ registerCommand(new WarpCommand("isle", "isle"));
+ registerCommand(new WarpCommand("crimson", "crimson"));
+ registerCommand(new WarpCommand("mines", "mines"));
+ registerCommand(new WarpCommand("forge", "forge"));
+ registerCommand(new WarpCommand("crystals", "crystals"));
+ registerCommand(new WarpCommand("gold", "gold"));
+ registerCommand(new WarpCommand("desert", "desert"));
+ registerCommand(new WarpCommand("spider", "spider"));
+ registerCommand(new WarpCommand("barn", "barn"));
+ registerCommand(new WarpCommand("end", "end"));
+ registerCommand(new WarpCommand("park", "park"));
+ registerCommand(new WarpCommand("castle", "castle"));
+ registerCommand(new WarpCommand("museum", "museum"));
+ registerCommand(new WarpCommand("da", "da"));
+ registerCommand(new WarpCommand("crypt", "crypt"));
+ registerCommand(new WarpCommand("nest", "nest"));
+ registerCommand(new WarpCommand("void", "void"));
+ registerCommand(new WarpCommand("drag", "dragon"));
+ registerCommand(new WarpCommand("jungle", "jungle"));
+ registerCommand(new WarpCommand("howl", "howl"));
+ registerCommand(new WarpCommand("dun", "dungeon_hub"));
+ }
+
+}