mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-11-04 03:03:43 +01:00 
			
		
		
		
	fix regenallroads and made performance improvements to trim
This commit is contained in:
		@@ -21,6 +21,9 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
package com.intellectualcrafters.plot.commands;
 | 
					package com.intellectualcrafters.plot.commands;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.io.File;
 | 
				
			||||||
 | 
					import java.io.FileNotFoundException;
 | 
				
			||||||
 | 
					import java.io.PrintWriter;
 | 
				
			||||||
import java.sql.Timestamp;
 | 
					import java.sql.Timestamp;
 | 
				
			||||||
import java.util.ArrayList;
 | 
					import java.util.ArrayList;
 | 
				
			||||||
import java.util.Arrays;
 | 
					import java.util.Arrays;
 | 
				
			||||||
@@ -43,6 +46,7 @@ import com.intellectualcrafters.plot.util.ChunkManager;
 | 
				
			|||||||
import com.intellectualcrafters.plot.util.ExpireManager;
 | 
					import com.intellectualcrafters.plot.util.ExpireManager;
 | 
				
			||||||
import com.intellectualcrafters.plot.util.PlayerFunctions;
 | 
					import com.intellectualcrafters.plot.util.PlayerFunctions;
 | 
				
			||||||
import com.intellectualcrafters.plot.util.UUIDHandler;
 | 
					import com.intellectualcrafters.plot.util.UUIDHandler;
 | 
				
			||||||
 | 
					import com.sk89q.worldedit.regions.Region;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class DebugExec extends SubCommand {
 | 
					public class DebugExec extends SubCommand {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -127,53 +131,46 @@ public class DebugExec extends SubCommand {
 | 
				
			|||||||
	        	    PlayerFunctions.sendMessage(null, "Local: " + date.toLocaleString());
 | 
						        	    PlayerFunctions.sendMessage(null, "Local: " + date.toLocaleString());
 | 
				
			||||||
	        	    return true;
 | 
						        	    return true;
 | 
				
			||||||
	        	}
 | 
						        	}
 | 
				
			||||||
	        	case "trim-get-chunks": {
 | 
						        	case "trim-check": {
 | 
				
			||||||
	        	    if (args.length != 2) {
 | 
						        	    if (args.length != 2) {
 | 
				
			||||||
	        	        PlayerFunctions.sendMessage(null, "Use /plot debugexec trim-get-chunks <world>");
 | 
						        	        PlayerFunctions.sendMessage(null, "Use /plot debugexec trim-get-chunks <world>");
 | 
				
			||||||
	        	        PlayerFunctions.sendMessage(null, "&7 - Generates a list of regions to trim");
 | 
						        	        PlayerFunctions.sendMessage(null, "&7 - Generates a list of regions to trim");
 | 
				
			||||||
	        	        return PlayerFunctions.sendMessage(null, "&7 - Run after plot expiry has run");
 | 
						        	        return PlayerFunctions.sendMessage(null, "&7 - Run after plot expiry has run");
 | 
				
			||||||
	        	    }
 | 
						        	    }
 | 
				
			||||||
	        	    World world = Bukkit.getWorld(args[1]);
 | 
						        	    final World world = Bukkit.getWorld(args[1]);
 | 
				
			||||||
	        	    if (world == null || !PlotMain.isPlotWorld(args[1])) {
 | 
						        	    if (world == null || !PlotMain.isPlotWorld(args[1])) {
 | 
				
			||||||
                        return PlayerFunctions.sendMessage(null, "Invalid world: "+args[1]);
 | 
					                        return PlayerFunctions.sendMessage(null, "Invalid world: "+args[1]);
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
	        	    ArrayList<ChunkLoc> chunks0 = Trim.getTrimChunks(world);
 | 
						        	    final ArrayList<ChunkLoc> empty = new ArrayList<>();
 | 
				
			||||||
	        	    PlayerFunctions.sendMessage(null, "BULK MCR: " + chunks0.size());
 | 
						        	    Trim.getTrimRegions(empty, world, new Runnable() {
 | 
				
			||||||
	        	    ArrayList<ChunkLoc> chunks = Trim.getTrimPlots(world);
 | 
					                        @Override
 | 
				
			||||||
	        	    chunks.addAll(chunks0);
 | 
					                        public void run() {
 | 
				
			||||||
	        	    this.chunks = chunks;
 | 
					                            Trim.sendMessage("Processing is complete! Here's how many chunks would be deleted:");
 | 
				
			||||||
	        	    this.world = world;
 | 
					                            Trim.sendMessage(" - MCA #: " + empty.size());
 | 
				
			||||||
	        	    PlayerFunctions.sendMessage(null, "MCR: " + chunks.size());
 | 
					                            Trim.sendMessage(" - CHUNKS: " + (empty.size() * 256) + " (max)");
 | 
				
			||||||
	        	    PlayerFunctions.sendMessage(null, "CHUNKS: " + chunks.size() * 256);
 | 
					                            Trim.sendMessage("Exporting log for manual approval...");
 | 
				
			||||||
	        	    PlayerFunctions.sendMessage(null, "Calculating size on disk...");
 | 
					                            final File file = new File(PlotMain.getMain().getDataFolder() + File.separator + "trim.txt");
 | 
				
			||||||
	        	    PlayerFunctions.sendMessage(null, "SIZE (bytes): " + Trim.calculateSizeOnDisk(world, chunks));
 | 
					                            PrintWriter writer;
 | 
				
			||||||
 | 
					                            try {
 | 
				
			||||||
 | 
					                                writer = new PrintWriter(file);
 | 
				
			||||||
 | 
					                                String worldname = world.getName();
 | 
				
			||||||
 | 
					                                for (ChunkLoc loc : empty) {
 | 
				
			||||||
 | 
					                                    writer.println(worldname +"/region/r." + loc.x + "." + loc.z +".mca" );
 | 
				
			||||||
 | 
					                                }
 | 
				
			||||||
 | 
					                                writer.close();
 | 
				
			||||||
 | 
					                                Trim.sendMessage("File saved");
 | 
				
			||||||
 | 
					                            } catch (FileNotFoundException e) {
 | 
				
			||||||
 | 
					                                e.printStackTrace();
 | 
				
			||||||
 | 
					                                Trim.sendMessage("File failed to save! :(");
 | 
				
			||||||
 | 
					                            }
 | 
				
			||||||
 | 
					                            Trim.sendMessage("How to get the chunk coords from a region file:");
 | 
				
			||||||
 | 
					                            Trim.sendMessage(" - Locate the x,z values for the region file (the two numbers which are separated by a dot)");
 | 
				
			||||||
 | 
					                            Trim.sendMessage(" - Multiply each number by 32; this gives you the starting position");
 | 
				
			||||||
 | 
					                            Trim.sendMessage(" - Add 31 to each number to get the end position");
 | 
				
			||||||
 | 
					                        }
 | 
				
			||||||
 | 
					                    });
 | 
				
			||||||
	        	    return true;
 | 
						        	    return true;
 | 
				
			||||||
	        	}
 | 
						        	}
 | 
				
			||||||
	        	case "trim-check-chunks": {
 | 
					 | 
				
			||||||
	        	    if (this.chunks == null) {
 | 
					 | 
				
			||||||
	        	        return PlayerFunctions.sendMessage(null, "Please run the 'trim-get-chunks' command first");
 | 
					 | 
				
			||||||
	        	    }
 | 
					 | 
				
			||||||
	        	    
 | 
					 | 
				
			||||||
	        	    PlayerFunctions.sendMessage(null, "Checking MCR files for existing plots:");
 | 
					 | 
				
			||||||
	        	    int count = 0;
 | 
					 | 
				
			||||||
	        	    for (ChunkLoc loc : chunks) {
 | 
					 | 
				
			||||||
	                    int sx = loc.x << 4;
 | 
					 | 
				
			||||||
	                    int sz = loc.z << 4;
 | 
					 | 
				
			||||||
	                    loop:
 | 
					 | 
				
			||||||
	                    for (int x = sx; x < sx + 16; x++) {
 | 
					 | 
				
			||||||
	                        for (int z = sz; z < sz + 16; z++) {
 | 
					 | 
				
			||||||
	                            Chunk chunk = world.getChunkAt(x, z);
 | 
					 | 
				
			||||||
	                            Plot plot = ChunkManager.hasPlot(world, chunk);
 | 
					 | 
				
			||||||
	                            if (plot != null) {
 | 
					 | 
				
			||||||
	                                PlayerFunctions.sendMessage(null, " - " + plot);
 | 
					 | 
				
			||||||
	                                count++;
 | 
					 | 
				
			||||||
	                                break loop;
 | 
					 | 
				
			||||||
	                            }
 | 
					 | 
				
			||||||
	                        }
 | 
					 | 
				
			||||||
	                    }
 | 
					 | 
				
			||||||
	                }
 | 
					 | 
				
			||||||
	        	    PlayerFunctions.sendMessage(null, "Found " + count + "plots.");
 | 
					 | 
				
			||||||
	        	}
 | 
					 | 
				
			||||||
        	}
 | 
					        	}
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    	PlayerFunctions.sendMessage(player, "Possible sub commands: /plot debugexec <" + StringUtils.join(allowed_params, "|") + ">");
 | 
					    	PlayerFunctions.sendMessage(player, "Possible sub commands: /plot debugexec <" + StringUtils.join(allowed_params, "|") + ">");
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -101,37 +101,49 @@ public class Trim extends SubCommand {
 | 
				
			|||||||
            PlayerFunctions.sendMessage(plr, C.NOT_VALID_WORLD);
 | 
					            PlayerFunctions.sendMessage(plr, C.NOT_VALID_WORLD);
 | 
				
			||||||
            return false;
 | 
					            return false;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        if (runTrimTask(world)) {
 | 
					        
 | 
				
			||||||
            sendMessage(C.TRIM_START.s());
 | 
					        if (Trim.TASK) {
 | 
				
			||||||
            return true;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
            sendMessage(C.TRIM_IN_PROGRESS.s());
 | 
					            sendMessage(C.TRIM_IN_PROGRESS.s());
 | 
				
			||||||
            return false;
 | 
					            return false;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        
 | 
					        
 | 
				
			||||||
    public boolean runTrimTask(final World world) {
 | 
					        sendMessage(C.TRIM_START.s());
 | 
				
			||||||
 | 
					        final ArrayList<ChunkLoc> empty = new ArrayList<>();
 | 
				
			||||||
 | 
					        getTrimRegions(empty, world, new Runnable() {
 | 
				
			||||||
 | 
					            @Override
 | 
				
			||||||
 | 
					            public void run() {
 | 
				
			||||||
 | 
					                deleteChunks(world, empty);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					        return true;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    public static boolean getBulkRegions(final ArrayList<ChunkLoc> empty, final World world, final Runnable whenDone) {
 | 
				
			||||||
        if (Trim.TASK) {
 | 
					        if (Trim.TASK) {
 | 
				
			||||||
            return false;
 | 
					            return false;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        Trim.TASK = true;
 | 
					 | 
				
			||||||
        TaskManager.runTask(new Runnable() {
 | 
					        TaskManager.runTask(new Runnable() {
 | 
				
			||||||
            @Override
 | 
					            @Override
 | 
				
			||||||
            public void run() {
 | 
					            public void run() {
 | 
				
			||||||
                final HybridPlotManager manager = (HybridPlotManager) PlotMain.getPlotManager(world);
 | 
					 | 
				
			||||||
                final HybridPlotWorld plotworld = (HybridPlotWorld) PlotMain.getWorldSettings(world);
 | 
					 | 
				
			||||||
                final String worldname = world.getName();
 | 
					 | 
				
			||||||
                String directory = world.getName() + File.separator + "region";
 | 
					                String directory = world.getName() + File.separator + "region";
 | 
				
			||||||
                File folder = new File(directory);
 | 
					                File folder = new File(directory);
 | 
				
			||||||
                File[] regionFiles = folder.listFiles();
 | 
					                File[] regionFiles = folder.listFiles();
 | 
				
			||||||
                ArrayList<ChunkLoc> chunkChunks = new ArrayList<>();
 | 
					 | 
				
			||||||
                for (File file : regionFiles) {
 | 
					                for (File file : regionFiles) {
 | 
				
			||||||
                    String name = file.getName();
 | 
					                    String name = file.getName();
 | 
				
			||||||
                    if (name.endsWith("mca")) {
 | 
					                    if (name.endsWith("mca")) {
 | 
				
			||||||
                        if (file.getTotalSpace() <= 8192) {
 | 
					                        if (file.getTotalSpace() <= 8192) {
 | 
				
			||||||
                            file.delete();
 | 
					                            try {
 | 
				
			||||||
 | 
					                                String[] split = name.split("\\.");
 | 
				
			||||||
 | 
					                                int x = Integer.parseInt(split[1]);
 | 
				
			||||||
 | 
					                                int z = Integer.parseInt(split[2]);
 | 
				
			||||||
 | 
					                                ChunkLoc loc = new ChunkLoc(x, z);
 | 
				
			||||||
 | 
					                                empty.add(loc);
 | 
				
			||||||
 | 
					                            }
 | 
				
			||||||
 | 
					                            catch (Exception e) {
 | 
				
			||||||
 | 
					                                System.out.print("INVALID MCA: " + name);
 | 
				
			||||||
 | 
					                            }
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                        else {
 | 
					                        else {
 | 
				
			||||||
                            boolean delete = false;
 | 
					 | 
				
			||||||
                            Path path = Paths.get(file.getPath());
 | 
					                            Path path = Paths.get(file.getPath());
 | 
				
			||||||
                            try {
 | 
					                            try {
 | 
				
			||||||
                                BasicFileAttributes attr = Files.readAttributes(path, BasicFileAttributes.class);
 | 
					                                BasicFileAttributes attr = Files.readAttributes(path, BasicFileAttributes.class);
 | 
				
			||||||
@@ -139,51 +151,70 @@ public class Trim extends SubCommand {
 | 
				
			|||||||
                                long modification = file.lastModified();
 | 
					                                long modification = file.lastModified();
 | 
				
			||||||
                                long diff = Math.abs(creation - modification);
 | 
					                                long diff = Math.abs(creation - modification);
 | 
				
			||||||
                                if (diff < 10000) {
 | 
					                                if (diff < 10000) {
 | 
				
			||||||
                                    PlotMain.sendConsoleSenderMessage("&6 - Deleted region "+name+" (max 256 chunks)");
 | 
					                                    try {
 | 
				
			||||||
                                    file.delete();
 | 
					                                        String[] split = name.split("\\.");
 | 
				
			||||||
                                    delete = true;
 | 
					                                        int x = Integer.parseInt(split[1]);
 | 
				
			||||||
 | 
					                                        int z = Integer.parseInt(split[2]);
 | 
				
			||||||
 | 
					                                        ChunkLoc loc = new ChunkLoc(x, z);
 | 
				
			||||||
 | 
					                                        empty.add(loc);
 | 
				
			||||||
 | 
					                                    }
 | 
				
			||||||
 | 
					                                    catch (Exception e) {
 | 
				
			||||||
 | 
					                                        System.out.print("INVALID MCA: " + name);
 | 
				
			||||||
 | 
					                                    }
 | 
				
			||||||
                                }
 | 
					                                }
 | 
				
			||||||
                            } catch (Exception e) {
 | 
					                            } catch (Exception e) {
 | 
				
			||||||
                                
 | 
					                                
 | 
				
			||||||
                            }
 | 
					                            }
 | 
				
			||||||
                            if (!delete) {
 | 
					 | 
				
			||||||
                                String[] split = name.split("\\.");
 | 
					 | 
				
			||||||
                                try {
 | 
					 | 
				
			||||||
                                    int x = Integer.parseInt(split[1]);
 | 
					 | 
				
			||||||
                                    int z = Integer.parseInt(split[2]);
 | 
					 | 
				
			||||||
                                    ChunkLoc loc = new ChunkLoc(x, z);
 | 
					 | 
				
			||||||
                                    chunkChunks.add(loc);
 | 
					 | 
				
			||||||
                                }
 | 
					 | 
				
			||||||
                                catch (Exception e) {  }
 | 
					 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					                Trim.TASK = false;
 | 
				
			||||||
 | 
					                TaskManager.runTask(whenDone);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
                final Set<Plot> plots = ExpireManager.getOldPlots(world.getName()).keySet();
 | 
					        });
 | 
				
			||||||
 | 
					        Trim.TASK = true;
 | 
				
			||||||
 | 
					        return true;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    public static boolean getTrimRegions(final ArrayList<ChunkLoc> empty, final World world, final Runnable whenDone) {
 | 
				
			||||||
 | 
					        if (Trim.TASK) {
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        sendMessage("Collecting region data...");
 | 
				
			||||||
 | 
					        final ArrayList<ChunkLoc> chunks = ChunkManager.getChunkChunks(world);
 | 
				
			||||||
 | 
					        sendMessage(" - MCA #: " + chunks.size());
 | 
				
			||||||
 | 
					        sendMessage(" - CHUNKS: " + (chunks.size() * 256) +" (max)");
 | 
				
			||||||
 | 
					        sendMessage(" - TIME ESTIMATE: " + (chunks.size()/1200) +" minutes");
 | 
				
			||||||
        Trim.TASK_ID = Bukkit.getScheduler().scheduleSyncRepeatingTask(PlotMain.getMain(), new Runnable() {
 | 
					        Trim.TASK_ID = Bukkit.getScheduler().scheduleSyncRepeatingTask(PlotMain.getMain(), new Runnable() {
 | 
				
			||||||
            @Override
 | 
					            @Override
 | 
				
			||||||
            public void run() {
 | 
					            public void run() {
 | 
				
			||||||
                        if (manager != null && plots.size() > 0) {
 | 
					                if (chunks.size() == 0) {
 | 
				
			||||||
                            Plot plot = plots.iterator().next();
 | 
					                    TaskManager.runTask(whenDone);
 | 
				
			||||||
                            if (plot.hasOwner()) {
 | 
					 | 
				
			||||||
                                HybridPlotManager.checkModified(plot, 0);
 | 
					 | 
				
			||||||
                            }
 | 
					 | 
				
			||||||
                            if (plot.owner == null || !HybridPlotManager.checkModified(plot, plotworld.REQUIRED_CHANGES)) {
 | 
					 | 
				
			||||||
                                PlotMain.removePlot(worldname, plot.id, true);
 | 
					 | 
				
			||||||
                            }
 | 
					 | 
				
			||||||
                            plots.remove(0);
 | 
					 | 
				
			||||||
                        }
 | 
					 | 
				
			||||||
                        else {
 | 
					 | 
				
			||||||
                            trimPlots(world);
 | 
					 | 
				
			||||||
                            Trim.TASK = false;
 | 
					 | 
				
			||||||
                            sendMessage("Done!");
 | 
					 | 
				
			||||||
                    Bukkit.getScheduler().cancelTask(Trim.TASK_ID);
 | 
					                    Bukkit.getScheduler().cancelTask(Trim.TASK_ID);
 | 
				
			||||||
                    return;
 | 
					                    return;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					                ChunkLoc loc = chunks.get(0);
 | 
				
			||||||
 | 
					                int sx = loc.x << 5;
 | 
				
			||||||
 | 
					                int sz = loc.z << 5;
 | 
				
			||||||
 | 
					                
 | 
				
			||||||
 | 
					                boolean delete = true;
 | 
				
			||||||
 | 
					                
 | 
				
			||||||
 | 
					                loop:
 | 
				
			||||||
 | 
					                for (int x = sx; x < sx + 32; x++) {
 | 
				
			||||||
 | 
					                    for (int z = sz; z < sz + 32; z++) {
 | 
				
			||||||
 | 
					                        Chunk chunk = world.getChunkAt(x, z);
 | 
				
			||||||
 | 
					                        if (ChunkManager.hasPlot(world, chunk) != null) {
 | 
				
			||||||
 | 
					                            delete = false;
 | 
				
			||||||
 | 
					                            break loop;
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                }, 1, 1);
 | 
					 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
        });
 | 
					                }
 | 
				
			||||||
 | 
					                if (delete) {
 | 
				
			||||||
 | 
					                    empty.add(loc);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }, 1L, 1L);
 | 
				
			||||||
 | 
					        Trim.TASK = true;
 | 
				
			||||||
        return true;
 | 
					        return true;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
@@ -219,99 +250,7 @@ public class Trim extends SubCommand {
 | 
				
			|||||||
        }, 1, 1);
 | 
					        }, 1, 1);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
    public static long calculateSizeOnDisk(World world, ArrayList<ChunkLoc> chunks) {
 | 
					    public static void deleteChunks(World world, ArrayList<ChunkLoc> chunks) {
 | 
				
			||||||
        int result = 0;
 | 
					 | 
				
			||||||
        for (ChunkLoc loc : chunks) {
 | 
					 | 
				
			||||||
            String directory = world.getName() + File.separator + "region" + File.separator + "r." + loc.x + "." + loc.z + ".mca";
 | 
					 | 
				
			||||||
            File file = new File(directory);
 | 
					 | 
				
			||||||
            try {
 | 
					 | 
				
			||||||
                result += file.length();
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            catch (Exception e) {
 | 
					 | 
				
			||||||
                e.printStackTrace();
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return result;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    
 | 
					 | 
				
			||||||
    public static ArrayList<ChunkLoc> getTrimChunks(World world) {
 | 
					 | 
				
			||||||
        ArrayList<ChunkLoc> toRemove = new ArrayList<>();
 | 
					 | 
				
			||||||
        String directory = world.getName() + File.separator + "region";
 | 
					 | 
				
			||||||
        File folder = new File(directory);
 | 
					 | 
				
			||||||
        File[] regionFiles = folder.listFiles();
 | 
					 | 
				
			||||||
        for (File file : regionFiles) {
 | 
					 | 
				
			||||||
            String name = file.getName();
 | 
					 | 
				
			||||||
            if (name.endsWith("mca")) {
 | 
					 | 
				
			||||||
                if (file.getTotalSpace() <= 8192) {
 | 
					 | 
				
			||||||
                    try {
 | 
					 | 
				
			||||||
                        String[] split = name.split("\\.");
 | 
					 | 
				
			||||||
                        int x = Integer.parseInt(split[1]);
 | 
					 | 
				
			||||||
                        int z = Integer.parseInt(split[2]);
 | 
					 | 
				
			||||||
                        ChunkLoc loc = new ChunkLoc(x, z);
 | 
					 | 
				
			||||||
                        toRemove.add(loc);
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                    catch (Exception e) {
 | 
					 | 
				
			||||||
                        System.out.print(name);
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                    continue;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                else {
 | 
					 | 
				
			||||||
                    Path path = Paths.get(file.getPath());
 | 
					 | 
				
			||||||
                    try {
 | 
					 | 
				
			||||||
                        BasicFileAttributes attr = Files.readAttributes(path, BasicFileAttributes.class);
 | 
					 | 
				
			||||||
                        long creation = attr.creationTime().toMillis();
 | 
					 | 
				
			||||||
                        long modification = file.lastModified();
 | 
					 | 
				
			||||||
                        long diff = Math.abs(creation - modification);
 | 
					 | 
				
			||||||
                        if (diff < 10000) {
 | 
					 | 
				
			||||||
                            PlotMain.sendConsoleSenderMessage("&6 - Deleted region "+name+" (max 256 chunks)");
 | 
					 | 
				
			||||||
                            try {
 | 
					 | 
				
			||||||
                                String[] split = name.split("\\.");
 | 
					 | 
				
			||||||
                                int x = Integer.parseInt(split[1]);
 | 
					 | 
				
			||||||
                                int z = Integer.parseInt(split[2]);
 | 
					 | 
				
			||||||
                                ChunkLoc loc = new ChunkLoc(x, z);
 | 
					 | 
				
			||||||
                                toRemove.add(loc);
 | 
					 | 
				
			||||||
                            }
 | 
					 | 
				
			||||||
                            catch (Exception e) {
 | 
					 | 
				
			||||||
                                System.out.print(name);
 | 
					 | 
				
			||||||
                            }
 | 
					 | 
				
			||||||
                        }
 | 
					 | 
				
			||||||
                    } catch (Exception e) {
 | 
					 | 
				
			||||||
                        
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return toRemove;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    
 | 
					 | 
				
			||||||
    public static ArrayList<ChunkLoc> getTrimPlots(World world) {
 | 
					 | 
				
			||||||
        ArrayList<ChunkLoc> toRemove = new ArrayList<>();
 | 
					 | 
				
			||||||
        ArrayList<ChunkLoc> chunks = ChunkManager.getChunkChunks(world);
 | 
					 | 
				
			||||||
        for (ChunkLoc loc : chunks) {
 | 
					 | 
				
			||||||
            int sx = loc.x << 4;
 | 
					 | 
				
			||||||
            int sz = loc.z << 4;
 | 
					 | 
				
			||||||
            
 | 
					 | 
				
			||||||
            boolean delete = true;
 | 
					 | 
				
			||||||
            
 | 
					 | 
				
			||||||
            loop:
 | 
					 | 
				
			||||||
            for (int x = sx; x < sx + 16; x++) {
 | 
					 | 
				
			||||||
                for (int z = sz; z < sz + 16; z++) {
 | 
					 | 
				
			||||||
                    Chunk chunk = world.getChunkAt(x, z);
 | 
					 | 
				
			||||||
                    if (ChunkManager.hasPlot(world, chunk) != null) {
 | 
					 | 
				
			||||||
                        delete = false;
 | 
					 | 
				
			||||||
                        break loop;
 | 
					 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            if (delete) {
 | 
					 | 
				
			||||||
                toRemove.add(loc);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return toRemove;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    
 | 
					 | 
				
			||||||
    public static void trimPlots(World world) {
 | 
					 | 
				
			||||||
        ArrayList<ChunkLoc> chunks = getTrimPlots(world);
 | 
					 | 
				
			||||||
        String worldname = world.getName();
 | 
					        String worldname = world.getName();
 | 
				
			||||||
        for (ChunkLoc loc : chunks) {
 | 
					        for (ChunkLoc loc : chunks) {
 | 
				
			||||||
            ChunkManager.deleteRegionFile(worldname, loc);
 | 
					            ChunkManager.deleteRegionFile(worldname, loc);
 | 
				
			||||||
@@ -319,7 +258,7 @@ public class Trim extends SubCommand {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
    public static void sendMessage(final String message) {
 | 
					    public static void sendMessage(final String message) {
 | 
				
			||||||
        PlotMain.sendConsoleSenderMessage("&3PlotSquared -> World trim&8: " + message);
 | 
					        PlotMain.sendConsoleSenderMessage("&3PlotSquared -> World trim&8: &7" + message);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -180,13 +180,13 @@ import com.intellectualcrafters.plot.util.SendChunk;
 | 
				
			|||||||
    
 | 
					    
 | 
				
			||||||
    public void regenerateChunkChunk(World world, ChunkLoc loc) {
 | 
					    public void regenerateChunkChunk(World world, ChunkLoc loc) {
 | 
				
			||||||
        
 | 
					        
 | 
				
			||||||
        int sx = loc.x << 4;
 | 
					        int sx = loc.x << 5;
 | 
				
			||||||
        int sz = loc.z << 4;
 | 
					        int sz = loc.z << 5;
 | 
				
			||||||
        
 | 
					        
 | 
				
			||||||
        HashSet<Chunk> chunks = new HashSet<Chunk>();
 | 
					        HashSet<Chunk> chunks = new HashSet<Chunk>();
 | 
				
			||||||
        
 | 
					        
 | 
				
			||||||
        for (int x = sx; x < sx + 16; x++) {
 | 
					        for (int x = sx; x < sx + 32; x++) {
 | 
				
			||||||
            for (int z = sz; z < sz + 16; z++) {
 | 
					            for (int z = sz; z < sz + 32; z++) {
 | 
				
			||||||
                Chunk chunk = world.getChunkAt(x, z);
 | 
					                Chunk chunk = world.getChunkAt(x, z);
 | 
				
			||||||
                chunk.load(false);
 | 
					                chunk.load(false);
 | 
				
			||||||
                chunks.add(chunk);
 | 
					                chunks.add(chunk);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -78,7 +78,7 @@ public class ChunkManager {
 | 
				
			|||||||
            public void run() {
 | 
					            public void run() {
 | 
				
			||||||
                String directory = world + File.separator + "region" + File.separator + "r." + loc.x + "." + loc.z + ".mca";
 | 
					                String directory = world + File.separator + "region" + File.separator + "r." + loc.x + "." + loc.z + ".mca";
 | 
				
			||||||
                File file = new File(directory);
 | 
					                File file = new File(directory);
 | 
				
			||||||
                PlotMain.sendConsoleSenderMessage("&6 - Deleted region "+file.getName()+" (max 256 chunks)");
 | 
					                PlotMain.sendConsoleSenderMessage("&6 - Deleting file: " + file.getName() + " (max 1024 chunks)");
 | 
				
			||||||
                if (file.exists()) {
 | 
					                if (file.exists()) {
 | 
				
			||||||
                    file.delete();
 | 
					                    file.delete();
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user