me.lucko.helper.command.functional.FunctionalCommandBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of helper Show documentation
Show all versions of helper Show documentation
A utility to reduce boilerplate code in Bukkit plugins.
/*
* This file is part of helper, licensed under the MIT License.
*
* Copyright (c) lucko (Luck)
* Copyright (c) contributors
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package me.lucko.helper.command.functional;
import me.lucko.helper.command.Command;
import me.lucko.helper.utils.annotation.NonnullByDefault;
import org.bukkit.command.CommandSender;
import org.bukkit.command.ConsoleCommandSender;
import org.bukkit.entity.Player;
import java.util.function.Predicate;
/**
* Functional builder API for {@link Command}
*
* @param the sender type
*/
@NonnullByDefault
public interface FunctionalCommandBuilder {
// Default failure messages
String DEFAULT_NO_PERMISSION_MESSAGE = "&cYou do not have permission to use this command.";
String DEFAULT_NOT_OP_MESSAGE = "&cOnly server operators are able to use this command.";
String DEFAULT_NOT_PLAYER_MESSAGE = "&cOnly players are able to use this command.";
String DEFAULT_NOT_CONSOLE_MESSAGE = "&cThis command is only available through the server console.";
String DEFAULT_INVALID_USAGE_MESSAGE = "&cInvalid usage. Try: {usage}.";
String DEFAULT_INVALID_ARGUMENT_MESSAGE = "&cInvalid argument '{arg}' at index {index}.";
String DEFAULT_INVALID_SENDER_MESSAGE = "&cYou are not able to use this command.";
static FunctionalCommandBuilder newBuilder() {
return new FunctionalCommandBuilderImpl<>();
}
/**
* Asserts that the sender has the specified permission, and sends them the default failure message
* if they don't have permission.
*
* @param permission the permission to check for
* @return the builder instance
*/
default FunctionalCommandBuilder assertPermission(String permission) {
return assertPermission(permission, DEFAULT_NO_PERMISSION_MESSAGE);
}
/**
* Asserts that the sender has the specified permission, and sends them the failure message if they
* don't have permission.
*
* @param permission the permission to check for
* @param failureMessage the failure message to send if they don't have permission
* @return the builder instance
*/
FunctionalCommandBuilder assertPermission(String permission, String failureMessage);
/**
* Asserts that the sender is op, and sends them the default failure message if they're not.
*
* @return the builder instance
*/
default FunctionalCommandBuilder assertOp() {
return assertOp(DEFAULT_NOT_OP_MESSAGE);
}
/**
* Asserts that the sender is op, and sends them the failure message if they don't have permission
*
* @param failureMessage the failure message to send if they're not op
* @return the builder instance
*/
FunctionalCommandBuilder assertOp(String failureMessage);
/**
* Asserts that the sender is instance of Player, and sends them the default failure message if they're not.
*
* @return the builder instance
*/
default FunctionalCommandBuilder assertPlayer() {
return assertPlayer(DEFAULT_NOT_PLAYER_MESSAGE);
}
/**
* Asserts that the sender is instance of Player, and sends them the failure message if they're not
*
* @param failureMessage the failure message to send if they're not a player
* @return the builder instance
*/
FunctionalCommandBuilder assertPlayer(String failureMessage);
/**
* Asserts that the sender is instance of ConsoleCommandSender, and sends them the default failure message if
* they're not.
*
* @return the builder instance
*/
default FunctionalCommandBuilder assertConsole() {
return assertConsole(DEFAULT_NOT_CONSOLE_MESSAGE);
}
/**
* Asserts that the sender is instance of ConsoleCommandSender, and sends them the failure message if they're not
*
* @param failureMessage the failure message to send if they're not console
* @return the builder instance
*/
FunctionalCommandBuilder assertConsole(String failureMessage);
/**
* Asserts that the arguments match the given usage string.
*
* Arguments should be separated by a " " space. Optional arguments are denoted by wrapping the argument name in
* square quotes "[ ]"
*
* The default failure message is sent if they didn't provide enough arguments.
*
* @param usage the usage string
* @return the builder instance
*/
default FunctionalCommandBuilder assertUsage(String usage) {
return assertUsage(usage, DEFAULT_INVALID_USAGE_MESSAGE);
}
/**
* Asserts that the arguments match the given usage string.
*
* Arguments should be separated by a " " space. Optional arguments are denoted by wrapping the argument name in
* square quotes "[ ]"
*
* The failure message is sent if they didn't provide enough arguments. "{usage}" in this message will be replaced by
* the usage for the command.
*
* @param usage the usage string
* @param failureMessage the failure message to send if the arguments to not match the usage
* @return the builder instance
*/
FunctionalCommandBuilder assertUsage(String usage, String failureMessage);
/**
* Tests a given argument with the provided predicate.
*
* The default failure message is sent if the argument does not pass the predicate. If the argument is not
* present at the given index, null
is passed to the predicate.
*
* @param index the index of the argument to test
* @param test the test predicate
* @return the builder instance
*/
default FunctionalCommandBuilder assertArgument(int index, Predicate test) {
return assertArgument(index, test, DEFAULT_INVALID_ARGUMENT_MESSAGE);
}
/**
* Tests a given argument with the provided predicate.
*
* The failure message is sent if the argument does not pass the predicate. If the argument is not present at the
* given index, null
is passed to the predicate.
*
* "{arg}" and "{index}" will be replaced in the failure message with the index and actual argument value respectively.
*
* @param index the index of the argument to test
* @param test the test predicate
* @param failureMessage the failure message to send if the predicate fails
* @return the builder instance
*/
FunctionalCommandBuilder assertArgument(int index, Predicate test, String failureMessage);
/**
* Tests the sender with the provided predicate.
*
* The default failure message is sent if the sender does not pass the predicate.
*
* @param test the test predicate
* @return the builder instance
*/
default FunctionalCommandBuilder assertSender(Predicate test) {
return assertSender(test, DEFAULT_INVALID_SENDER_MESSAGE);
}
/**
* Tests the sender with the provided predicate.
*
* The failure message is sent if the sender does not pass the predicate.
*
* @param test the test predicate
* @param failureMessage the failure message to send if the predicate fails
* @return the builder instance
*/
FunctionalCommandBuilder assertSender(Predicate test, String failureMessage);
/**
* Builds this {@link FunctionalCommandBuilder} into a {@link Command} instance.
*
* The command will not be registered with the server until {@link Command#register(String...)} is called.
*
* @param handler the command handler
* @return the command instance.
*/
Command handler(FunctionalCommandHandler handler);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy