summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDemonWav <demonwav@gmail.com>2016-08-25 09:48:52 +1000
committermd_5 <git@md-5.net>2016-08-25 09:48:52 +1000
commitc74e2a73016e1e6b7ebf025e40438e16b90b41a3 (patch)
treee635765574613fc9da6cd0921c35480628d71005 /src
parent4db0855e3e1cbac09c819f140cf2f5590f5d0997 (diff)
downloadcraftbukkit-c74e2a73016e1e6b7ebf025e40438e16b90b41a3.tar
craftbukkit-c74e2a73016e1e6b7ebf025e40438e16b90b41a3.tar.gz
craftbukkit-c74e2a73016e1e6b7ebf025e40438e16b90b41a3.tar.lz
craftbukkit-c74e2a73016e1e6b7ebf025e40438e16b90b41a3.tar.xz
craftbukkit-c74e2a73016e1e6b7ebf025e40438e16b90b41a3.zip
SPIGOT-215: Implement infrastructure for Location tab completes
Diffstat (limited to 'src')
-rw-r--r--src/main/java/org/bukkit/craftbukkit/CraftServer.java13
-rw-r--r--src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java7
2 files changed, 13 insertions, 7 deletions
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
index bb956bc0..a741f1eb 100644
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
@@ -29,6 +29,7 @@ import org.bukkit.BanList;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.GameMode;
+import org.bukkit.Location;
import org.bukkit.OfflinePlayer;
import org.bukkit.Server;
import org.bukkit.UnsafeValues;
@@ -1528,7 +1529,7 @@ public final class CraftServer implements Server {
return warningState;
}
- public List<String> tabComplete(net.minecraft.server.ICommandListener sender, String message) {
+ public List<String> tabComplete(net.minecraft.server.ICommandListener sender, String message, BlockPosition pos) {
if (!(sender instanceof EntityPlayer)) {
return ImmutableList.of();
}
@@ -1536,7 +1537,7 @@ public final class CraftServer implements Server {
List<String> offers;
Player player = ((EntityPlayer) sender).getBukkitEntity();
if (message.startsWith("/")) {
- offers = tabCompleteCommand(player, message);
+ offers = tabCompleteCommand(player, message, pos);
} else {
offers = tabCompleteChat(player, message);
}
@@ -1547,10 +1548,14 @@ public final class CraftServer implements Server {
return tabEvent.isCancelled() ? Collections.EMPTY_LIST : tabEvent.getCompletions();
}
- public List<String> tabCompleteCommand(Player player, String message) {
+ public List<String> tabCompleteCommand(Player player, String message, BlockPosition pos) {
List<String> completions = null;
try {
- completions = getCommandMap().tabComplete(player, message.substring(1));
+ if (pos == null) {
+ completions = getCommandMap().tabComplete(player, message.substring(1));
+ } else {
+ completions = getCommandMap().tabComplete(player, message.substring(1), new Location(player.getWorld(), pos.getX(), pos.getY(), pos.getZ()));
+ }
} catch (CommandException ex) {
player.sendMessage(ChatColor.RED + "An internal error occurred while attempting to tab-complete this command");
getLogger().log(Level.SEVERE, "Exception when " + player.getName() + " attempted to tab complete " + message, ex);
diff --git a/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java b/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java
index 0930d30d..dcc2ab07 100644
--- a/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java
+++ b/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java
@@ -7,6 +7,7 @@ import net.minecraft.server.*;
import org.apache.commons.lang.Validate;
import org.apache.logging.log4j.Level;
+import org.bukkit.Location;
import org.bukkit.command.BlockCommandSender;
import org.bukkit.command.CommandSender;
import org.bukkit.command.ConsoleCommandSender;
@@ -38,11 +39,11 @@ public final class VanillaCommandWrapper extends VanillaCommand {
}
@Override
- public List<String> tabComplete(CommandSender sender, String alias, String[] args) throws IllegalArgumentException {
+ public List<String> tabComplete(CommandSender sender, String alias, String[] args, Location location) throws IllegalArgumentException {
Validate.notNull(sender, "Sender cannot be null");
Validate.notNull(args, "Arguments cannot be null");
Validate.notNull(alias, "Alias cannot be null");
- return (List<String>) vanillaCommand.tabComplete(MinecraftServer.getServer(), getListener(sender), args, new BlockPosition(0, 0, 0));
+ return (List<String>) vanillaCommand.tabComplete(MinecraftServer.getServer(), getListener(sender), args, new BlockPosition(location.getX(), location.getY(), location.getZ()));
}
public static CommandSender lastSender = null; // Nasty :(
@@ -72,7 +73,7 @@ public final class VanillaCommandWrapper extends VanillaCommand {
if (i > -1) {
List<Entity> list = ((List<Entity>)PlayerSelector.getPlayers(icommandlistener, as[i], Entity.class));
String s2 = as[i];
-
+
icommandlistener.a(CommandObjectiveExecutor.EnumCommandResult.AFFECTED_ENTITIES, list.size());
Iterator<Entity> iterator = list.iterator();