2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Minecrell <minecrell@minecrell.net>
|
|
|
|
Date: Fri, 9 Jun 2017 19:03:43 +0200
|
|
|
|
Subject: [PATCH] Use TerminalConsoleAppender for console improvements
|
|
|
|
|
|
|
|
Rewrite console improvements (console colors, tab completion,
|
|
|
|
persistent input line, ...) using JLine 3.x and TerminalConsoleAppender.
|
|
|
|
|
|
|
|
New features:
|
|
|
|
- Support console colors for Vanilla commands
|
|
|
|
- Add console colors for warnings and errors
|
|
|
|
- Server can now be turned off safely using CTRL + C. JLine catches
|
|
|
|
the signal and the implementation shuts down the server cleanly.
|
|
|
|
- Support console colors and persistent input line when running in
|
|
|
|
IntelliJ IDEA
|
|
|
|
|
|
|
|
Other changes:
|
|
|
|
- Server starts 1-2 seconds faster thanks to optimizations in Log4j
|
|
|
|
configuration
|
|
|
|
|
2021-06-12 12:26:21 +02:00
|
|
|
diff --git a/build.gradle.kts b/build.gradle.kts
|
2021-06-17 21:12:40 +02:00
|
|
|
index ffb7b25b01bc26e3234358e39633c7f7578e018d..a85b1922391bd9aa121a3654f0095c9523e7fbd7 100644
|
2021-06-12 12:26:21 +02:00
|
|
|
--- a/build.gradle.kts
|
|
|
|
+++ b/build.gradle.kts
|
2021-06-17 01:23:02 +02:00
|
|
|
@@ -21,7 +21,17 @@ repositories {
|
2021-06-12 12:26:21 +02:00
|
|
|
|
|
|
|
dependencies {
|
|
|
|
implementation(project(":Paper-API"))
|
|
|
|
- implementation("jline:jline:2.12.1")
|
|
|
|
+ // Paper start
|
|
|
|
+ implementation("org.jline:jline-terminal-jansi:3.12.1")
|
|
|
|
+ implementation("net.minecrell:terminalconsoleappender:1.2.0")
|
|
|
|
+ /*
|
2021-06-11 14:02:28 +02:00
|
|
|
+ Required to add the missing Log4j2Plugins.dat file from log4j-core
|
|
|
|
+ which has been removed by Mojang. Without it, log4j has to classload
|
|
|
|
+ all its classes to check if they are plugins.
|
|
|
|
+ Scanning takes about 1-2 seconds so adding this speeds up the server start.
|
2021-06-12 12:26:21 +02:00
|
|
|
+ */
|
|
|
|
+ runtimeOnly("org.apache.logging.log4j:log4j-core:2.14.1")
|
|
|
|
+ // Paper end
|
|
|
|
implementation("org.apache.logging.log4j:log4j-iostreams:2.14.1") // Paper
|
|
|
|
implementation("org.apache.logging.log4j:log4j-api:2.14.1") // Paper
|
|
|
|
implementation("org.apache.logging.log4j:log4j-slf4j-impl:2.14.1") // Paper
|
2021-06-11 14:02:28 +02:00
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/console/PaperConsole.java b/src/main/java/com/destroystokyo/paper/console/PaperConsole.java
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000000000000000000000000000000000000..a4070b59e261f0f1ac4beec47b11492f4724bf27
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/console/PaperConsole.java
|
|
|
|
@@ -0,0 +1,41 @@
|
|
|
|
+package com.destroystokyo.paper.console;
|
|
|
|
+
|
|
|
|
+import net.minecraft.server.dedicated.DedicatedServer;
|
|
|
|
+import net.minecrell.terminalconsole.SimpleTerminalConsole;
|
|
|
|
+import org.bukkit.craftbukkit.command.ConsoleCommandCompleter;
|
|
|
|
+import org.jline.reader.LineReader;
|
|
|
|
+import org.jline.reader.LineReaderBuilder;
|
|
|
|
+
|
|
|
|
+public final class PaperConsole extends SimpleTerminalConsole {
|
|
|
|
+
|
|
|
|
+ private final DedicatedServer server;
|
|
|
|
+
|
|
|
|
+ public PaperConsole(DedicatedServer server) {
|
|
|
|
+ this.server = server;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ protected LineReader buildReader(LineReaderBuilder builder) {
|
|
|
|
+ return super.buildReader(builder
|
|
|
|
+ .appName("Paper")
|
|
|
|
+ .variable(LineReader.HISTORY_FILE, java.nio.file.Paths.get(".console_history"))
|
|
|
|
+ .completer(new ConsoleCommandCompleter(this.server))
|
|
|
|
+ );
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ protected boolean isRunning() {
|
|
|
|
+ return !this.server.isStopped() && this.server.isRunning();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ protected void runCommand(String command) {
|
|
|
|
+ this.server.handleConsoleInput(command, this.server.createCommandSourceStack());
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ protected void shutdown() {
|
|
|
|
+ this.server.halt(false);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+}
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/console/TerminalConsoleCommandSender.java b/src/main/java/com/destroystokyo/paper/console/TerminalConsoleCommandSender.java
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000000000000000000000000000000000000..685deaa0e5d1ddc13e3a7c0471b1cfcf1710c869
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/console/TerminalConsoleCommandSender.java
|
|
|
|
@@ -0,0 +1,17 @@
|
|
|
|
+package com.destroystokyo.paper.console;
|
|
|
|
+
|
|
|
|
+import org.apache.logging.log4j.LogManager;
|
|
|
|
+import org.apache.logging.log4j.Logger;
|
|
|
|
+import org.bukkit.craftbukkit.command.CraftConsoleCommandSender;
|
|
|
|
+
|
|
|
|
+public class TerminalConsoleCommandSender extends CraftConsoleCommandSender {
|
|
|
|
+
|
|
|
|
+ private static final Logger LOGGER = LogManager.getRootLogger();
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void sendRawMessage(String message) {
|
|
|
|
+ // TerminalConsoleAppender supports color codes directly in log messages
|
|
|
|
+ LOGGER.info(message);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+}
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
2021-06-17 21:12:40 +02:00
|
|
|
index 84067073ebb9852fcca0c290b5ca916b099707f1..151d08104ed390905becda5f7ba16c8f933cd3d0 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
|
|
@@ -12,6 +12,7 @@ import com.mojang.datafixers.DataFixer;
|
|
|
|
import io.netty.buffer.ByteBuf;
|
|
|
|
import io.netty.buffer.ByteBufOutputStream;
|
|
|
|
import io.netty.buffer.Unpooled;
|
|
|
|
+import io.papermc.paper.adventure.PaperAdventure; // Paper
|
|
|
|
import it.unimi.dsi.fastutil.longs.LongIterator;
|
2021-06-12 12:26:21 +02:00
|
|
|
import java.awt.GraphicsEnvironment;
|
2021-06-11 14:02:28 +02:00
|
|
|
import java.awt.image.BufferedImage;
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -172,7 +173,7 @@ import org.apache.logging.log4j.Logger;
|
2021-06-11 14:02:28 +02:00
|
|
|
import com.mojang.serialization.DynamicOps;
|
|
|
|
import com.mojang.serialization.Lifecycle;
|
|
|
|
import com.google.common.collect.ImmutableSet;
|
|
|
|
-import jline.console.ConsoleReader;
|
|
|
|
+// import jline.console.ConsoleReader; // Paper
|
|
|
|
import joptsimple.OptionSet;
|
|
|
|
import net.minecraft.resources.RegistryReadOps;
|
|
|
|
import net.minecraft.server.bossevents.CustomBossEvents;
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -287,7 +288,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
2021-06-11 14:02:28 +02:00
|
|
|
public OptionSet options;
|
|
|
|
public org.bukkit.command.ConsoleCommandSender console;
|
|
|
|
public org.bukkit.command.RemoteConsoleCommandSender remoteConsole;
|
|
|
|
- public ConsoleReader reader;
|
|
|
|
+ //public ConsoleReader reader; // Paper
|
|
|
|
public static int currentTick = 0; // Paper - Further improve tick loop
|
|
|
|
public java.util.Queue<Runnable> processQueue = new java.util.concurrent.ConcurrentLinkedQueue<Runnable>();
|
|
|
|
public int autosavePeriod;
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -365,7 +366,9 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
2021-06-11 14:02:28 +02:00
|
|
|
this.options = options;
|
|
|
|
this.datapackconfiguration = datapackconfiguration;
|
|
|
|
this.vanillaCommandDispatcher = datapackresources.commands; // CraftBukkit
|
|
|
|
+ // Paper start - Handled by TerminalConsoleAppender
|
|
|
|
// Try to see if we're actually running in a terminal, disable jline if not
|
|
|
|
+ /*
|
|
|
|
if (System.console() == null && System.getProperty("jline.terminal") == null) {
|
|
|
|
System.setProperty("jline.terminal", "jline.UnsupportedTerminal");
|
|
|
|
Main.useJline = false;
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -386,6 +389,8 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
|
|
|
MinecraftServer.LOGGER.warn((String) null, ex);
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
+ */
|
|
|
|
+ // Paper end
|
|
|
|
Runtime.getRuntime().addShutdownHook(new org.bukkit.craftbukkit.util.ServerShutdownThread(this));
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
2021-06-13 07:13:07 +02:00
|
|
|
@@ -1160,7 +1165,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
2021-06-11 14:02:28 +02:00
|
|
|
org.spigotmc.WatchdogThread.doStop(); // Spigot
|
|
|
|
// CraftBukkit start - Restore terminal to original settings
|
|
|
|
try {
|
2021-06-12 12:26:21 +02:00
|
|
|
- this.reader.getTerminal().restore();
|
2021-06-11 14:02:28 +02:00
|
|
|
+ net.minecrell.terminalconsole.TerminalConsoleAppender.close(); // Paper - Use TerminalConsoleAppender
|
|
|
|
} catch (Exception ignored) {
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
2021-06-13 07:13:07 +02:00
|
|
|
@@ -1549,7 +1554,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
2021-06-11 14:02:28 +02:00
|
|
|
|
|
|
|
@Override
|
2021-06-12 12:26:21 +02:00
|
|
|
public void sendMessage(Component message, UUID sender) {
|
2021-06-11 14:02:28 +02:00
|
|
|
- MinecraftServer.LOGGER.info(message.getString());
|
|
|
|
+ MinecraftServer.LOGGER.info(PaperAdventure.LEGACY_SECTION_UXRC.serialize(PaperAdventure.asAdventure(message))); // Paper - Log message with colors
|
|
|
|
}
|
|
|
|
|
|
|
|
public KeyPair getKeyPair() {
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
2021-06-12 12:26:21 +02:00
|
|
|
index e2095308a8ec8471b04acce929d314fd828bc3de..45ae21718df16e16b5a3835a92afbf714959950e 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -108,6 +108,9 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
|
2021-06-11 14:02:28 +02:00
|
|
|
if (!org.bukkit.craftbukkit.Main.useConsole) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
+ // Paper start - Use TerminalConsoleAppender
|
|
|
|
+ new com.destroystokyo.paper.console.PaperConsole(DedicatedServer.this).start();
|
|
|
|
+ /*
|
|
|
|
jline.console.ConsoleReader bufferedreader = reader;
|
|
|
|
|
|
|
|
// MC-33041, SPIGOT-5538: if System.in is not valid due to javaw, then return
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -139,7 +142,7 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
|
2021-06-11 14:02:28 +02:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (s.trim().length() > 0) { // Trim to filter lines which are just spaces
|
|
|
|
- DedicatedServer.this.handleConsoleInput(s, DedicatedServer.this.createCommandSourceStack());
|
|
|
|
+ DedicatedServer.this.issueCommand(s, DedicatedServer.this.getServerCommandListener());
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
|
|
|
}
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -147,6 +150,8 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
|
2021-06-11 14:02:28 +02:00
|
|
|
DedicatedServer.LOGGER.error("Exception handling console input", ioexception);
|
|
|
|
}
|
|
|
|
|
|
|
|
+ */
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -158,6 +163,9 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
global.addHandler(new org.bukkit.craftbukkit.util.ForwardLogHandler());
|
|
|
|
|
|
|
|
+ // Paper start - Not needed with TerminalConsoleAppender
|
|
|
|
+ final org.apache.logging.log4j.Logger logger = LogManager.getRootLogger();
|
|
|
|
+ /*
|
|
|
|
final org.apache.logging.log4j.core.Logger logger = ((org.apache.logging.log4j.core.Logger) LogManager.getRootLogger());
|
|
|
|
for (org.apache.logging.log4j.core.Appender appender : logger.getAppenders().values()) {
|
|
|
|
if (appender instanceof org.apache.logging.log4j.core.appender.ConsoleAppender) {
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -166,6 +174,8 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
new org.bukkit.craftbukkit.util.TerminalConsoleWriterThread(System.out, this.reader).start();
|
|
|
|
+ */
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
System.setOut(IoBuilder.forLogger(logger).setLevel(Level.INFO).buildPrintStream());
|
|
|
|
System.setErr(IoBuilder.forLogger(logger).setLevel(Level.WARN).buildPrintStream());
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/players/PlayerList.java b/src/main/java/net/minecraft/server/players/PlayerList.java
|
2021-06-12 12:26:21 +02:00
|
|
|
index 79ebb15bed6eec80c12c1020b2b6b07c758332aa..bf6c3ac7ae37067f345568fb6656cf6b4d864be2 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/players/PlayerList.java
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -151,8 +151,7 @@ public abstract class PlayerList {
|
2021-06-11 14:02:28 +02:00
|
|
|
|
|
|
|
public PlayerList(MinecraftServer server, RegistryAccess.RegistryHolder registryManager, PlayerDataStorage saveHandler, int maxPlayers) {
|
|
|
|
this.cserver = server.server = new CraftServer((DedicatedServer) server, this);
|
|
|
|
- server.console = org.bukkit.craftbukkit.command.ColouredConsoleSender.getInstance();
|
|
|
|
- server.reader.addCompleter(new org.bukkit.craftbukkit.command.ConsoleCommandCompleter(server.server));
|
|
|
|
+ server.console = new com.destroystokyo.paper.console.TerminalConsoleCommandSender(); // Paper
|
|
|
|
// CraftBukkit end
|
|
|
|
|
|
|
|
this.bans = new UserBanList(PlayerList.USERBANLIST_FILE);
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
2021-06-15 10:38:57 +02:00
|
|
|
index 8bd458b8995c9019b5ae85eab062df44e9424703..79fe58b09c9e0870a5ab55bc21b8ab933450a1d7 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
|
|
|
@@ -46,7 +46,6 @@ import java.util.function.Consumer;
|
|
|
|
import java.util.logging.Level;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
import javax.imageio.ImageIO;
|
|
|
|
-import jline.console.ConsoleReader;
|
|
|
|
import net.minecraft.advancements.Advancement;
|
|
|
|
import net.minecraft.commands.CommandSourceStack;
|
|
|
|
import net.minecraft.commands.Commands;
|
|
|
|
@@ -60,6 +59,7 @@ import net.minecraft.resources.RegistryReadOps;
|
|
|
|
import net.minecraft.resources.ResourceKey;
|
|
|
|
import net.minecraft.resources.ResourceLocation;
|
|
|
|
import net.minecraft.server.ConsoleInput;
|
|
|
|
+//import jline.console.ConsoleReader; // Paper
|
|
|
|
import net.minecraft.server.MinecraftServer;
|
|
|
|
import net.minecraft.server.bossevents.CustomBossEvent;
|
|
|
|
import net.minecraft.server.commands.ReloadCommand;
|
2021-06-15 10:38:57 +02:00
|
|
|
@@ -1204,9 +1204,13 @@ public final class CraftServer implements Server {
|
2021-06-12 12:26:21 +02:00
|
|
|
return this.logger;
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start - JLine update
|
|
|
|
+ /*
|
|
|
|
public ConsoleReader getReader() {
|
|
|
|
return console.reader;
|
|
|
|
}
|
|
|
|
+ */
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public PluginCommand getPluginCommand(String name) {
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/Main.java b/src/main/java/org/bukkit/craftbukkit/Main.java
|
2021-06-17 21:12:40 +02:00
|
|
|
index 213ff112be27f02c3742265cea6478a6f8130c99..787db22e4d7df30ccf3d92297fbd2f08ff87beb5 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/Main.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/Main.java
|
|
|
|
@@ -12,7 +12,7 @@ import java.util.logging.Level;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
import joptsimple.OptionParser;
|
|
|
|
import joptsimple.OptionSet;
|
|
|
|
-import org.fusesource.jansi.AnsiConsole;
|
|
|
|
+import net.minecrell.terminalconsole.TerminalConsoleAppender; // Paper
|
|
|
|
|
|
|
|
public class Main {
|
|
|
|
public static boolean useJline = true;
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -189,6 +189,8 @@ public class Main {
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
+ // Paper start - Handled by TerminalConsoleAppender
|
|
|
|
+ /*
|
|
|
|
// This trick bypasses Maven Shade's clever rewriting of our getProperty call when using String literals
|
|
|
|
String jline_UnsupportedTerminal = new String(new char[]{'j', 'l', 'i', 'n', 'e', '.', 'U', 'n', 's', 'u', 'p', 'p', 'o', 'r', 't', 'e', 'd', 'T', 'e', 'r', 'm', 'i', 'n', 'a', 'l'});
|
|
|
|
String jline_terminal = new String(new char[]{'j', 'l', 'i', 'n', 'e', '.', 't', 'e', 'r', 'm', 'i', 'n', 'a', 'l'});
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -206,9 +208,18 @@ public class Main {
|
2021-06-11 14:02:28 +02:00
|
|
|
// This ensures the terminal literal will always match the jline implementation
|
|
|
|
System.setProperty(jline.TerminalFactory.JLINE_TERMINAL, jline.UnsupportedTerminal.class.getName());
|
|
|
|
}
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+ if (options.has("nojline")) {
|
|
|
|
+ System.setProperty(TerminalConsoleAppender.JLINE_OVERRIDE_PROPERTY, "false");
|
|
|
|
+ useJline = false;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
if (options.has("noconsole")) {
|
2021-06-12 12:26:21 +02:00
|
|
|
Main.useConsole = false;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ useJline = false; // Paper
|
|
|
|
+ System.setProperty(TerminalConsoleAppender.JLINE_OVERRIDE_PROPERTY, "false"); // Paper
|
|
|
|
}
|
|
|
|
|
2021-06-12 12:26:21 +02:00
|
|
|
if (Main.class.getPackage().getImplementationVendor() != null && System.getProperty("IReallyKnowWhatIAmDoingISwear") == null) {
|
|
|
|
@@ -236,7 +247,7 @@ public class Main {
|
2021-06-11 14:02:28 +02:00
|
|
|
System.out.println("Unable to read system info");
|
|
|
|
}
|
|
|
|
// Paper end
|
|
|
|
-
|
|
|
|
+ System.setProperty( "library.jansi.version", "Paper" ); // Paper - set meaningless jansi version to prevent git builds from crashing on Windows
|
|
|
|
System.out.println("Loading libraries, please wait...");
|
|
|
|
net.minecraft.server.Main.main(options);
|
|
|
|
} catch (Throwable t) {
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/command/ColouredConsoleSender.java b/src/main/java/org/bukkit/craftbukkit/command/ColouredConsoleSender.java
|
2021-06-12 12:26:21 +02:00
|
|
|
index 76fb1ecd47cb86b50486effe8cc7fe4abf8e311c..21f889ddec72b40f5954eec07417e08d192b4661 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/command/ColouredConsoleSender.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/command/ColouredConsoleSender.java
|
|
|
|
@@ -5,15 +5,13 @@ import java.util.EnumMap;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.regex.Matcher;
|
|
|
|
import java.util.regex.Pattern;
|
|
|
|
-import jline.Terminal;
|
|
|
|
+//import jline.Terminal;
|
|
|
|
import org.bukkit.Bukkit;
|
|
|
|
import org.bukkit.ChatColor;
|
|
|
|
import org.bukkit.command.ConsoleCommandSender;
|
|
|
|
import org.bukkit.craftbukkit.CraftServer;
|
|
|
|
-import org.fusesource.jansi.Ansi;
|
|
|
|
-import org.fusesource.jansi.Ansi.Attribute;
|
|
|
|
|
|
|
|
-public class ColouredConsoleSender extends CraftConsoleCommandSender {
|
|
|
|
+public class ColouredConsoleSender /*extends CraftConsoleCommandSender */{/* // Paper - disable
|
|
|
|
private final Terminal terminal;
|
|
|
|
private final Map<ChatColor, String> replacements = new EnumMap<ChatColor, String>(ChatColor.class);
|
|
|
|
private final ChatColor[] colors = ChatColor.values();
|
|
|
|
@@ -93,5 +91,5 @@ public class ColouredConsoleSender extends CraftConsoleCommandSender {
|
|
|
|
} else {
|
|
|
|
return new ColouredConsoleSender();
|
|
|
|
}
|
|
|
|
- }
|
|
|
|
+ }*/ // Paper
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java b/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java
|
2021-06-12 12:26:21 +02:00
|
|
|
index 0b4c62387c1093652ac15b64a8703249de4cf088..b996fde481cebbbcce80a6c267591136db7cc0bc 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/command/ConsoleCommandCompleter.java
|
2021-06-12 12:26:21 +02:00
|
|
|
@@ -4,50 +4,73 @@ import java.util.Collections;
|
2021-06-11 14:02:28 +02:00
|
|
|
import java.util.List;
|
|
|
|
import java.util.concurrent.ExecutionException;
|
|
|
|
import java.util.logging.Level;
|
|
|
|
-import jline.console.completer.Completer;
|
|
|
|
+import net.minecraft.server.dedicated.DedicatedServer;
|
|
|
|
import org.bukkit.craftbukkit.CraftServer;
|
|
|
|
import org.bukkit.craftbukkit.util.Waitable;
|
|
|
|
+
|
|
|
|
+// Paper start - JLine update
|
|
|
|
+import org.jline.reader.Candidate;
|
|
|
|
+import org.jline.reader.Completer;
|
|
|
|
+import org.jline.reader.LineReader;
|
|
|
|
+import org.jline.reader.ParsedLine;
|
|
|
|
+// Paper end
|
|
|
|
import org.bukkit.event.server.TabCompleteEvent;
|
|
|
|
|
|
|
|
public class ConsoleCommandCompleter implements Completer {
|
|
|
|
- private final CraftServer server;
|
|
|
|
+ private final DedicatedServer server; // Paper - CraftServer -> DedicatedServer
|
|
|
|
|
|
|
|
- public ConsoleCommandCompleter(CraftServer server) {
|
|
|
|
+ public ConsoleCommandCompleter(DedicatedServer server) { // Paper - CraftServer -> DedicatedServer
|
|
|
|
this.server = server;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start - Change method signature for JLine update
|
|
|
|
@Override
|
|
|
|
- public int complete(final String buffer, final int cursor, final List<CharSequence> candidates) {
|
|
|
|
+ public void complete(LineReader reader, ParsedLine line, List<Candidate> candidates) {
|
|
|
|
+ final CraftServer server = this.server.server;
|
|
|
|
+ final String buffer = line.line();
|
|
|
|
+ // Paper end
|
|
|
|
Waitable<List<String>> waitable = new Waitable<List<String>>() {
|
|
|
|
@Override
|
|
|
|
protected List<String> evaluate() {
|
2021-06-12 12:26:21 +02:00
|
|
|
- List<String> offers = ConsoleCommandCompleter.this.server.getCommandMap().tabComplete(ConsoleCommandCompleter.this.server.getConsoleSender(), buffer);
|
|
|
|
+ List<String> offers = server.getCommandMap().tabComplete(server.getConsoleSender(), buffer); // Paper - fix remap
|
|
|
|
|
|
|
|
- TabCompleteEvent tabEvent = new TabCompleteEvent(ConsoleCommandCompleter.this.server.getConsoleSender(), buffer, (offers == null) ? Collections.EMPTY_LIST : offers);
|
|
|
|
- ConsoleCommandCompleter.this.server.getPluginManager().callEvent(tabEvent);
|
|
|
|
+ TabCompleteEvent tabEvent = new TabCompleteEvent(server.getConsoleSender(), buffer, (offers == null) ? Collections.EMPTY_LIST : offers); // Paper - fix remap
|
|
|
|
+ server.getPluginManager().callEvent(tabEvent); // Paper - fix remap
|
|
|
|
|
2021-06-11 14:02:28 +02:00
|
|
|
return tabEvent.isCancelled() ? Collections.EMPTY_LIST : tabEvent.getCompletions();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
- this.server.getServer().processQueue.add(waitable);
|
|
|
|
+ server.getServer().processQueue.add(waitable); // Paper - Remove "this."
|
|
|
|
try {
|
|
|
|
List<String> offers = waitable.get();
|
|
|
|
if (offers == null) {
|
|
|
|
- return cursor;
|
|
|
|
+ return; // Paper - Method returns void
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // Paper start - JLine update
|
|
|
|
+ for (String completion : offers) {
|
|
|
|
+ if (completion.isEmpty()) {
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ candidates.add(new Candidate(completion));
|
|
|
|
}
|
|
|
|
- candidates.addAll(offers);
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
+ // Paper start - JLine handles cursor now
|
|
|
|
+ /*
|
|
|
|
final int lastSpace = buffer.lastIndexOf(' ');
|
|
|
|
if (lastSpace == -1) {
|
|
|
|
return cursor - buffer.length();
|
|
|
|
} else {
|
|
|
|
return cursor - (buffer.length() - lastSpace - 1);
|
|
|
|
}
|
|
|
|
+ */
|
|
|
|
+ // Paper end
|
|
|
|
} catch (ExecutionException e) {
|
|
|
|
- this.server.getLogger().log(Level.WARNING, "Unhandled exception when tab completing", e);
|
|
|
|
+ server.getLogger().log(Level.WARNING, "Unhandled exception when tab completing", e); // Paper - Remove "this."
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
Thread.currentThread().interrupt();
|
|
|
|
}
|
|
|
|
- return cursor;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/util/ServerShutdownThread.java b/src/main/java/org/bukkit/craftbukkit/util/ServerShutdownThread.java
|
2021-06-12 12:26:21 +02:00
|
|
|
index 6a073a9dc44d93eba296a0e18a9c7be8a7881725..b4a19d80bbf71591f25729fd0e98590350cb31d0 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/util/ServerShutdownThread.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/util/ServerShutdownThread.java
|
|
|
|
@@ -17,7 +17,7 @@ public class ServerShutdownThread extends Thread {
|
2021-06-12 12:26:21 +02:00
|
|
|
this.server.close();
|
2021-06-11 14:02:28 +02:00
|
|
|
} finally {
|
|
|
|
try {
|
|
|
|
- server.reader.getTerminal().restore();
|
|
|
|
+ net.minecrell.terminalconsole.TerminalConsoleAppender.close(); // Paper - Use TerminalConsoleAppender
|
|
|
|
} catch (Exception e) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/util/TerminalConsoleWriterThread.java b/src/main/java/org/bukkit/craftbukkit/util/TerminalConsoleWriterThread.java
|
2021-06-12 12:26:21 +02:00
|
|
|
index 5b63604aeae9a54e2c61cc4a22115a72f34a56bd..fc07f6bd45712ec0f1aec5fe820034e6d54b39c1 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/util/TerminalConsoleWriterThread.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/util/TerminalConsoleWriterThread.java
|
|
|
|
@@ -5,12 +5,12 @@ import java.io.IOException;
|
|
|
|
import java.io.OutputStream;
|
|
|
|
import java.util.logging.Level;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
-import jline.console.ConsoleReader;
|
|
|
|
+//import jline.console.ConsoleReader;
|
|
|
|
import org.bukkit.craftbukkit.Main;
|
|
|
|
-import org.fusesource.jansi.Ansi;
|
|
|
|
-import org.fusesource.jansi.Ansi.Erase;
|
|
|
|
+//import org.fusesource.jansi.Ansi;
|
|
|
|
+//import org.fusesource.jansi.Ansi.Erase;
|
|
|
|
|
|
|
|
-public class TerminalConsoleWriterThread extends Thread {
|
|
|
|
+public class TerminalConsoleWriterThread /*extends Thread*/ {/* // Paper - disable
|
|
|
|
private final ConsoleReader reader;
|
|
|
|
private final OutputStream output;
|
|
|
|
|
|
|
|
@@ -54,5 +54,5 @@ public class TerminalConsoleWriterThread extends Thread {
|
|
|
|
Logger.getLogger(TerminalConsoleWriterThread.class.getName()).log(Level.SEVERE, null, ex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
- }
|
|
|
|
+ }*/
|
|
|
|
}
|
|
|
|
diff --git a/src/main/resources/log4j2.component.properties b/src/main/resources/log4j2.component.properties
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000000000000000000000000000000000000..0694b21465fb9e4164e71862ff24b62241b191f2
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/resources/log4j2.component.properties
|
|
|
|
@@ -0,0 +1 @@
|
|
|
|
+log4j.skipJansi=true
|
|
|
|
diff --git a/src/main/resources/log4j2.xml b/src/main/resources/log4j2.xml
|
|
|
|
index 722ca84968cbbbdeffd09939abff0cccd0a84010..620b9490e5f159080e50289d127404a1b56adbef 100644
|
|
|
|
--- a/src/main/resources/log4j2.xml
|
|
|
|
+++ b/src/main/resources/log4j2.xml
|
|
|
|
@@ -1,17 +1,14 @@
|
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
|
<Configuration status="WARN" packages="com.mojang.util">
|
|
|
|
<Appenders>
|
|
|
|
- <Console name="SysOut" target="SYSTEM_OUT">
|
|
|
|
- <PatternLayout pattern="[%d{HH:mm:ss}] [%t/%level]: %msg%n" />
|
|
|
|
- </Console>
|
|
|
|
<Queue name="ServerGuiConsole">
|
|
|
|
<PatternLayout pattern="[%d{HH:mm:ss} %level]: %msg%n" />
|
|
|
|
</Queue>
|
|
|
|
- <Queue name="TerminalConsole">
|
|
|
|
- <PatternLayout pattern="[%d{HH:mm:ss}] [%t/%level]: %msg%n" />
|
|
|
|
- </Queue>
|
|
|
|
+ <TerminalConsole name="TerminalConsole">
|
|
|
|
+ <PatternLayout pattern="%highlightError{[%d{HH:mm:ss} %level]: %minecraftFormatting{%msg}%n%xEx}" />
|
|
|
|
+ </TerminalConsole>
|
|
|
|
<RollingRandomAccessFile name="File" fileName="logs/latest.log" filePattern="logs/%d{yyyy-MM-dd}-%i.log.gz">
|
|
|
|
- <PatternLayout pattern="[%d{HH:mm:ss}] [%t/%level]: %msg%n" />
|
|
|
|
+ <PatternLayout pattern="[%d{HH:mm:ss}] [%t/%level]: %minecraftFormatting{%msg}{strip}%n" />
|
|
|
|
<Policies>
|
|
|
|
<TimeBasedTriggeringPolicy />
|
|
|
|
<OnStartupTriggeringPolicy />
|
|
|
|
@@ -24,10 +21,9 @@
|
|
|
|
<filters>
|
|
|
|
<MarkerFilter marker="NETWORK_PACKETS" onMatch="DENY" onMismatch="NEUTRAL" />
|
|
|
|
</filters>
|
|
|
|
- <AppenderRef ref="SysOut" level="info"/>
|
|
|
|
<AppenderRef ref="File"/>
|
|
|
|
- <AppenderRef ref="ServerGuiConsole" level="info"/>
|
|
|
|
<AppenderRef ref="TerminalConsole" level="info"/>
|
|
|
|
+ <AppenderRef ref="ServerGuiConsole" level="info"/>
|
|
|
|
</Root>
|
|
|
|
</Loggers>
|
|
|
|
</Configuration>
|