mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 05:47:45 +01:00
Allow vanilla commands to be the main version of a command
By: Thinkofdeath <thethinkofdeath@gmail.com>
This commit is contained in:
parent
8440092f32
commit
9c8d5eefd0
@ -491,8 +491,11 @@ public final class CraftServer implements Server {
|
||||
}
|
||||
|
||||
if (type == PluginLoadOrder.POSTWORLD) {
|
||||
// Spigot start - Allow vanilla commands to be forced to be the main command
|
||||
this.setVanillaCommands(true);
|
||||
this.commandMap.setFallbackCommands();
|
||||
this.setVanillaCommands();
|
||||
this.setVanillaCommands(false);
|
||||
// Spigot end
|
||||
this.commandMap.registerServerAliases();
|
||||
DefaultPermissions.registerCorePermissions();
|
||||
CraftDefaultPermissions.registerCorePermissions();
|
||||
@ -506,12 +509,21 @@ public final class CraftServer implements Server {
|
||||
this.pluginManager.disablePlugins();
|
||||
}
|
||||
|
||||
private void setVanillaCommands() {
|
||||
private void setVanillaCommands(boolean first) { // Spigot
|
||||
Commands dispatcher = this.console.vanillaCommandDispatcher;
|
||||
|
||||
// Build a list of all Vanilla commands and create wrappers
|
||||
for (CommandNode<CommandSourceStack> cmd : dispatcher.getDispatcher().getRoot().getChildren()) {
|
||||
this.commandMap.register("minecraft", new VanillaCommandWrapper(dispatcher, cmd));
|
||||
// Spigot start
|
||||
VanillaCommandWrapper wrapper = new VanillaCommandWrapper(dispatcher, cmd);
|
||||
if (org.spigotmc.SpigotConfig.replaceCommands.contains( wrapper.getName() ) ) {
|
||||
if (first) {
|
||||
this.commandMap.register("minecraft", wrapper);
|
||||
}
|
||||
} else if (!first) {
|
||||
this.commandMap.register("minecraft", wrapper);
|
||||
}
|
||||
// Spigot end
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -8,8 +8,10 @@ import java.lang.reflect.Method;
|
||||
import java.lang.reflect.Modifier;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.logging.Level;
|
||||
import net.minecraft.core.registries.BuiltInRegistries;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
@ -300,4 +302,16 @@ public class SpigotConfig
|
||||
{
|
||||
SpigotConfig.silentCommandBlocks = SpigotConfig.getBoolean( "commands.silent-commandblock-console", false );
|
||||
}
|
||||
|
||||
public static Set<String> replaceCommands;
|
||||
private static void replaceCommands()
|
||||
{
|
||||
if ( SpigotConfig.config.contains( "replace-commands" ) )
|
||||
{
|
||||
SpigotConfig.set( "commands.replace-commands", SpigotConfig.config.getStringList( "replace-commands" ) );
|
||||
SpigotConfig.config.set( "replace-commands", null );
|
||||
}
|
||||
SpigotConfig.replaceCommands = new HashSet<String>( (List<String>) SpigotConfig.getList( "commands.replace-commands",
|
||||
Arrays.asList( "setblock", "summon", "testforblock", "tellraw" ) ) );
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user