mirror of
https://github.com/CitizensDev/Citizens2.git
synced 2025-01-21 07:32:16 +01:00
Better usability for commands which require an NPC to be selected
This commit is contained in:
parent
7d214ffce9
commit
01ec75e254
@ -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);
|
||||||
|
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user