mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2025-01-24 09:02:00 +01:00
Added CompositeCommand#call(...) (#772)
* Implements new call API for commands https://github.com/BentoBoxWorld/BentoBox/issues/759 * pom.xml should not use tabs * Improved javadoc * refixed the since tag in javadoc
This commit is contained in:
parent
c864ba7ab6
commit
15b602f331
@ -215,17 +215,6 @@ public abstract class CompositeCommand extends Command implements PluginIdentifi
|
|||||||
public boolean execute(CommandSender sender, String label, String[] args) {
|
public boolean execute(CommandSender sender, String label, String[] args) {
|
||||||
// Get the User instance for this sender
|
// Get the User instance for this sender
|
||||||
User user = User.getInstance(sender);
|
User user = User.getInstance(sender);
|
||||||
CompositeCommand cmd = getCommandFromArgs(args);
|
|
||||||
// Check for console and permissions
|
|
||||||
if (cmd.onlyPlayer && !(sender instanceof Player)) {
|
|
||||||
user.sendMessage("general.errors.use-in-game");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
// Check perms, but only if this isn't the console
|
|
||||||
if ((sender instanceof Player) && !sender.isOp() && !cmd.getPermission().isEmpty() && !sender.hasPermission(cmd.getPermission())) {
|
|
||||||
user.sendMessage("general.errors.no-permission", TextVariables.PERMISSION, cmd.getPermission());
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
// Fire an event to see if this command should be cancelled
|
// Fire an event to see if this command should be cancelled
|
||||||
CommandEvent event = CommandEvent.builder()
|
CommandEvent event = CommandEvent.builder()
|
||||||
.setCommand(this)
|
.setCommand(this)
|
||||||
@ -236,14 +225,39 @@ public abstract class CompositeCommand extends Command implements PluginIdentifi
|
|||||||
if (event.isCancelled()) {
|
if (event.isCancelled()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
// Get command
|
||||||
|
CompositeCommand cmd = getCommandFromArgs(args);
|
||||||
|
String cmdLabel = (cmd.subCommandLevel > 0) ? args[cmd.subCommandLevel-1] : label;
|
||||||
|
List<String> cmdArgs = Arrays.asList(args).subList(cmd.subCommandLevel, args.length);
|
||||||
|
// Call
|
||||||
|
return cmd.call(user, cmdLabel, cmdArgs);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calls this composite command.
|
||||||
|
* Does not traverse the tree of subcommands in args.
|
||||||
|
* Event is not fired and it cannot be cancelled.
|
||||||
|
* @param user - user calling this command
|
||||||
|
* @param label - label used
|
||||||
|
* @param args - list of args
|
||||||
|
* @return {@code true} if successful, {@code false} if not.
|
||||||
|
* @since 1.5.3
|
||||||
|
*/
|
||||||
|
public boolean call(User user, String cmdLabel, List<String> cmdArgs) {
|
||||||
|
// Check for console and permissions
|
||||||
|
if (onlyPlayer && !user.isPlayer()) {
|
||||||
|
user.sendMessage("general.errors.use-in-game");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
// Check perms, but only if this isn't the console
|
||||||
|
if (user.isPlayer() && !user.isOp() && !getPermission().isEmpty() && !user.hasPermission(getPermission())) {
|
||||||
|
user.sendMessage("general.errors.no-permission", TextVariables.PERMISSION, getPermission());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
// Set the user's addon context
|
// Set the user's addon context
|
||||||
user.setAddon(addon);
|
user.setAddon(addon);
|
||||||
// Execute and trim args
|
// Execute and trim args
|
||||||
|
return canExecute(user, cmdLabel, cmdArgs) && execute(user, cmdLabel, cmdArgs);
|
||||||
String cmdLabel = (cmd.subCommandLevel > 0) ? args[cmd.subCommandLevel-1] : label;
|
|
||||||
List<String> cmdArgs = Arrays.asList(args).subList(cmd.subCommandLevel, args.length);
|
|
||||||
|
|
||||||
return cmd.canExecute(user, cmdLabel, cmdArgs) && cmd.execute(user, cmdLabel, cmdArgs);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user