Sync chunk load command improvements (#8554)

This commit is contained in:
Lulu13022002 2022-11-19 20:10:13 +01:00
parent 7ad5dcb810
commit f07cda9bb9

View File

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