mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-23 12:06:15 +01:00
debug trim command
This commit is contained in:
parent
5f9dce1a07
commit
e9aa1be58c
@ -22,6 +22,7 @@
|
|||||||
package com.intellectualcrafters.plot.commands;
|
package com.intellectualcrafters.plot.commands;
|
||||||
|
|
||||||
import java.sql.Timestamp;
|
import java.sql.Timestamp;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -34,6 +35,8 @@ import org.bukkit.OfflinePlayer;
|
|||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import com.intellectualcrafters.plot.PlotMain;
|
||||||
|
import com.intellectualcrafters.plot.object.ChunkLoc;
|
||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
import com.intellectualcrafters.plot.util.ExpireManager;
|
import com.intellectualcrafters.plot.util.ExpireManager;
|
||||||
import com.intellectualcrafters.plot.util.PlayerFunctions;
|
import com.intellectualcrafters.plot.util.PlayerFunctions;
|
||||||
@ -51,7 +54,7 @@ public class DebugExec extends SubCommand {
|
|||||||
if (args.length > 0) {
|
if (args.length > 0) {
|
||||||
String arg = args[0].toLowerCase();
|
String arg = args[0].toLowerCase();
|
||||||
switch (arg) {
|
switch (arg) {
|
||||||
case "stop-expire":
|
case "stop-expire": {
|
||||||
if (ExpireManager.task != -1) {
|
if (ExpireManager.task != -1) {
|
||||||
Bukkit.getScheduler().cancelTask(ExpireManager.task);
|
Bukkit.getScheduler().cancelTask(ExpireManager.task);
|
||||||
}
|
}
|
||||||
@ -60,7 +63,8 @@ public class DebugExec extends SubCommand {
|
|||||||
}
|
}
|
||||||
ExpireManager.task = -1;
|
ExpireManager.task = -1;
|
||||||
return PlayerFunctions.sendMessage(null, "Cancelled task.");
|
return PlayerFunctions.sendMessage(null, "Cancelled task.");
|
||||||
case "start-expire":
|
}
|
||||||
|
case "start-expire": {
|
||||||
if (ExpireManager.task == -1) {
|
if (ExpireManager.task == -1) {
|
||||||
ExpireManager.runTask();
|
ExpireManager.runTask();
|
||||||
}
|
}
|
||||||
@ -68,7 +72,8 @@ public class DebugExec extends SubCommand {
|
|||||||
return PlayerFunctions.sendMessage(null, "Plot expiry task already started");
|
return PlayerFunctions.sendMessage(null, "Plot expiry task already started");
|
||||||
}
|
}
|
||||||
return PlayerFunctions.sendMessage(null, "Started plot expiry task");
|
return PlayerFunctions.sendMessage(null, "Started plot expiry task");
|
||||||
case "update-expired":
|
}
|
||||||
|
case "update-expired": {
|
||||||
if (args.length > 1) {
|
if (args.length > 1) {
|
||||||
World world = Bukkit.getWorld(args[1]);
|
World world = Bukkit.getWorld(args[1]);
|
||||||
if (world == null) {
|
if (world == null) {
|
||||||
@ -79,7 +84,8 @@ public class DebugExec extends SubCommand {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return PlayerFunctions.sendMessage(null, "Use /plot debugexec update-expired <world>");
|
return PlayerFunctions.sendMessage(null, "Use /plot debugexec update-expired <world>");
|
||||||
case "show-expired":
|
}
|
||||||
|
case "show-expired": {
|
||||||
if (args.length > 1) {
|
if (args.length > 1) {
|
||||||
World world = Bukkit.getWorld(args[1]);
|
World world = Bukkit.getWorld(args[1]);
|
||||||
if (world == null || !ExpireManager.expiredPlots.containsKey(args[1])) {
|
if (world == null || !ExpireManager.expiredPlots.containsKey(args[1])) {
|
||||||
@ -94,7 +100,8 @@ public class DebugExec extends SubCommand {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return PlayerFunctions.sendMessage(null, "Use /plot debugexec show-expired <world>");
|
return PlayerFunctions.sendMessage(null, "Use /plot debugexec show-expired <world>");
|
||||||
case "seen":
|
}
|
||||||
|
case "seen": {
|
||||||
if (args.length != 2) {
|
if (args.length != 2) {
|
||||||
return PlayerFunctions.sendMessage(null, "Use /plot debugexec seen <player>");
|
return PlayerFunctions.sendMessage(null, "Use /plot debugexec seen <player>");
|
||||||
}
|
}
|
||||||
@ -115,6 +122,26 @@ 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": {
|
||||||
|
if (args.length != 2) {
|
||||||
|
PlayerFunctions.sendMessage(null, "Use /plot debugexec trim-get-chunks <world>");
|
||||||
|
PlayerFunctions.sendMessage(null, "&7 - Generates a list of regions to trim");
|
||||||
|
return PlayerFunctions.sendMessage(null, "&7 - Run after plot expiry has run");
|
||||||
|
}
|
||||||
|
World world = Bukkit.getWorld(args[1]);
|
||||||
|
if (world == null || !PlotMain.isPlotWorld(args[1])) {
|
||||||
|
return PlayerFunctions.sendMessage(null, "Invalid world: "+args[1]);
|
||||||
|
}
|
||||||
|
ArrayList<ChunkLoc> chunks0 = Trim.getTrimChunks(world);
|
||||||
|
PlayerFunctions.sendMessage(null, "BULK MCR: " + chunks0.size());
|
||||||
|
ArrayList<ChunkLoc> chunks = Trim.getTrimPlots(world);
|
||||||
|
chunks.addAll(chunks0);
|
||||||
|
PlayerFunctions.sendMessage(null, "MCR: " + chunks.size());
|
||||||
|
PlayerFunctions.sendMessage(null, "CHUNKS: " + chunks.size() * 256);
|
||||||
|
PlayerFunctions.sendMessage(null, "Calculating size on disk...");
|
||||||
|
PlayerFunctions.sendMessage(null, "SIZE (bytes): " + Trim.calculateSizeOnDisk(world, chunks));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
PlayerFunctions.sendMessage(player, "Possible sub commands: /plot debugexec <" + StringUtils.join(allowed_params, "|") + ">");
|
PlayerFunctions.sendMessage(player, "Possible sub commands: /plot debugexec <" + StringUtils.join(allowed_params, "|") + ">");
|
||||||
return true;
|
return true;
|
||||||
|
@ -27,6 +27,8 @@ import java.nio.file.Path;
|
|||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.nio.file.attribute.BasicFileAttributes;
|
import java.nio.file.attribute.BasicFileAttributes;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@ -185,8 +187,98 @@ public class Trim extends SubCommand {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void trimPlots(World world) {
|
public static ArrayList<Plot> expired = null;
|
||||||
String worldname = world.getName();
|
|
||||||
|
public static void updateUnmodifiedPlots(final World world) {
|
||||||
|
final HybridPlotManager manager = (HybridPlotManager) PlotMain.getPlotManager(world);
|
||||||
|
final HybridPlotWorld plotworld = (HybridPlotWorld) PlotMain.getWorldSettings(world);
|
||||||
|
final ArrayList<Plot> expired = new ArrayList<>();
|
||||||
|
final Set<Plot> plots = ExpireManager.getOldPlots(world.getName()).keySet();
|
||||||
|
sendMessage("Checking " + plots.size() +" plots! This may take a long time...");
|
||||||
|
Trim.TASK_ID = Bukkit.getScheduler().scheduleSyncRepeatingTask(PlotMain.getMain(), new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (manager != null && plots.size() > 0) {
|
||||||
|
Plot plot = plots.iterator().next();
|
||||||
|
if (plot.hasOwner()) {
|
||||||
|
HybridPlotManager.checkModified(plot, 0);
|
||||||
|
}
|
||||||
|
if (plot.owner == null || !HybridPlotManager.checkModified(plot, plotworld.REQUIRED_CHANGES)) {
|
||||||
|
expired.add(plot);
|
||||||
|
sendMessage("found expired: " + plot);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Trim.expired = expired;
|
||||||
|
Trim.TASK = false;
|
||||||
|
sendMessage("Done!");
|
||||||
|
Bukkit.getScheduler().cancelTask(Trim.TASK_ID);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, 1, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static long calculateSizeOnDisk(World world, ArrayList<ChunkLoc> chunks) {
|
||||||
|
int result = 0;
|
||||||
|
for (ChunkLoc loc : chunks) {
|
||||||
|
String directory = new File(".").getAbsolutePath() + File.separator + world + File.separator + "region" + File.separator + "r." + loc.x + "." + loc.z + ".mca";
|
||||||
|
File file = new File(directory);
|
||||||
|
result += file.getTotalSpace();
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<ChunkLoc> getTrimChunks(World world) {
|
||||||
|
ArrayList<ChunkLoc> toRemove = new ArrayList<>();
|
||||||
|
String directory = new File(".").getAbsolutePath() + File.separator + 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) {}
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
boolean delete = false;
|
||||||
|
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) {}
|
||||||
|
delete = true;
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return toRemove;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<ChunkLoc> getTrimPlots(World world) {
|
||||||
|
ArrayList<ChunkLoc> toRemove = new ArrayList<>();
|
||||||
ArrayList<ChunkLoc> chunks = ChunkManager.getChunkChunks(world);
|
ArrayList<ChunkLoc> chunks = ChunkManager.getChunkChunks(world);
|
||||||
for (ChunkLoc loc : chunks) {
|
for (ChunkLoc loc : chunks) {
|
||||||
int sx = loc.x << 4;
|
int sx = loc.x << 4;
|
||||||
@ -205,12 +297,21 @@ public class Trim extends SubCommand {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (delete) {
|
if (delete) {
|
||||||
|
toRemove.add(loc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return toRemove;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void trimPlots(World world) {
|
||||||
|
ArrayList<ChunkLoc> chunks = getTrimPlots(world);
|
||||||
|
String worldname = world.getName();
|
||||||
|
for (ChunkLoc loc : chunks) {
|
||||||
ChunkManager.deleteRegionFile(worldname, loc);
|
ChunkManager.deleteRegionFile(worldname, loc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private 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: " + message);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user