summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsnowleo <schneeleo@gmail.com>2012-10-18 23:17:03 +0200
committersnowleo <schneeleo@gmail.com>2012-10-18 23:17:19 +0200
commit9d486ac6384340ff1c45c5db6d5f1d1e70487851 (patch)
treedd7f2144b9e9accd0ce710dd361ccda606f8155a
parentafa47c176b7a061ca6e0747b3dc66a2574f5d3ec (diff)
downloadEssentials-9d486ac6384340ff1c45c5db6d5f1d1e70487851.tar
Essentials-9d486ac6384340ff1c45c5db6d5f1d1e70487851.tar.gz
Essentials-9d486ac6384340ff1c45c5db6d5f1d1e70487851.tar.lz
Essentials-9d486ac6384340ff1c45c5db6d5f1d1e70487851.tar.xz
Essentials-9d486ac6384340ff1c45c5db6d5f1d1e70487851.zip
Add tabComplete support to Essentials commands
-rw-r--r--Essentials/src/net/ess3/api/ICommandHandler.java6
-rw-r--r--Essentials/src/net/ess3/bukkit/BukkitPlugin.java10
-rw-r--r--Essentials/src/net/ess3/commands/EssentialsCommand.java68
-rw-r--r--Essentials/src/net/ess3/commands/EssentialsCommandHandler.java124
-rw-r--r--Essentials/src/net/ess3/commands/IEssentialsCommand.java5
-rw-r--r--pom.xml2
6 files changed, 162 insertions, 53 deletions
diff --git a/Essentials/src/net/ess3/api/ICommandHandler.java b/Essentials/src/net/ess3/api/ICommandHandler.java
index 33093d4bd..1ea437c34 100644
--- a/Essentials/src/net/ess3/api/ICommandHandler.java
+++ b/Essentials/src/net/ess3/api/ICommandHandler.java
@@ -1,12 +1,12 @@
package net.ess3.api;
import java.util.Map;
-import org.bukkit.command.Command;
import org.bukkit.command.CommandSender;
+import org.bukkit.command.TabExecutor;
import org.bukkit.plugin.Plugin;
-public interface ICommandHandler extends IReload
+public interface ICommandHandler extends IReload, TabExecutor
{
Map<String, String> disabledCommands();
@@ -14,7 +14,5 @@ public interface ICommandHandler extends IReload
public void addPlugin(Plugin plugin);
- boolean handleCommand(CommandSender sender, Command command, String commandLabel, String[] args);
-
void showCommandError(CommandSender sender, String commandLabel, Throwable exception);
}
diff --git a/Essentials/src/net/ess3/bukkit/BukkitPlugin.java b/Essentials/src/net/ess3/bukkit/BukkitPlugin.java
index fa5f00a4c..11df0bcb6 100644
--- a/Essentials/src/net/ess3/bukkit/BukkitPlugin.java
+++ b/Essentials/src/net/ess3/bukkit/BukkitPlugin.java
@@ -3,6 +3,7 @@ package net.ess3.bukkit;
import java.io.File;
import java.util.Collections;
import java.util.HashMap;
+import java.util.List;
import java.util.Map;
import java.util.logging.Level;
import net.ess3.Essentials;
@@ -17,6 +18,7 @@ import net.ess3.metrics.MetricsListener;
import net.ess3.metrics.MetricsStarter;
import org.bukkit.Location;
import org.bukkit.command.Command;
+import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
@@ -119,7 +121,13 @@ public class BukkitPlugin extends JavaPlugin implements IPlugin
@Override
public boolean onCommand(final org.bukkit.command.CommandSender sender, final Command command, final String label, final String[] args)
{
- return ess.getCommandHandler().handleCommand(sender, command, label, args);
+ return ess.getCommandHandler().onCommand(sender, command, label, args);
+ }
+
+ @Override
+ public List<String> onTabComplete(CommandSender sender, Command command, String alias, String[] args)
+ {
+ return ess.getCommandHandler().onTabComplete(sender, command, alias, args);
}
@Override
diff --git a/Essentials/src/net/ess3/commands/EssentialsCommand.java b/Essentials/src/net/ess3/commands/EssentialsCommand.java
index 7b9c0c1f9..1994d1cf6 100644
--- a/Essentials/src/net/ess3/commands/EssentialsCommand.java
+++ b/Essentials/src/net/ess3/commands/EssentialsCommand.java
@@ -1,5 +1,6 @@
package net.ess3.commands;
+import java.util.List;
import java.util.logging.Logger;
import static net.ess3.I18n._;
import net.ess3.api.IEssentials;
@@ -37,51 +38,6 @@ public abstract class EssentialsCommand extends AbstractSuperpermsPermission imp
this.module = module;
}
- /*protected IUser getPlayer(final String[] args, final int pos) throws NoSuchFieldException, NotEnoughArgumentsException
- {
- return getPlayer(args, pos, false);
- }
-
- protected IUser getPlayer(final String[] args, final int pos, final boolean getOffline) throws NoSuchFieldException, NotEnoughArgumentsException
- {
- if (args.length <= pos)
- {
- throw new NotEnoughArgumentsException();
- }
- if (args[pos].isEmpty())
- {
- throw new NoSuchFieldException(_("playerNotFound"));
- }
- final IUser user = ess.getUserMap().getUser(args[pos]);
- if (user != null)
- {
- if (!getOffline && (!user.isOnline() || user.isHidden()))
- {
- throw new NoSuchFieldException(_("playerNotFound"));
- }
- return user;
- }
- final List<Player> matches = server.matchPlayer(args[pos]);
-
- if (!matches.isEmpty())
- {
- for (Player player : matches)
- {
- final IUser userMatch = player.getUser();
- if (userMatch.getDisplayName().startsWith(args[pos]) && (getOffline || !userMatch.isHidden()))
- {
- return userMatch;
- }
- }
- final IUser userMatch = matches.get(0).getUser();
- if (getOffline || !userMatch.isHidden())
- {
- return userMatch;
- }
- }
- throw new NoSuchFieldException(_("playerNotFound"));
- }*/
-
@Override
public final void run(final IUser user, final Command cmd, final String commandLabel, final String[] args) throws Exception
{
@@ -106,6 +62,28 @@ public abstract class EssentialsCommand extends AbstractSuperpermsPermission imp
{
throw new Exception(_("onlyPlayers", commandName));
}
+
+ @Override
+ public final List<String> tabComplete(final IUser user, final Command cmd, final String commandLabel, final String[] args)
+ {
+ return tabComplete(user, commandLabel, args);
+ }
+
+ protected List<String> tabComplete(final IUser user, final String commandLabel, final String[] args)
+ {
+ return tabComplete((CommandSender)user, commandLabel, args);
+ }
+
+ @Override
+ public final List<String> tabComplete(final CommandSender sender, final Command cmd, final String commandLabel, final String[] args)
+ {
+ return tabComplete(sender, commandLabel, args);
+ }
+
+ protected List<String> tabComplete(final CommandSender sender, final String commandLabel, final String[] args)
+ {
+ return null;
+ }
public static String getFinalArg(final String[] args, final int start)
{
diff --git a/Essentials/src/net/ess3/commands/EssentialsCommandHandler.java b/Essentials/src/net/ess3/commands/EssentialsCommandHandler.java
index c2707ffee..fdda25205 100644
--- a/Essentials/src/net/ess3/commands/EssentialsCommandHandler.java
+++ b/Essentials/src/net/ess3/commands/EssentialsCommandHandler.java
@@ -11,11 +11,12 @@ import org.bukkit.command.Command;
import org.bukkit.command.CommandSender;
import org.bukkit.command.PluginCommand;
import org.bukkit.command.PluginCommandYamlParser;
+import org.bukkit.command.TabExecutor;
import org.bukkit.entity.Player;
import org.bukkit.plugin.Plugin;
-public class EssentialsCommandHandler implements ICommandHandler
+public class EssentialsCommandHandler implements ICommandHandler, TabExecutor
{
private final transient ClassLoader classLoader;
private final transient String commandPath;
@@ -49,7 +50,7 @@ public class EssentialsCommandHandler implements ICommandHandler
}
@Override
- public boolean handleCommand(final CommandSender sender, final Command command, final String commandLabel, final String[] args)
+ public boolean onCommand(final CommandSender sender, final Command command, final String commandLabel, final String[] args)
{
ISettings settings = ess.getSettings();
@@ -109,6 +110,9 @@ public class EssentialsCommandHandler implements ICommandHandler
cmd.init(ess, commandName);
cmd.setEssentialsModule(module);
commands.put(commandName, cmd);
+ if (command instanceof PluginCommand) {
+ ((PluginCommand)command).setExecutor(this);
+ }
}
catch (Exception ex)
{
@@ -175,6 +179,122 @@ public class EssentialsCommandHandler implements ICommandHandler
}
}
+ //TODO: Clean this up, since both methods have a lot in common.
+ @Override
+ public List<String> onTabComplete(CommandSender sender, Command command, String commandLabel, String[] args)
+ {
+ ISettings settings = ess.getSettings();
+
+ boolean disabled = settings.getData().getCommands().isDisabled(command.getName());
+ boolean overridden = !disabled || settings.getData().getCommands().isOverridden(command.getName());
+
+ // TODO: Move this stuff to bukkit workarounds
+ // Allow plugins to override the command via onCommand
+ if (!overridden && (!commandLabel.startsWith("e") || commandLabel.equalsIgnoreCase(command.getName())))
+ {
+ final PluginCommand pc = getAlternative(commandLabel);
+ if (pc != null)
+ {
+
+ executed(commandLabel, pc.getLabel());
+ try
+ {
+ return pc.tabComplete(sender, commandLabel, args);
+ }
+ catch (final Exception ex)
+ {
+ final ArrayList<StackTraceElement> elements = new ArrayList<StackTraceElement>(Arrays.asList(ex.getStackTrace()));
+ elements.remove(0);
+ final ArrayList<StackTraceElement> toRemove = new ArrayList<StackTraceElement>();
+ for (final StackTraceElement e : elements)
+ {
+ if (e.getClassName().equals("net.ess3.Essentials"))
+ {
+ toRemove.add(e);
+ }
+ }
+ elements.removeAll(toRemove);
+ final StackTraceElement[] trace = elements.toArray(new StackTraceElement[elements.size()]);
+ ex.setStackTrace(trace);
+ ex.printStackTrace();
+ sender.sendMessage(ChatColor.RED + "An internal error occurred while attempting to perform this command");
+ return null;
+ }
+ }
+ }
+
+ try
+ {
+ // Check for disabled commands
+ if (disabled)
+ {
+ return null;
+ }
+
+ final String commandName = command.getName().toLowerCase(Locale.ENGLISH);
+ IEssentialsCommand cmd = commands.get(commandName);
+ if (cmd == null)
+ {
+ try
+ {
+ cmd = (IEssentialsCommand)classLoader.loadClass(commandPath + commandName).newInstance();
+ cmd.init(ess, commandName);
+ cmd.setEssentialsModule(module);
+ commands.put(commandName, cmd);
+ if (command instanceof PluginCommand) {
+ ((PluginCommand)command).setExecutor(this);
+ }
+ }
+ catch (Exception ex)
+ {
+ sender.sendMessage(_("commandNotLoaded", commandName));
+ LOGGER.log(Level.SEVERE, _("commandNotLoaded", commandName), ex);
+ return null;
+ }
+ }
+
+ // Check authorization
+ if (sender != null && !cmd.isAuthorized(sender))
+ {
+ LOGGER.log(Level.WARNING, _("deniedAccessCommand", sender.getName()));
+ sender.sendMessage(_("noAccessCommand"));
+ return null;
+ }
+
+ IUser user = (sender instanceof Player) ? ess.getUserMap().getUser((Player)sender) : null;
+ // Run the command
+ try
+ {
+ if (user == null)
+ {
+ return cmd.tabComplete(sender, command, commandLabel, args);
+ }
+ else
+ {
+ user.setPlayerCache((Player)sender);
+ try
+ {
+ return cmd.tabComplete(user, command, commandLabel, args);
+ }
+ finally
+ {
+ user.setPlayerCache(null);
+ }
+ }
+ }
+ catch (Throwable ex)
+ {
+ showCommandError(sender, commandLabel, ex);
+ return null;
+ }
+ }
+ catch (Throwable ex)
+ {
+ LOGGER.log(Level.SEVERE, _("commandFailed", commandLabel), ex);
+ return null;
+ }
+ }
+
@Override
public void showCommandError(final CommandSender sender, final String commandLabel, final Throwable exception)
{
diff --git a/Essentials/src/net/ess3/commands/IEssentialsCommand.java b/Essentials/src/net/ess3/commands/IEssentialsCommand.java
index 34f1ba020..3d20209fb 100644
--- a/Essentials/src/net/ess3/commands/IEssentialsCommand.java
+++ b/Essentials/src/net/ess3/commands/IEssentialsCommand.java
@@ -1,5 +1,6 @@
package net.ess3.commands;
+import java.util.List;
import net.ess3.api.IEssentials;
import net.ess3.api.IEssentialsModule;
import net.ess3.api.IPermission;
@@ -15,6 +16,10 @@ public interface IEssentialsCommand extends IPermission
void run(CommandSender sender, Command cmd, String commandLabel, String[] args)
throws Exception;
+
+ List<String> tabComplete(IUser user, Command cmd, String commandLabel, String[] args);
+
+ List<String> tabComplete(CommandSender sender, Command cmd, String commandLabel, String[] args);
void init(IEssentials ess, String commandLabel);
diff --git a/pom.xml b/pom.xml
index 5f6a6b90f..066ee5827 100644
--- a/pom.xml
+++ b/pom.xml
@@ -76,7 +76,7 @@
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
- <bukkit.version>1.3.2-R1.1-SNAPSHOT</bukkit.version>
+ <bukkit.version>1.3.2-R2.1-SNAPSHOT</bukkit.version>
<build.number>Unknown</build.number>
<org-netbeans-modules-editor-indent.CodeStyle.project.expand-tabs>true</org-netbeans-modules-editor-indent.CodeStyle.project.expand-tabs>
<org-netbeans-modules-editor-indent.CodeStyle.project.indent-shift-width>2</org-netbeans-modules-editor-indent.CodeStyle.project.indent-shift-width>