SPIGOT-4024: Improve interactions of Vanilla tab completion, and also reloads

By: md_5 <git@md-5.net>
This commit is contained in:
CraftBukkit/Spigot 2018-07-21 11:20:38 +10:00
parent ee4832c2ce
commit 5bc15c40d8
4 changed files with 35 additions and 22 deletions

View File

@ -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));
}

View File

@ -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) -> {

View File

@ -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;

View File

@ -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()) {