Update console command completion for improved thread safety

This commit is contained in:
Phillip Schichtel 2013-08-04 20:01:08 +10:00 committed by md_5
parent 843c21ddf8
commit b0888e8231

View file

@ -1,4 +1,4 @@
From 4f18b70047255bbd18202656c6e95333ec9cac58 Mon Sep 17 00:00:00 2001 From f0b905b9c4e67f0594a46c19bcab3f9d70984fcb Mon Sep 17 00:00:00 2001
From: Phillip Schichtel <quick_wango@code-infection.de> From: Phillip Schichtel <quick_wango@code-infection.de>
Date: Fri, 5 Jul 2013 21:55:00 +1000 Date: Fri, 5 Jul 2013 21:55:00 +1000
Subject: [PATCH] Console Command Completion Subject: [PATCH] Console Command Completion
@ -13,7 +13,7 @@ This commit implements tab completion in the console by providing the
ConsoleReader with a Completer implementation. ConsoleReader with a Completer implementation.
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
index 971cfa5..7cf2a94 100644 index c4fc9d0..de4a430 100644
--- a/src/main/java/net/minecraft/server/PlayerList.java --- a/src/main/java/net/minecraft/server/PlayerList.java
+++ b/src/main/java/net/minecraft/server/PlayerList.java +++ b/src/main/java/net/minecraft/server/PlayerList.java
@@ -17,6 +17,7 @@ import java.util.Map.Entry; @@ -17,6 +17,7 @@ import java.util.Map.Entry;
@ -34,7 +34,7 @@ index 971cfa5..7cf2a94 100644
diff --git a/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java b/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java diff --git a/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java b/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java
new file mode 100644 new file mode 100644
index 0000000..b108bd1 index 0000000..a889ff3
--- /dev/null --- /dev/null
+++ b/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java +++ b/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java
@@ -0,0 +1,46 @@ @@ -0,0 +1,46 @@
@ -56,10 +56,15 @@ index 0000000..b108bd1
+ } + }
+ +
+ public int complete(final String buffer, final int cursor, final List<CharSequence> candidates) { + public int complete(final String buffer, final int cursor, final List<CharSequence> candidates) {
+ Waitable<Integer> waitable = new Waitable<Integer>() { + Waitable<List<String>> waitable = new Waitable<List<String>>() {
+ @Override + @Override
+ protected Integer evaluate() { + protected List<String> evaluate() {
+ List<String> offers = server.getCommandMap().tabComplete(server.getConsoleSender(), buffer); + return server.getCommandMap().tabComplete(server.getConsoleSender(), buffer);
+ }
+ };
+ this.server.getServer().processQueue.add(waitable);
+ try {
+ List<String> offers = waitable.get();
+ if (offers == null) { + if (offers == null) {
+ return cursor; + return cursor;
+ } + }
@ -71,11 +76,6 @@ index 0000000..b108bd1
+ } else { + } else {
+ return cursor - (buffer.length() - lastSpace - 1); + return cursor - (buffer.length() - lastSpace - 1);
+ } + }
+ }
+ };
+ this.server.getServer().processQueue.add(waitable);
+ try {
+ return waitable.get();
+ } catch (ExecutionException e) { + } catch (ExecutionException e) {
+ this.server.getLogger().log(Level.WARNING, "Unhandled exception when tab completing", e); + this.server.getLogger().log(Level.WARNING, "Unhandled exception when tab completing", e);
+ } catch (InterruptedException e) { + } catch (InterruptedException e) {