Better usability for commands which require an NPC to be selected

This commit is contained in:
fullwall 2012-09-09 17:52:00 +08:00
parent 7d214ffce9
commit 01ec75e254
2 changed files with 30 additions and 21 deletions

View File

@ -15,6 +15,7 @@ import java.util.Set;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.citizensnpcs.api.CitizensAPI;
import net.citizensnpcs.api.npc.NPC; import net.citizensnpcs.api.npc.NPC;
import net.citizensnpcs.api.trait.trait.MobType; import net.citizensnpcs.api.trait.trait.MobType;
import net.citizensnpcs.api.trait.trait.Owner; import net.citizensnpcs.api.trait.trait.Owner;
@ -94,14 +95,39 @@ public class CommandManager {
if (!hasPermission(method, sender) && methodArgs[1] instanceof Player) if (!hasPermission(method, sender) && methodArgs[1] instanceof Player)
throw new NoPermissionsException(); throw new NoPermissionsException();
Command cmd = method.getAnnotation(Command.class);
CommandContext context = new CommandContext(args);
if (context.argsLength() < cmd.min())
throw new CommandUsageException("Too few arguments.", getUsage(args, cmd));
if (cmd.max() != -1 && context.argsLength() > cmd.max())
throw new CommandUsageException("Too many arguments.", getUsage(args, cmd));
if (!context.getFlags().contains('*')) {
for (char flag : context.getFlags())
if (cmd.flags().indexOf(String.valueOf(flag)) == -1)
throw new CommandUsageException("Unknown flag: " + flag, getUsage(args, cmd));
}
methodArgs[0] = context;
Requirements cmdRequirements = requirements.get(method); Requirements cmdRequirements = requirements.get(method);
if (cmdRequirements != null) { if (cmdRequirements != null) {
NPC npc = (NPC) methodArgs[2]; NPC npc = (NPC) methodArgs[2];
// Requirements // Requirements
if (cmdRequirements.selected() && npc == null) if (cmdRequirements.selected() && npc == null) {
throw new RequirementMissingException( boolean canRedefineSelected = context.hasValueFlag("id")
"You must have an NPC selected to execute that command."); && sender.hasPermission("npc.select");
String error = "You must have an NPC selected to execute that command.";
if (canRedefineSelected) {
npc = CitizensAPI.getNPCRegistry().getById(context.getFlagInteger("id"));
if (npc == null)
error += " Couldn't find any NPC with ID " + context.getFlagInteger("id") + ".";
}
throw new RequirementMissingException(error);
}
if (cmdRequirements.ownership() && npc != null && !sender.hasPermission("citizens.admin") if (cmdRequirements.ownership() && npc != null && !sender.hasPermission("citizens.admin")
&& !npc.getTrait(Owner.class).isOwnedBy(sender)) && !npc.getTrait(Owner.class).isOwnedBy(sender))
@ -123,23 +149,6 @@ public class CommandManager {
} }
} }
Command cmd = method.getAnnotation(Command.class);
CommandContext context = new CommandContext(args);
if (context.argsLength() < cmd.min())
throw new CommandUsageException("Too few arguments.", getUsage(args, cmd));
if (cmd.max() != -1 && context.argsLength() > cmd.max())
throw new CommandUsageException("Too many arguments.", getUsage(args, cmd));
if (!context.getFlags().contains('*')) {
for (char flag : context.getFlags())
if (cmd.flags().indexOf(String.valueOf(flag)) == -1)
throw new CommandUsageException("Unknown flag: " + flag, getUsage(args, cmd));
}
methodArgs[0] = context;
Object instance = instances.get(method); Object instance = instances.get(method);
try { try {
method.invoke(instance, methodArgs); method.invoke(instance, methodArgs);

View File

@ -362,7 +362,7 @@ public class NPCCommands {
@Command( @Command(
aliases = { "npc" }, aliases = { "npc" },
usage = "moveto", usage = "moveto (--x x --y y --z z --world world --pitch pitch --yaw yaw",
desc = "Teleports a NPC to a given location", desc = "Teleports a NPC to a given location",
modifiers = "moveto", modifiers = "moveto",
min = 1, min = 1,