Mirror von
https://github.com/PaperMC/Velocity.git
synchronisiert 2025-01-11 23:51:22 +01:00
feat: Warn if an attempt is made to register a command with multiple interfaces implemented instead of just ignoring it (#1000)
Dieser Commit ist enthalten in:
Ursprung
d438422d52
Commit
e364e2c7d1
@ -39,6 +39,7 @@ import com.velocitypowered.proxy.command.registrar.CommandRegistrar;
|
|||||||
import com.velocitypowered.proxy.command.registrar.RawCommandRegistrar;
|
import com.velocitypowered.proxy.command.registrar.RawCommandRegistrar;
|
||||||
import com.velocitypowered.proxy.command.registrar.SimpleCommandRegistrar;
|
import com.velocitypowered.proxy.command.registrar.SimpleCommandRegistrar;
|
||||||
import com.velocitypowered.proxy.event.VelocityEventManager;
|
import com.velocitypowered.proxy.event.VelocityEventManager;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
@ -47,7 +48,7 @@ import java.util.concurrent.CompletableFuture;
|
|||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.locks.ReadWriteLock;
|
import java.util.concurrent.locks.ReadWriteLock;
|
||||||
import java.util.concurrent.locks.ReentrantReadWriteLock;
|
import java.util.concurrent.locks.ReentrantReadWriteLock;
|
||||||
import net.kyori.adventure.identity.Identity;
|
import java.util.stream.Collectors;
|
||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import net.kyori.adventure.text.format.NamedTextColor;
|
import net.kyori.adventure.text.format.NamedTextColor;
|
||||||
import org.checkerframework.checker.lock.qual.GuardedBy;
|
import org.checkerframework.checker.lock.qual.GuardedBy;
|
||||||
@ -114,14 +115,21 @@ public class VelocityCommandManager implements CommandManager {
|
|||||||
Preconditions.checkNotNull(meta, "meta");
|
Preconditions.checkNotNull(meta, "meta");
|
||||||
Preconditions.checkNotNull(command, "command");
|
Preconditions.checkNotNull(command, "command");
|
||||||
|
|
||||||
// TODO Warn if command implements multiple registrable interfaces?
|
final List<CommandRegistrar<?>> commandRegistrars = this.implementedRegistrars(command);
|
||||||
for (final CommandRegistrar<?> registrar : this.registrars) {
|
if (commandRegistrars.isEmpty()) {
|
||||||
if (this.tryRegister(registrar, command, meta)) {
|
|
||||||
return; // success
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new IllegalArgumentException(
|
throw new IllegalArgumentException(
|
||||||
command + " does not implement a registrable Command subinterface");
|
command + " does not implement a registrable Command subinterface");
|
||||||
|
} else if (commandRegistrars.size() > 1) {
|
||||||
|
final String implementedInterfaces = commandRegistrars.stream()
|
||||||
|
.map(CommandRegistrar::registrableSuperInterface)
|
||||||
|
.map(Class::getSimpleName)
|
||||||
|
.collect(Collectors.joining(", "));
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
command + " implements multiple registrable Command subinterfaces: "
|
||||||
|
+ implementedInterfaces);
|
||||||
|
} else {
|
||||||
|
this.internalRegister(commandRegistrars.get(0), command, meta);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -133,21 +141,26 @@ public class VelocityCommandManager implements CommandManager {
|
|||||||
* @param command the command to register
|
* @param command the command to register
|
||||||
* @param meta the command metadata
|
* @param meta the command metadata
|
||||||
* @param <T> the type of the command
|
* @param <T> the type of the command
|
||||||
* @return true if the command implements the registrable superinterface of the registrar; false
|
|
||||||
* otherwise.
|
|
||||||
* @throws IllegalArgumentException if the registrar cannot register the command
|
* @throws IllegalArgumentException if the registrar cannot register the command
|
||||||
*/
|
*/
|
||||||
private <T extends Command> boolean tryRegister(final CommandRegistrar<T> registrar,
|
private <T extends Command> void internalRegister(final CommandRegistrar<T> registrar,
|
||||||
final Command command, final CommandMeta meta) {
|
final Command command, final CommandMeta meta) {
|
||||||
final Class<T> superInterface = registrar.registrableSuperInterface();
|
final Class<T> superInterface = registrar.registrableSuperInterface();
|
||||||
if (!superInterface.isInstance(command)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
registrar.register(meta, superInterface.cast(command));
|
registrar.register(meta, superInterface.cast(command));
|
||||||
for (String alias : meta.getAliases()) {
|
for (String alias : meta.getAliases()) {
|
||||||
commandMetas.put(alias, meta);
|
commandMetas.put(alias, meta);
|
||||||
}
|
}
|
||||||
return true;
|
}
|
||||||
|
|
||||||
|
private List<CommandRegistrar<?>> implementedRegistrars(final Command command) {
|
||||||
|
final List<CommandRegistrar<?>> registrarsFound = new ArrayList<>(2);
|
||||||
|
for (final CommandRegistrar<?> registrar : this.registrars) {
|
||||||
|
final Class<?> superInterface = registrar.registrableSuperInterface();
|
||||||
|
if (superInterface.isInstance(command)) {
|
||||||
|
registrarsFound.add(registrar);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return registrarsFound;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -215,7 +228,7 @@ public class VelocityCommandManager implements CommandManager {
|
|||||||
boolean isSyntaxError = !e.getType().equals(
|
boolean isSyntaxError = !e.getType().equals(
|
||||||
CommandSyntaxException.BUILT_IN_EXCEPTIONS.dispatcherUnknownCommand());
|
CommandSyntaxException.BUILT_IN_EXCEPTIONS.dispatcherUnknownCommand());
|
||||||
if (isSyntaxError) {
|
if (isSyntaxError) {
|
||||||
source.sendMessage(Identity.nil(), Component.text(e.getMessage(), NamedTextColor.RED));
|
source.sendMessage(Component.text(e.getMessage(), NamedTextColor.RED));
|
||||||
// This is, of course, a lie, but the API will need to change...
|
// This is, of course, a lie, but the API will need to change...
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
Laden…
x
In neuem Issue referenzieren
Einen Benutzer sperren