mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-10 10:17:38 +01:00
SPIGOT-4024: Improve interactions of Vanilla tab completion, and also reloads
By: md_5 <git@md-5.net>
This commit is contained in:
parent
ee4832c2ce
commit
5bc15c40d8
@ -93,7 +93,7 @@
|
|||||||
ChatComponentText chatcomponenttext;
|
ChatComponentText chatcomponenttext;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@@ -135,54 +188,59 @@
|
@@ -135,65 +188,80 @@
|
||||||
return i;
|
return i;
|
||||||
} catch (CommandException commandexception) {
|
} catch (CommandException commandexception) {
|
||||||
commandlistenerwrapper.sendFailureMessage(commandexception.a());
|
commandlistenerwrapper.sendFailureMessage(commandexception.a());
|
||||||
@ -145,17 +145,17 @@
|
|||||||
} catch (Exception exception) {
|
} catch (Exception exception) {
|
||||||
- chatcomponenttext = new ChatComponentText;
|
- chatcomponenttext = new ChatComponentText;
|
||||||
- }
|
- }
|
||||||
+ ChatMessage chatmessage1 = new ChatMessage("command.failed", new Object[0]);
|
-
|
||||||
|
|
||||||
- chatcomponenttext.<init>(exception.getMessage() == null ? exception.getClass().getName() : exception.getMessage());
|
- chatcomponenttext.<init>(exception.getMessage() == null ? exception.getClass().getName() : exception.getMessage());
|
||||||
- ChatComponentText chatcomponenttext1 = chatcomponenttext;
|
- ChatComponentText chatcomponenttext1 = chatcomponenttext;
|
||||||
|
+ ChatMessage chatmessage1 = new ChatMessage("command.failed", new Object[0]);
|
||||||
|
|
||||||
|
- if (CommandDispatcher.a.isDebugEnabled()) {
|
||||||
|
- StackTraceElement[] astacktraceelement = exception.getStackTrace();
|
||||||
+ chatcomponenttext = new ChatComponentText(exception.getMessage() == null ? exception.getClass().getName() : exception.getMessage());
|
+ chatcomponenttext = new ChatComponentText(exception.getMessage() == null ? exception.getClass().getName() : exception.getMessage());
|
||||||
+ if (CommandDispatcher.a.isDebugEnabled()) {
|
+ if (CommandDispatcher.a.isDebugEnabled()) {
|
||||||
+ StackTraceElement[] astacktraceelement = exception.getStackTrace();
|
+ StackTraceElement[] astacktraceelement = exception.getStackTrace();
|
||||||
|
|
||||||
- if (CommandDispatcher.a.isDebugEnabled()) {
|
|
||||||
- StackTraceElement[] astacktraceelement = exception.getStackTrace();
|
|
||||||
-
|
|
||||||
- for (int k = 0; k < Math.min(astacktraceelement.length, 3); ++k) {
|
- for (int k = 0; k < Math.min(astacktraceelement.length, 3); ++k) {
|
||||||
- chatcomponenttext1.a("\n\n").a(astacktraceelement[k].getMethodName()).a("\n ").a(astacktraceelement[k].getFileName()).a(":").a(String.valueOf(astacktraceelement[k].getLineNumber()));
|
- chatcomponenttext1.a("\n\n").a(astacktraceelement[k].getMethodName()).a("\n ").a(astacktraceelement[k].getFileName()).a(":").a(String.valueOf(astacktraceelement[k].getLineNumber()));
|
||||||
+ for (int k = 0; k < Math.min(astacktraceelement.length, 3); ++k) {
|
+ for (int k = 0; k < Math.min(astacktraceelement.length, 3); ++k) {
|
||||||
@ -180,3 +180,25 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
return b0;
|
return b0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void a(EntityPlayer entityplayer) {
|
||||||
|
- HashMap hashmap = Maps.newHashMap();
|
||||||
|
+ // CraftBukkit start
|
||||||
|
+ // Register Vanilla commands into builtRoot as before
|
||||||
|
+ Map hashmap = Maps.newIdentityHashMap(); // Use identity to prevent aliasing issues
|
||||||
|
+ RootCommandNode vanillaRoot = new RootCommandNode();
|
||||||
|
+
|
||||||
|
+ RootCommandNode<CommandListenerWrapper> vanilla = entityplayer.server.vanillaCommandDispatcher.a().getRoot();
|
||||||
|
+ hashmap.put(vanilla, vanillaRoot);
|
||||||
|
+ this.a(vanilla, vanillaRoot, entityplayer.getCommandListener(), (Map) hashmap);
|
||||||
|
+
|
||||||
|
+ // Now build the global commands in a second pass
|
||||||
|
RootCommandNode rootcommandnode = new RootCommandNode();
|
||||||
|
|
||||||
|
hashmap.put(this.b.getRoot(), rootcommandnode);
|
||||||
|
this.a(this.b.getRoot(), rootcommandnode, entityplayer.getCommandListener(), (Map) hashmap);
|
||||||
|
+ // CraftBukkit end
|
||||||
|
entityplayer.playerConnection.sendPacket(new PacketPlayOutCommands(rootcommandnode));
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/net/minecraft/server/CustomFunctionData.java
|
--- a/net/minecraft/server/CustomFunctionData.java
|
||||||
+++ b/net/minecraft/server/CustomFunctionData.java
|
+++ b/net/minecraft/server/CustomFunctionData.java
|
||||||
@@ -32,14 +32,16 @@
|
@@ -32,7 +32,7 @@
|
||||||
private final Map<MinecraftKey, CustomFunction> g = Maps.newHashMap();
|
private final Map<MinecraftKey, CustomFunction> g = Maps.newHashMap();
|
||||||
private final ArrayDeque<CustomFunctionData.a> h = new ArrayDeque();
|
private final ArrayDeque<CustomFunctionData.a> h = new ArrayDeque();
|
||||||
private boolean i;
|
private boolean i;
|
||||||
@ -9,25 +9,16 @@
|
|||||||
return this.a(minecraftkey) != null;
|
return this.a(minecraftkey) != null;
|
||||||
}, this::a, "tags/functions", true, "function");
|
}, this::a, "tags/functions", true, "function");
|
||||||
private final List<CustomFunction> k = Lists.newArrayList();
|
private final List<CustomFunction> k = Lists.newArrayList();
|
||||||
private boolean l;
|
@@ -60,7 +60,7 @@
|
||||||
+ private final com.mojang.brigadier.CommandDispatcher<CommandListenerWrapper> dispatcher; // CraftBukkit
|
|
||||||
|
|
||||||
public CustomFunctionData(MinecraftServer minecraftserver) {
|
|
||||||
this.f = minecraftserver;
|
|
||||||
+ this.dispatcher = this.f.getCommandDispatcher().a(); // CraftBukkit
|
|
||||||
}
|
|
||||||
|
|
||||||
@Nullable
|
|
||||||
@@ -60,7 +62,7 @@
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public com.mojang.brigadier.CommandDispatcher<CommandListenerWrapper> d() {
|
public com.mojang.brigadier.CommandDispatcher<CommandListenerWrapper> d() {
|
||||||
- return this.f.getCommandDispatcher().a();
|
- return this.f.getCommandDispatcher().a();
|
||||||
+ return dispatcher; // CraftBukkit
|
+ return this.f.vanillaCommandDispatcher.a(); // CraftBukkit
|
||||||
}
|
}
|
||||||
|
|
||||||
public void X_() {
|
public void X_() {
|
||||||
@@ -164,7 +166,7 @@
|
@@ -164,7 +164,7 @@
|
||||||
arraylist.add(CompletableFuture.supplyAsync(() -> {
|
arraylist.add(CompletableFuture.supplyAsync(() -> {
|
||||||
return a(iresourcemanager, minecraftkey);
|
return a(iresourcemanager, minecraftkey);
|
||||||
}, Resource.a).thenApplyAsync((list) -> {
|
}, Resource.a).thenApplyAsync((list) -> {
|
||||||
|
@ -31,10 +31,10 @@
|
|||||||
+ public java.util.Queue<Runnable> processQueue = new java.util.concurrent.ConcurrentLinkedQueue<Runnable>();
|
+ public java.util.Queue<Runnable> processQueue = new java.util.concurrent.ConcurrentLinkedQueue<Runnable>();
|
||||||
+ public int autosavePeriod;
|
+ public int autosavePeriod;
|
||||||
+ public File bukkitDataPackFolder;
|
+ public File bukkitDataPackFolder;
|
||||||
|
+ public CommandDispatcher vanillaCommandDispatcher;
|
||||||
+ // CraftBukkit end
|
+ // CraftBukkit end
|
||||||
+
|
+
|
||||||
+ public MinecraftServer(OptionSet options, Proxy proxy, DataFixer datafixer, CommandDispatcher commanddispatcher, YggdrasilAuthenticationService yggdrasilauthenticationservice, MinecraftSessionService minecraftsessionservice, GameProfileRepository gameprofilerepository, UserCache usercache) {
|
+ public MinecraftServer(OptionSet options, Proxy proxy, DataFixer datafixer, CommandDispatcher commanddispatcher, YggdrasilAuthenticationService yggdrasilauthenticationservice, MinecraftSessionService minecraftsessionservice, GameProfileRepository gameprofilerepository, UserCache usercache) {
|
||||||
+ this.commandDispatcher = commanddispatcher; // CraftBukkit
|
|
||||||
this.ac = new ResourceManager(EnumResourcePackType.SERVER_DATA);
|
this.ac = new ResourceManager(EnumResourcePackType.SERVER_DATA);
|
||||||
this.resourcePackRepository = new ResourcePackRepository(ResourcePackLoader::new);
|
this.resourcePackRepository = new ResourcePackRepository(ResourcePackLoader::new);
|
||||||
this.ag = new CraftingManager();
|
this.ag = new CraftingManager();
|
||||||
@ -43,7 +43,7 @@
|
|||||||
this.am = new CustomFunctionData(this);
|
this.am = new CustomFunctionData(this);
|
||||||
this.d = proxy;
|
this.d = proxy;
|
||||||
- this.commandDispatcher = commanddispatcher;
|
- this.commandDispatcher = commanddispatcher;
|
||||||
+ // this.commandDispatcher = commanddispatcher; // CraftBukkit - moved up
|
+ this.commandDispatcher = this.vanillaCommandDispatcher = commanddispatcher; // CraftBukkit
|
||||||
this.U = yggdrasilauthenticationservice;
|
this.U = yggdrasilauthenticationservice;
|
||||||
this.V = minecraftsessionservice;
|
this.V = minecraftsessionservice;
|
||||||
this.W = gameprofilerepository;
|
this.W = gameprofilerepository;
|
||||||
|
@ -355,7 +355,7 @@ public final class CraftServer implements Server {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void setVanillaCommands() {
|
private void setVanillaCommands() {
|
||||||
CommandDispatcher dispatcher = console.getCommandDispatcher();
|
CommandDispatcher dispatcher = console.vanillaCommandDispatcher;
|
||||||
|
|
||||||
// Build a list of all Vanilla commands and create wrappers
|
// Build a list of all Vanilla commands and create wrappers
|
||||||
for (CommandNode<CommandListenerWrapper> cmd : dispatcher.a().getRoot().getChildren()) {
|
for (CommandNode<CommandListenerWrapper> cmd : dispatcher.a().getRoot().getChildren()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user