mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 13:57:35 +01:00
Sync chunk load command improvements (#8554)
This commit is contained in:
parent
7ad5dcb810
commit
f07cda9bb9
@ -231,9 +231,14 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import java.io.FileOutputStream;
|
+import java.io.FileOutputStream;
|
||||||
+import java.io.PrintStream;
|
+import java.io.PrintStream;
|
||||||
+import java.io.StringWriter;
|
+import java.io.StringWriter;
|
||||||
|
+import java.nio.charset.StandardCharsets;
|
||||||
+import java.time.LocalDateTime;
|
+import java.time.LocalDateTime;
|
||||||
+import java.time.format.DateTimeFormatter;
|
+import java.time.format.DateTimeFormatter;
|
||||||
+import java.util.List;
|
+import java.util.List;
|
||||||
|
+
|
||||||
|
+import net.kyori.adventure.text.event.ClickEvent;
|
||||||
|
+import net.kyori.adventure.text.event.HoverEvent;
|
||||||
|
+import net.minecraft.server.MinecraftServer;
|
||||||
+import org.bukkit.command.CommandSender;
|
+import org.bukkit.command.CommandSender;
|
||||||
+import org.checkerframework.checker.nullness.qual.NonNull;
|
+import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
+import org.checkerframework.framework.qual.DefaultQualifier;
|
+import org.checkerframework.framework.qual.DefaultQualifier;
|
||||||
@ -242,6 +247,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import static net.kyori.adventure.text.format.NamedTextColor.GRAY;
|
+import static net.kyori.adventure.text.format.NamedTextColor.GRAY;
|
||||||
+import static net.kyori.adventure.text.format.NamedTextColor.GREEN;
|
+import static net.kyori.adventure.text.format.NamedTextColor.GREEN;
|
||||||
+import static net.kyori.adventure.text.format.NamedTextColor.RED;
|
+import static net.kyori.adventure.text.format.NamedTextColor.RED;
|
||||||
|
+import static net.kyori.adventure.text.format.NamedTextColor.WHITE;
|
||||||
+
|
+
|
||||||
+@DefaultQualifier(NonNull.class)
|
+@DefaultQualifier(NonNull.class)
|
||||||
+public final class SyncLoadInfoCommand implements PaperSubcommand {
|
+public final class SyncLoadInfoCommand implements PaperSubcommand {
|
||||||
@ -256,9 +262,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ return CommandUtil.getListMatchingLast(sender, args, "clear");
|
+ return CommandUtil.getListMatchingLast(sender, args, "clear");
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ private static final DateTimeFormatter FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM-dd_HH.mm.ss");
|
||||||
|
+
|
||||||
+ private void doSyncLoadInfo(final CommandSender sender, final String[] args) {
|
+ private void doSyncLoadInfo(final CommandSender sender, final String[] args) {
|
||||||
+ if (!SyncLoadFinder.ENABLED) {
|
+ if (!SyncLoadFinder.ENABLED) {
|
||||||
+ sender.sendMessage(text("This command requires the server startup flag '-Dpaper.debug-sync-loads=true' to be set.", RED));
|
+ String systemFlag = "-Dpaper.debug-sync-loads=true";
|
||||||
|
+ sender.sendMessage(text().color(RED).append(text("This command requires the server startup flag '")).append(
|
||||||
|
+ text(systemFlag, WHITE).clickEvent(ClickEvent.copyToClipboard(systemFlag))
|
||||||
|
+ .hoverEvent(HoverEvent.showText(text("Click to copy the system flag")))).append(
|
||||||
|
+ text("' to be set.")));
|
||||||
+ return;
|
+ return;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
@ -269,7 +281,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ File file = new File(new File(new File("."), "debug"),
|
+ File file = new File(new File(new File("."), "debug"),
|
||||||
+ "sync-load-info" + DateTimeFormatter.ofPattern("yyyy-MM-dd_HH.mm.ss").format(LocalDateTime.now()) + ".txt");
|
+ "sync-load-info" + FORMATTER.format(LocalDateTime.now()) + ".txt");
|
||||||
+ file.getParentFile().mkdirs();
|
+ file.getParentFile().mkdirs();
|
||||||
+ sender.sendMessage(text("Writing sync load info to " + file, GREEN));
|
+ sender.sendMessage(text("Writing sync load info to " + file, GREEN));
|
||||||
+
|
+
|
||||||
@ -283,17 +295,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ jsonWriter.setLenient(false);
|
+ jsonWriter.setLenient(false);
|
||||||
+ Streams.write(data, jsonWriter);
|
+ Streams.write(data, jsonWriter);
|
||||||
+
|
+
|
||||||
+ String fileData = stringWriter.toString();
|
|
||||||
+
|
|
||||||
+ try (
|
+ try (
|
||||||
+ PrintStream out = new PrintStream(new FileOutputStream(file), false, "UTF-8")
|
+ PrintStream out = new PrintStream(new FileOutputStream(file), false, StandardCharsets.UTF_8)
|
||||||
+ ) {
|
+ ) {
|
||||||
+ out.print(fileData);
|
+ out.print(stringWriter);
|
||||||
+ }
|
+ }
|
||||||
+ sender.sendMessage(text("Successfully written sync load information!", GREEN));
|
+ sender.sendMessage(text("Successfully written sync load information!", GREEN));
|
||||||
+ } catch (Throwable thr) {
|
+ } catch (Throwable thr) {
|
||||||
+ sender.sendMessage(text("Failed to write sync load information!", RED));
|
+ sender.sendMessage(text("Failed to write sync load information! See the console for more info.", RED));
|
||||||
+ thr.printStackTrace();
|
+ MinecraftServer.LOGGER.warn("Error occurred while dumping sync chunk load info", thr);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
|
Loading…
Reference in New Issue
Block a user