mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2025-04-02 09:46:23 +02:00
229 lines
10 KiB
Java
229 lines
10 KiB
Java
////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
// 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 com.intellectualcrafters.plot.config.C;
|
|
import com.intellectualcrafters.plot.config.Settings;
|
|
import com.intellectualcrafters.plot.object.Plot;
|
|
import com.intellectualcrafters.plot.object.PlotArea;
|
|
import com.intellectualcrafters.plot.object.PlotId;
|
|
import com.intellectualcrafters.plot.object.PlotPlayer;
|
|
import com.intellectualcrafters.plot.util.ByteArrayUtilities;
|
|
import com.intellectualcrafters.plot.util.EconHandler;
|
|
import com.intellectualcrafters.plot.util.MainUtil;
|
|
import com.intellectualcrafters.plot.util.Permissions;
|
|
import com.plotsquared.general.commands.CommandDeclaration;
|
|
|
|
@CommandDeclaration(
|
|
command = "auto",
|
|
permission = "plots.auto",
|
|
category = CommandCategory.CLAIMING,
|
|
requiredType = RequiredType.NONE,
|
|
description = "Claim the nearest plot",
|
|
aliases = { "a" },
|
|
usage = "/plot auto [length,width]")
|
|
public class Auto extends SubCommand {
|
|
|
|
public static PlotId getNextPlotId(final PlotId id, final int step) {
|
|
final int absX = Math.abs(id.x);
|
|
final int absY = Math.abs(id.y);
|
|
if (absX > absY) {
|
|
if (id.x > 0) {
|
|
return new PlotId(id.x, id.y + 1);
|
|
} else {
|
|
return new PlotId(id.x, id.y - 1);
|
|
}
|
|
} else if (absY > absX) {
|
|
if (id.y > 0) {
|
|
return new PlotId(id.x - 1, id.y);
|
|
} else {
|
|
return new PlotId(id.x + 1, id.y);
|
|
}
|
|
} else {
|
|
if (id.x.equals(id.y) && (id.x > 0)) {
|
|
return new PlotId(id.x, id.y + step);
|
|
}
|
|
if (id.x == absX) {
|
|
return new PlotId(id.x, id.y + 1);
|
|
}
|
|
if (id.y == absY) {
|
|
return new PlotId(id.x, id.y - 1);
|
|
}
|
|
return new PlotId(id.x + 1, id.y);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean onCommand(final PlotPlayer plr, final String[] args) {
|
|
PlotArea plotarea = plr.getApplicablePlotArea();
|
|
if (plotarea == null) {
|
|
MainUtil.sendMessage(plr, C.NOT_IN_PLOT_WORLD);
|
|
return false;
|
|
}
|
|
int size_x = 1;
|
|
int size_z = 1;
|
|
String schematic = null;
|
|
if (args.length > 0) {
|
|
if (Permissions.hasPermission(plr, "plots.auto.mega")) {
|
|
try {
|
|
final String[] split = args[0].split(",|;");
|
|
size_x = Integer.parseInt(split[0]);
|
|
size_z = Integer.parseInt(split[1]);
|
|
if ((size_x < 1) || (size_z < 1)) {
|
|
MainUtil.sendMessage(plr, "&cError: size<=0");
|
|
}
|
|
if (args.length > 1) {
|
|
schematic = args[1];
|
|
}
|
|
} catch (final Exception e) {
|
|
size_x = 1;
|
|
size_z = 1;
|
|
schematic = args[0];
|
|
// PlayerFunctions.sendMessage(plr,
|
|
// "&cError: Invalid size (X,Y)");
|
|
// return false;
|
|
}
|
|
} else {
|
|
schematic = args[0];
|
|
// PlayerFunctions.sendMessage(plr, C.NO_PERMISSION);
|
|
// return false;
|
|
}
|
|
}
|
|
if ((size_x * size_z) > Settings.MAX_AUTO_SIZE) {
|
|
MainUtil.sendMessage(plr, C.CANT_CLAIM_MORE_PLOTS_NUM, Settings.MAX_AUTO_SIZE + "");
|
|
return false;
|
|
}
|
|
int removeGrants = 0;
|
|
final int currentPlots = Settings.GLOBAL_LIMIT ? plr.getPlotCount() : plr.getPlotCount(plotarea.worldname);
|
|
final int diff = currentPlots - plr.getAllowedPlots();
|
|
if ((diff + (size_x * size_z)) > 0) {
|
|
if (diff < 0) {
|
|
MainUtil.sendMessage(plr, C.CANT_CLAIM_MORE_PLOTS_NUM, (-diff) + "");
|
|
} else {
|
|
if (plr.hasPersistentMeta("grantedPlots")) {
|
|
int grantedPlots = ByteArrayUtilities.bytesToInteger(plr.getPersistentMeta("grantedPlots"));
|
|
if (grantedPlots < size_x * size_z) {
|
|
plr.removePersistentMeta("grantedPlots");
|
|
return sendMessage(plr, C.CANT_CLAIM_MORE_PLOTS);
|
|
} else {
|
|
removeGrants = size_x * size_z;
|
|
}
|
|
} else {
|
|
MainUtil.sendMessage(plr, C.CANT_CLAIM_MORE_PLOTS);
|
|
}
|
|
}
|
|
if (removeGrants == 0) {
|
|
return false;
|
|
}
|
|
}
|
|
if ((EconHandler.manager != null) && plotarea.USE_ECONOMY) {
|
|
double cost = plotarea.PLOT_PRICE;
|
|
cost = (size_x * size_z) * cost;
|
|
if (cost > 0d) {
|
|
if (EconHandler.manager.getMoney(plr) < cost) {
|
|
sendMessage(plr, C.CANNOT_AFFORD_PLOT, "" + cost);
|
|
return true;
|
|
}
|
|
EconHandler.manager.withdrawMoney(plr, cost);
|
|
sendMessage(plr, C.REMOVED_BALANCE, cost + "");
|
|
}
|
|
}
|
|
if (removeGrants > 0) {
|
|
int grantedPlots = ByteArrayUtilities.bytesToInteger(plr.getPersistentMeta("grantedPlots"));
|
|
plr.setPersistentMeta("grantedPlots", ByteArrayUtilities.integerToBytes(grantedPlots - removeGrants));
|
|
sendMessage(plr, C.REMOVED_GRANTED_PLOT, "" + removeGrants, "" + (grantedPlots - removeGrants));
|
|
}
|
|
if (schematic != null && !schematic.equals("")) {
|
|
if (!plotarea.SCHEMATICS.contains(schematic.toLowerCase())) {
|
|
sendMessage(plr, C.SCHEMATIC_INVALID, "non-existent: " + schematic);
|
|
return true;
|
|
}
|
|
if (!Permissions.hasPermission(plr, "plots.claim." + schematic) && !Permissions.hasPermission(plr, "plots.admin.command.schematic")) {
|
|
MainUtil.sendMessage(plr, C.NO_SCHEMATIC_PERMISSION, schematic);
|
|
return true;
|
|
}
|
|
}
|
|
if (plotarea.TYPE == 2) {
|
|
final PlotId bot = plotarea.getMin();
|
|
final PlotId top = plotarea.getMax();
|
|
final PlotId origin = new PlotId((bot.x + top.x) / 2, (bot.y + top.y) / 2);
|
|
PlotId id = new PlotId(0, 0);
|
|
final int width = Math.max((top.x - bot.x) + 1, (top.y - bot.y) + 1);
|
|
final int max = width * width;
|
|
//
|
|
for (int i = 0; i <= max; i++) {
|
|
final PlotId currentId = new PlotId(origin.x + id.x, origin.y + id.y);
|
|
Plot current = plotarea.getPlotAbs(currentId);
|
|
if (current.canClaim(plr)) {
|
|
Claim.claimPlot(plr, current, true, true);
|
|
return true;
|
|
}
|
|
id = getNextPlotId(id, 1);
|
|
}
|
|
// no free plots
|
|
MainUtil.sendMessage(plr, C.NO_FREE_PLOTS);
|
|
return false;
|
|
}
|
|
boolean br = false;
|
|
if ((size_x == 1) && (size_z == 1)) {
|
|
while (!br) {
|
|
Plot plot = plotarea.getPlotAbs(getLastPlotId(plotarea));
|
|
if (plot.canClaim(plr)) {
|
|
Claim.claimPlot(plr, plot, true, true);
|
|
br = true;
|
|
}
|
|
plotarea.setMeta("lastPlot", getNextPlotId(plot.getId(), 1));
|
|
}
|
|
} else {
|
|
while (!br) {
|
|
final PlotId start = getNextPlotId(getLastPlotId(plotarea), 1);
|
|
final PlotId end = new PlotId((start.x + size_x) - 1, (start.y + size_z) - 1);
|
|
plotarea.setMeta("lastPlot", start);
|
|
if (plotarea.canClaim(plr, start, end)) {
|
|
for (int i = start.x; i <= end.x; i++) {
|
|
for (int j = start.y; j <= end.y; j++) {
|
|
Plot plot = plotarea.getPlotAbs(new PlotId(i, j));
|
|
final boolean teleport = ((i == end.x) && (j == end.y));
|
|
Claim.claimPlot(plr, plot, teleport, true);
|
|
}
|
|
}
|
|
if (!plotarea.mergePlots(MainUtil.getPlotSelectionIds(start, end), Settings.MERGE_REMOVES_ROADS, true)) {
|
|
return false;
|
|
}
|
|
br = true;
|
|
}
|
|
}
|
|
}
|
|
plotarea.setMeta("lastPlot", new PlotId(0, 0));
|
|
return true;
|
|
}
|
|
|
|
public PlotId getLastPlotId(final PlotArea area) {
|
|
PlotId value = (PlotId) area.getMeta("lastPlot");
|
|
if (value == null) {
|
|
value = new PlotId(0, 0);
|
|
area.setMeta("lastPlot", value);
|
|
return value;
|
|
}
|
|
return value;
|
|
}
|
|
}
|