PlotSquared/PlotSquared/src/main/java/com/intellectualcrafters/plot/commands/Trim.java

218 lines
10 KiB
Java
Raw Normal View History

2015-01-07 14:29:20 +01:00
////////////////////////////////////////////////////////////////////////////////////////////////////
// PlotSquared - A plot manager and world generator for the Bukkit API /
// Copyright (c) 2014 IntellectualSites/IntellectualCrafters /
// /
// This program is free software; you can redistribute it and/or modify /
// it under the terms of the GNU General Public License as published by /
// the Free Software Foundation; either version 3 of the License, or /
// (at your option) any later version. /
// /
// This program is distributed in the hope that it will be useful, /
// but WITHOUT ANY WARRANTY; without even the implied warranty of /
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the /
// GNU General Public License for more details. /
// /
// You should have received a copy of the GNU General Public License /
// along with this program; if not, write to the Free Software Foundation, /
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA /
// /
// You can contact us via: support@intellectualsites.com /
////////////////////////////////////////////////////////////////////////////////////////////////////
package com.intellectualcrafters.plot.commands;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.attribute.BasicFileAttributes;
import java.util.ArrayList;
2015-02-12 08:41:26 +01:00
import java.util.HashSet;
2015-01-07 14:29:20 +01:00
2015-02-19 09:51:10 +01:00
import com.intellectualcrafters.plot.PlotSquared;
2015-01-07 14:29:20 +01:00
import com.intellectualcrafters.plot.config.C;
import com.intellectualcrafters.plot.object.ChunkLoc;
2015-02-22 13:57:59 +01:00
import com.intellectualcrafters.plot.object.Location;
2015-01-07 14:29:20 +01:00
import com.intellectualcrafters.plot.object.Plot;
import com.intellectualcrafters.plot.object.PlotId;
2015-02-21 12:38:44 +01:00
import com.intellectualcrafters.plot.object.PlotPlayer;
2015-02-22 07:42:52 +01:00
import com.intellectualcrafters.plot.util.AChunkManager;
2015-02-22 13:57:59 +01:00
import com.intellectualcrafters.plot.util.BlockManager;
2015-02-20 12:23:48 +01:00
import com.intellectualcrafters.plot.util.MainUtil;
2015-02-20 07:34:19 +01:00
import com.intellectualcrafters.plot.util.TaskManager;
2015-02-21 05:27:01 +01:00
import com.intellectualcrafters.plot.util.bukkit.ChunkManager;
2015-01-07 14:29:20 +01:00
public class Trim extends SubCommand {
2015-01-07 16:18:07 +01:00
public static boolean TASK = false;
private static int TASK_ID = 0;
2015-01-07 14:29:20 +01:00
public Trim() {
super("trim", "plots.admin", "Delete unmodified portions of your plotworld", "trim", "", CommandCategory.DEBUG, false);
}
2015-02-20 07:34:19 +01:00
public PlotId getId(final String id) {
2015-01-07 14:29:20 +01:00
try {
2015-02-20 07:34:19 +01:00
final String[] split = id.split(";");
2015-01-07 14:29:20 +01:00
return new PlotId(Integer.parseInt(split[0]), Integer.parseInt(split[1]));
2015-02-20 07:34:19 +01:00
} catch (final Exception e) {
2015-01-07 14:29:20 +01:00
return null;
}
}
@Override
2015-02-21 08:30:55 +01:00
public boolean execute(final PlotPlayer plr, final String... args) {
2015-01-07 14:29:20 +01:00
if (plr != null) {
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, (C.NOT_CONSOLE));
2015-01-07 14:29:20 +01:00
return false;
}
if (args.length == 1) {
2015-02-20 07:34:19 +01:00
final String arg = args[0].toLowerCase();
final PlotId id = getId(arg);
2015-01-07 14:29:20 +01:00
if (id != null) {
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, "/plot trim x;z &l<world>");
2015-01-07 14:29:20 +01:00
return false;
}
if (arg.equals("all")) {
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, "/plot trim all &l<world>");
2015-01-07 14:29:20 +01:00
return false;
}
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, C.TRIM_SYNTAX);
2015-01-07 14:29:20 +01:00
return false;
}
if (args.length != 2) {
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, C.TRIM_SYNTAX);
2015-01-07 14:29:20 +01:00
return false;
}
2015-02-20 07:34:19 +01:00
final String arg = args[0].toLowerCase();
2015-01-07 15:10:22 +01:00
if (!arg.equals("all")) {
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, C.TRIM_SYNTAX);
2015-01-07 15:10:22 +01:00
return false;
}
2015-02-22 13:57:59 +01:00
final String world = args[1];
if (!BlockManager.manager.isWorld(world) || (PlotSquared.getPlotWorld(world) == null)) {
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, C.NOT_VALID_WORLD);
2015-01-07 15:10:22 +01:00
return false;
}
if (Trim.TASK) {
sendMessage(C.TRIM_IN_PROGRESS.s());
return false;
2015-01-07 14:29:20 +01:00
}
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;
2015-01-07 14:29:20 +01:00
}
2015-02-22 13:57:59 +01:00
public static boolean getBulkRegions(final ArrayList<ChunkLoc> empty, final String world, final Runnable whenDone) {
2015-01-07 16:18:07 +01:00
if (Trim.TASK) {
return false;
}
2015-02-20 07:34:19 +01:00
TaskManager.runTaskAsync(new Runnable() {
2015-01-07 16:18:07 +01:00
@Override
public void run() {
2015-02-22 13:57:59 +01:00
final String directory = world + File.separator + "region";
2015-02-20 07:34:19 +01:00
final File folder = new File(directory);
final File[] regionFiles = folder.listFiles();
for (final File file : regionFiles) {
final String name = file.getName();
2015-01-07 16:18:07 +01:00
if (name.endsWith("mca")) {
if (file.getTotalSpace() <= 8192) {
try {
2015-02-20 07:34:19 +01:00
final String[] split = name.split("\\.");
final int x = Integer.parseInt(split[1]);
final int z = Integer.parseInt(split[2]);
final ChunkLoc loc = new ChunkLoc(x, z);
empty.add(loc);
2015-02-20 07:34:19 +01:00
} catch (final Exception e) {
System.out.print("INVALID MCA: " + name);
}
2015-02-20 07:34:19 +01:00
} else {
final Path path = Paths.get(file.getPath());
2015-01-07 16:18:07 +01:00
try {
2015-02-20 07:34:19 +01:00
final BasicFileAttributes attr = Files.readAttributes(path, BasicFileAttributes.class);
final long creation = attr.creationTime().toMillis();
final long modification = file.lastModified();
final long diff = Math.abs(creation - modification);
2015-01-07 16:18:07 +01:00
if (diff < 10000) {
try {
2015-02-20 07:34:19 +01:00
final String[] split = name.split("\\.");
final int x = Integer.parseInt(split[1]);
final int z = Integer.parseInt(split[2]);
final ChunkLoc loc = new ChunkLoc(x, z);
empty.add(loc);
2015-02-20 07:34:19 +01:00
} catch (final Exception e) {
System.out.print("INVALID MCA: " + name);
}
2015-01-07 16:18:07 +01:00
}
2015-02-20 07:34:19 +01:00
} catch (final Exception e) {
2015-01-07 16:18:07 +01:00
}
}
}
}
Trim.TASK = false;
2015-02-20 07:34:19 +01:00
TaskManager.runTaskAsync(whenDone);
}
});
Trim.TASK = true;
return true;
}
2015-02-22 07:42:52 +01:00
public static boolean getTrimRegions(final ArrayList<ChunkLoc> empty, final String world, final Runnable whenDone) {
if (Trim.TASK) {
return false;
}
2015-02-12 08:41:26 +01:00
final long startOld = System.currentTimeMillis();
sendMessage("Collecting region data...");
2015-02-12 08:41:26 +01:00
final ArrayList<Plot> plots = new ArrayList<>();
2015-02-19 09:51:10 +01:00
plots.addAll(PlotSquared.getPlots(world).values());
2015-02-22 07:42:52 +01:00
final HashSet<ChunkLoc> chunks = new HashSet<>(AChunkManager.manager.getChunkChunks(world));
sendMessage(" - MCA #: " + chunks.size());
2015-02-20 07:34:19 +01:00
sendMessage(" - CHUNKS: " + (chunks.size() * 1024) + " (max)");
sendMessage(" - TIME ESTIMATE: " + (chunks.size() / 1200) + " minutes");
2015-02-22 13:57:59 +01:00
Trim.TASK_ID = TaskManager.runTaskRepeat(new Runnable() {
@Override
public void run() {
2015-02-20 07:34:19 +01:00
final long start = System.currentTimeMillis();
while ((System.currentTimeMillis() - start) < 50) {
2015-02-12 08:41:26 +01:00
if (plots.size() == 0) {
empty.addAll(chunks);
System.out.print("DONE!");
Trim.TASK = false;
2015-02-20 07:34:19 +01:00
TaskManager.runTaskAsync(whenDone);
2015-02-22 13:57:59 +01:00
PlotSquared.TASK.cancelTask(Trim.TASK_ID);
2015-02-12 08:41:26 +01:00
return;
2015-01-07 16:18:07 +01:00
}
2015-02-20 07:34:19 +01:00
final Plot plot = plots.get(0);
2015-02-12 08:41:26 +01:00
plots.remove(0);
2015-02-20 12:23:48 +01:00
final Location pos1 = MainUtil.getPlotBottomLoc(world, plot.id);
final Location pos2 = MainUtil.getPlotTopLoc(world, plot.id);
2015-02-22 13:57:59 +01:00
final Location pos3 = new Location(world, pos1.getX(), 64, pos2.getZ());
final Location pos4 = new Location(world, pos2.getX(), 64, pos1.getZ());
2015-02-12 08:41:26 +01:00
chunks.remove(ChunkManager.getChunkChunk(pos1));
chunks.remove(ChunkManager.getChunkChunk(pos2));
chunks.remove(ChunkManager.getChunkChunk(pos3));
chunks.remove(ChunkManager.getChunkChunk(pos4));
}
2015-01-07 16:18:07 +01:00
}
2015-02-22 13:57:59 +01:00
}, 20);
Trim.TASK = true;
2015-01-07 16:18:07 +01:00
return true;
}
2015-02-11 09:41:10 +01:00
public static ArrayList<Plot> expired = null;
2015-02-22 13:57:59 +01:00
public static void deleteChunks(final String world, final ArrayList<ChunkLoc> chunks) {
2015-02-20 07:34:19 +01:00
for (final ChunkLoc loc : chunks) {
2015-02-22 13:57:59 +01:00
AChunkManager.manager.deleteRegionFile(world, loc);
2015-02-11 09:41:10 +01:00
}
2015-01-07 16:18:07 +01:00
}
2015-02-11 09:41:10 +01:00
public static void sendMessage(final String message) {
2015-02-19 11:23:36 +01:00
PlotSquared.log("&3PlotSquared -> World trim&8: &7" + message);
2015-01-07 14:29:20 +01:00
}
}