package gregtech.common.misc; import gregtech.api.enums.GT_Values; import gregtech.api.objects.GT_ChunkManager; import net.minecraft.command.CommandBase; import net.minecraft.command.ICommandSender; import net.minecraft.command.WrongUsageException; import net.minecraft.util.ChatComponentText; import java.lang.reflect.Field; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.stream.Stream; public final class GT_Command extends CommandBase { @Override public String getCommandName() { return "gt"; } @Override public String getCommandUsage(ICommandSender sender) { return "Usage: gt . Valid subcommands are: toggle, chunks."; } private void printHelp(ICommandSender sender) { sender.addChatMessage(new ChatComponentText("Usage: gt ")); sender.addChatMessage(new ChatComponentText("\"toggle D1\" - toggles general.Debug (D1)")); sender.addChatMessage(new ChatComponentText("\"toggle D2\" - toggles general.Debug2 (D2)")); sender.addChatMessage(new ChatComponentText("\"toggle debugCleanroom\" - toggles cleanroom debug log")); sender.addChatMessage(new ChatComponentText("\"toggle debugDriller\" - toggles oil drill debug log")); sender.addChatMessage(new ChatComponentText("\"toggle debugBlockPump\" - Possible issues with pumps")); sender.addChatMessage(new ChatComponentText("\"toggle debugBlockMiner\" - Possible issues with miners")); sender.addChatMessage(new ChatComponentText("\"toggle debugEntityCramming\" - How long it takes and how many entities it finds")); sender.addChatMessage(new ChatComponentText("\"toggle debugWorldGen\" - toggles generic worldgen debug")); sender.addChatMessage(new ChatComponentText("\"toggle debugOrevein\" - toggles worldgen ore vein debug")); sender.addChatMessage(new ChatComponentText("\"toggle debugSmallOres\" - toggles worldgen small vein debug")); sender.addChatMessage(new ChatComponentText("\"toggle debugStones\" - toggles worldgen stones debug")); sender.addChatMessage(new ChatComponentText("\"toggle debugChunkloaders\" - toggles chunkloaders debug")); sender.addChatMessage(new ChatComponentText("\"chunks\" - print a list of the force loaded chunks")); } @Override public List addTabCompletionOptions(ICommandSender sender, String[] ss) { List l = new ArrayList<>(); Stream keywords = Arrays.stream(new String[]{"toggle", "chunks"}); String test = ss.length == 0 ? "" : ss[0].trim(); if (ss.length == 0 || ss.length == 1 && (test.isEmpty() || keywords.anyMatch(s -> s.startsWith(test)))) { keywords.forEach(s -> { if (test.isEmpty() || s.startsWith(test)) l.add(s); }); } else if (test.equals("toggle")) { String test1 = ss.length == 1 ? "" : ss[1].trim(); Arrays.stream(new String[]{"D1", "D2", "debugCleanroom", "debugDriller", "debugBlockPump", "debugBlockMiner", "debugWorldGen", "debugEntityCramming", "debugOrevein", "debugSmallOres", "debugStones", "debugChunkloaders"}).forEach(s -> { if (test1.isEmpty() || s.startsWith(test1)) l.add(s); }); } return l; } @Override public void processCommand(ICommandSender sender, String[] strings) { if (strings.length < 1 || (!strings[0].equals("toggle") && !strings[0].equals("chunks"))) { printHelp(sender); return; } switch (strings[0]) { case "toggle": if (strings.length < 2) { printHelp(sender); return; } try { Field field = GT_Values.class.getDeclaredField(strings[1]); if (field.getType() != boolean.class) { sender.addChatMessage(new ChatComponentText("Wrong variable: " + strings[1])); return; } boolean b = !field.getBoolean(null); field.setBoolean(null, b); sender.addChatMessage(new ChatComponentText(strings[1] + " = " + (b ? "true" : "false"))); } catch (Exception e) { sender.addChatMessage(new ChatComponentText("No such variable: " + strings[0])); } break; case "chunks": GT_ChunkManager.printTickets(); sender.addChatMessage(new ChatComponentText("Forced chunks logged to GregTech.log")); break; } } }