mirror of
https://github.com/TotalFreedomMC/TF-PlotSquared.git
synced 2025-01-11 01:17:12 +00:00
Various changes
Plot class is now more reliable as most fields are private Cleanup some classes. Fixes #955 makes progress on #953
This commit is contained in:
parent
3fb686608b
commit
dfd29f6713
10 changed files with 335 additions and 240 deletions
Bukkit/src/main/java/com/plotsquared/bukkit
Core/src/main/java/com/intellectualcrafters/plot
|
@ -12,23 +12,74 @@ import com.intellectualcrafters.plot.generator.GeneratorWrapper;
|
||||||
import com.intellectualcrafters.plot.generator.HybridGen;
|
import com.intellectualcrafters.plot.generator.HybridGen;
|
||||||
import com.intellectualcrafters.plot.generator.HybridUtils;
|
import com.intellectualcrafters.plot.generator.HybridUtils;
|
||||||
import com.intellectualcrafters.plot.generator.IndependentPlotGenerator;
|
import com.intellectualcrafters.plot.generator.IndependentPlotGenerator;
|
||||||
import com.intellectualcrafters.plot.object.*;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
import com.intellectualcrafters.plot.util.*;
|
import com.intellectualcrafters.plot.object.PlotArea;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotPlayer;
|
||||||
|
import com.intellectualcrafters.plot.object.RunnableVal;
|
||||||
|
import com.intellectualcrafters.plot.object.SetupObject;
|
||||||
|
import com.intellectualcrafters.plot.util.AbstractTitle;
|
||||||
|
import com.intellectualcrafters.plot.util.ChatManager;
|
||||||
|
import com.intellectualcrafters.plot.util.ChunkManager;
|
||||||
|
import com.intellectualcrafters.plot.util.ConsoleColors;
|
||||||
|
import com.intellectualcrafters.plot.util.EconHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.EventUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.InventoryUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.MainUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.PlotQueue;
|
||||||
|
import com.intellectualcrafters.plot.util.SchematicHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.SetupUtils;
|
||||||
|
import com.intellectualcrafters.plot.util.StringMan;
|
||||||
|
import com.intellectualcrafters.plot.util.TaskManager;
|
||||||
|
import com.intellectualcrafters.plot.util.UUIDHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.UUIDHandlerImplementation;
|
||||||
|
import com.intellectualcrafters.plot.util.WorldUtil;
|
||||||
import com.intellectualcrafters.plot.uuid.UUIDWrapper;
|
import com.intellectualcrafters.plot.uuid.UUIDWrapper;
|
||||||
import com.plotsquared.bukkit.commands.DebugUUID;
|
import com.plotsquared.bukkit.commands.DebugUUID;
|
||||||
import com.plotsquared.bukkit.database.plotme.ClassicPlotMeConnector;
|
import com.plotsquared.bukkit.database.plotme.ClassicPlotMeConnector;
|
||||||
import com.plotsquared.bukkit.database.plotme.LikePlotMeConverter;
|
import com.plotsquared.bukkit.database.plotme.LikePlotMeConverter;
|
||||||
import com.plotsquared.bukkit.database.plotme.PlotMeConnector_017;
|
import com.plotsquared.bukkit.database.plotme.PlotMeConnector_017;
|
||||||
import com.plotsquared.bukkit.generator.BukkitPlotGenerator;
|
import com.plotsquared.bukkit.generator.BukkitPlotGenerator;
|
||||||
import com.plotsquared.bukkit.listeners.*;
|
import com.plotsquared.bukkit.listeners.ChunkListener;
|
||||||
|
import com.plotsquared.bukkit.listeners.ForceFieldListener;
|
||||||
|
import com.plotsquared.bukkit.listeners.PlayerEvents;
|
||||||
|
import com.plotsquared.bukkit.listeners.PlayerEvents_1_8;
|
||||||
|
import com.plotsquared.bukkit.listeners.PlayerEvents_1_8_3;
|
||||||
|
import com.plotsquared.bukkit.listeners.PlotPlusListener;
|
||||||
|
import com.plotsquared.bukkit.listeners.WorldEvents;
|
||||||
import com.plotsquared.bukkit.listeners.worldedit.WEListener;
|
import com.plotsquared.bukkit.listeners.worldedit.WEListener;
|
||||||
import com.plotsquared.bukkit.titles.DefaultTitle_19;
|
import com.plotsquared.bukkit.titles.DefaultTitle_19;
|
||||||
import com.plotsquared.bukkit.util.*;
|
import com.plotsquared.bukkit.util.BukkitChatManager;
|
||||||
import com.plotsquared.bukkit.util.block.*;
|
import com.plotsquared.bukkit.util.BukkitChunkManager;
|
||||||
import com.plotsquared.bukkit.uuid.*;
|
import com.plotsquared.bukkit.util.BukkitCommand;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitEconHandler;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitEventUtil;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitHybridUtils;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitInventoryUtil;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitPlainChatManager;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitSchematicHandler;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitSetupUtils;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitTaskManager;
|
||||||
|
import com.plotsquared.bukkit.util.BukkitUtil;
|
||||||
|
import com.plotsquared.bukkit.util.Metrics;
|
||||||
|
import com.plotsquared.bukkit.util.SendChunk;
|
||||||
|
import com.plotsquared.bukkit.util.SetGenCB;
|
||||||
|
import com.plotsquared.bukkit.util.block.FastQueue_1_7;
|
||||||
|
import com.plotsquared.bukkit.util.block.FastQueue_1_8;
|
||||||
|
import com.plotsquared.bukkit.util.block.FastQueue_1_8_3;
|
||||||
|
import com.plotsquared.bukkit.util.block.FastQueue_1_9;
|
||||||
|
import com.plotsquared.bukkit.util.block.SlowQueue;
|
||||||
|
import com.plotsquared.bukkit.uuid.DefaultUUIDWrapper;
|
||||||
|
import com.plotsquared.bukkit.uuid.FileUUIDHandler;
|
||||||
|
import com.plotsquared.bukkit.uuid.LowerOfflineUUIDWrapper;
|
||||||
|
import com.plotsquared.bukkit.uuid.OfflineUUIDWrapper;
|
||||||
|
import com.plotsquared.bukkit.uuid.SQLUUIDHandler;
|
||||||
import com.sk89q.worldedit.bukkit.WorldEditPlugin;
|
import com.sk89q.worldedit.bukkit.WorldEditPlugin;
|
||||||
import org.bukkit.*;
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.OfflinePlayer;
|
||||||
|
import org.bukkit.Server;
|
||||||
|
import org.bukkit.World;
|
||||||
import org.bukkit.command.PluginCommand;
|
import org.bukkit.command.PluginCommand;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
@ -42,7 +93,11 @@ import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
public class BukkitMain extends JavaPlugin implements Listener, IPlotMain {
|
public class BukkitMain extends JavaPlugin implements Listener, IPlotMain {
|
||||||
|
|
||||||
|
@ -87,9 +142,6 @@ public class BukkitMain extends JavaPlugin implements Listener, IPlotMain {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void log(String message) {
|
public void log(String message) {
|
||||||
if (message == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if ((THIS != null) && (Bukkit.getServer().getConsoleSender() != null)) {
|
if ((THIS != null) && (Bukkit.getServer().getConsoleSender() != null)) {
|
||||||
try {
|
try {
|
||||||
message = C.color(message);
|
message = C.color(message);
|
||||||
|
|
|
@ -27,16 +27,6 @@ import com.plotsquared.bukkit.object.BukkitLazyBlock;
|
||||||
import com.plotsquared.bukkit.object.BukkitPlayer;
|
import com.plotsquared.bukkit.object.BukkitPlayer;
|
||||||
import com.plotsquared.bukkit.util.BukkitUtil;
|
import com.plotsquared.bukkit.util.BukkitUtil;
|
||||||
import com.plotsquared.listener.PlayerBlockEventType;
|
import com.plotsquared.listener.PlayerBlockEventType;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map.Entry;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
@ -52,11 +42,13 @@ import org.bukkit.entity.EnderDragon;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.entity.EntityType;
|
import org.bukkit.entity.EntityType;
|
||||||
import org.bukkit.entity.Hanging;
|
import org.bukkit.entity.Hanging;
|
||||||
|
import org.bukkit.entity.Horse;
|
||||||
import org.bukkit.entity.HumanEntity;
|
import org.bukkit.entity.HumanEntity;
|
||||||
import org.bukkit.entity.LivingEntity;
|
import org.bukkit.entity.LivingEntity;
|
||||||
import org.bukkit.entity.Monster;
|
import org.bukkit.entity.Monster;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.entity.Projectile;
|
import org.bukkit.entity.Projectile;
|
||||||
|
import org.bukkit.entity.Skeleton;
|
||||||
import org.bukkit.entity.TNTPrimed;
|
import org.bukkit.entity.TNTPrimed;
|
||||||
import org.bukkit.entity.Tameable;
|
import org.bukkit.entity.Tameable;
|
||||||
import org.bukkit.entity.ThrownPotion;
|
import org.bukkit.entity.ThrownPotion;
|
||||||
|
@ -115,6 +107,17 @@ import org.bukkit.projectiles.BlockProjectileSource;
|
||||||
import org.bukkit.projectiles.ProjectileSource;
|
import org.bukkit.projectiles.ProjectileSource;
|
||||||
import org.bukkit.util.Vector;
|
import org.bukkit.util.Vector;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Player Events involving plots
|
* Player Events involving plots
|
||||||
*
|
*
|
||||||
|
@ -1307,9 +1310,7 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean checkEntity(final Entity entity, final Plot plot) {
|
public boolean checkEntity(final Entity entity, final Plot plot) {
|
||||||
if (plot == null || plot.owner == null || plot.settings == null || plot.getFlags().isEmpty() && plot.getArea().DEFAULT_FLAGS
|
if (plot == null || plot.owner == null || plot.getFlags().isEmpty() && plot.getArea().DEFAULT_FLAGS.isEmpty()) {
|
||||||
.isEmpty
|
|
||||||
()) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
switch (entity.getType()) {
|
switch (entity.getType()) {
|
||||||
|
@ -1324,6 +1325,10 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
case SNOWBALL:
|
case SNOWBALL:
|
||||||
case ENDER_PEARL:
|
case ENDER_PEARL:
|
||||||
case ARROW:
|
case ARROW:
|
||||||
|
case TIPPED_ARROW:
|
||||||
|
case SPECTRAL_ARROW:
|
||||||
|
case SHULKER_BULLET:
|
||||||
|
case DRAGON_FIREBALL:
|
||||||
// projectile
|
// projectile
|
||||||
case PRIMED_TNT:
|
case PRIMED_TNT:
|
||||||
case FALLING_BLOCK:
|
case FALLING_BLOCK:
|
||||||
|
@ -1336,6 +1341,7 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
case LEASH_HITCH:
|
case LEASH_HITCH:
|
||||||
case FIREWORK:
|
case FIREWORK:
|
||||||
case WEATHER:
|
case WEATHER:
|
||||||
|
case AREA_EFFECT_CLOUD:
|
||||||
case LIGHTNING:
|
case LIGHTNING:
|
||||||
case WITHER_SKULL:
|
case WITHER_SKULL:
|
||||||
case UNKNOWN:
|
case UNKNOWN:
|
||||||
|
@ -1360,7 +1366,6 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
case MUSHROOM_COW:
|
case MUSHROOM_COW:
|
||||||
case OCELOT:
|
case OCELOT:
|
||||||
case PIG:
|
case PIG:
|
||||||
case HORSE:
|
|
||||||
case SQUID:
|
case SQUID:
|
||||||
case VILLAGER:
|
case VILLAGER:
|
||||||
case IRON_GOLEM:
|
case IRON_GOLEM:
|
||||||
|
@ -1389,26 +1394,30 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
case WITCH:
|
case WITCH:
|
||||||
case WITHER:
|
case WITHER:
|
||||||
case ZOMBIE:
|
case ZOMBIE:
|
||||||
|
case SHULKER:
|
||||||
// monster
|
// monster
|
||||||
return checkEntity(plot, "entity-cap", "mob-cap", "hostile-cap");
|
return checkEntity(plot, "entity-cap", "mob-cap", "hostile-cap");
|
||||||
|
case HORSE:
|
||||||
|
Horse horse = ((Horse) entity);
|
||||||
|
if (horse.getVariant().equals(Horse.Variant.SKELETON_HORSE) && entity.getPassenger() instanceof Skeleton) {
|
||||||
|
return checkEntity(plot, "entity-cap", "mob-cap", "hostile-cap");
|
||||||
|
}
|
||||||
|
return checkEntity(plot, "entity-cap", "mob-cap", "animal-cap");
|
||||||
default:
|
default:
|
||||||
String[] types;
|
|
||||||
if (entity instanceof LivingEntity) {
|
if (entity instanceof LivingEntity) {
|
||||||
if (entity instanceof Animals) {
|
if (entity instanceof Animals) {
|
||||||
types = new String[] { "entity-cap", "mob-cap", "animal-cap" };
|
return checkEntity(plot, "entity-cap", "mob-cap", "animal-cap");
|
||||||
} else if (entity instanceof Monster) {
|
} else if (entity instanceof Monster) {
|
||||||
types = new String[] { "entity-cap", "mob-cap", "hostile-cap" };
|
return checkEntity(plot, "entity-cap", "mob-cap", "hostile-cap");
|
||||||
} else {
|
} else {
|
||||||
types = new String[] { "entity-cap", "mob-cap" };
|
return checkEntity(plot, "entity-cap", "mob-cap");
|
||||||
}
|
}
|
||||||
} else if (entity instanceof Vehicle) {
|
} else if (entity instanceof Vehicle) {
|
||||||
types = new String[] { "entity-cap", "vehicle-cap" };
|
return checkEntity(plot, "entity-cap", "vehicle-cap");
|
||||||
} else if (entity instanceof Hanging) {
|
} else if (entity instanceof Hanging) {
|
||||||
types = new String[] { "entity-cap", "misc-cap" };
|
return checkEntity(plot, "entity-cap", "misc-cap");
|
||||||
} else {
|
|
||||||
types = new String[] { "entity-cap" };
|
|
||||||
}
|
}
|
||||||
return checkEntity(plot, types);
|
return checkEntity(plot, "entity-cap");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1423,12 +1432,10 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
final Entity ent = e.getIgnitingEntity();
|
final Entity ent = e.getIgnitingEntity();
|
||||||
if (ent != null) {
|
if (ent != null) {
|
||||||
loc = BukkitUtil.getLocation(ent);
|
loc = BukkitUtil.getLocation(ent);
|
||||||
|
} else if (player != null) {
|
||||||
|
loc = BukkitUtil.getLocation(player);
|
||||||
} else {
|
} else {
|
||||||
if (player != null) {
|
return;
|
||||||
loc = BukkitUtil.getLocation(player);
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
PlotArea area = loc.getPlotArea();
|
PlotArea area = loc.getPlotArea();
|
||||||
|
@ -1511,24 +1518,22 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
}
|
}
|
||||||
} else if (lastPlot != null && now.equals(lastPlot)) {
|
} else if (lastPlot != null && now.equals(lastPlot)) {
|
||||||
return;
|
return;
|
||||||
} else {
|
} else if (!plotEntry(pp, now) && tmp_teleport) {
|
||||||
if (!plotEntry(pp, now) && tmp_teleport) {
|
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_ENTRY_DENIED);
|
||||||
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_ENTRY_DENIED);
|
if (!now.equals(area.getPlot(BukkitUtil.getLocation(from)))) {
|
||||||
if (!now.equals(area.getPlot(BukkitUtil.getLocation(from)))) {
|
tmp_teleport = false;
|
||||||
|
player.teleport(from);
|
||||||
|
tmp_teleport = true;
|
||||||
|
} else {
|
||||||
|
Location spawn = BukkitUtil.getLocation(player.getWorld().getSpawnLocation());
|
||||||
|
if (spawn.getEuclideanDistanceSquared(pp.getLocation()) > 2) {
|
||||||
tmp_teleport = false;
|
tmp_teleport = false;
|
||||||
player.teleport(from);
|
player.teleport(player.getWorld().getSpawnLocation());
|
||||||
tmp_teleport = true;
|
tmp_teleport = true;
|
||||||
} else {
|
|
||||||
Location spawn = BukkitUtil.getLocation(player.getWorld().getSpawnLocation());
|
|
||||||
if (spawn.getEuclideanDistanceSquared(pp.getLocation()) > 2) {
|
|
||||||
tmp_teleport = false;
|
|
||||||
player.teleport(player.getWorld().getSpawnLocation());
|
|
||||||
tmp_teleport = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
event.setCancelled(true);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
event.setCancelled(true);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
final Integer border = area.getBorder();
|
final Integer border = area.getBorder();
|
||||||
if (tmp_teleport) {
|
if (tmp_teleport) {
|
||||||
|
@ -1583,24 +1588,22 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
}
|
}
|
||||||
} else if (lastPlot != null && now.equals(lastPlot)) {
|
} else if (lastPlot != null && now.equals(lastPlot)) {
|
||||||
return;
|
return;
|
||||||
} else {
|
} else if (!plotEntry(pp, now) && tmp_teleport) {
|
||||||
if (!plotEntry(pp, now) && tmp_teleport) {
|
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_ENTRY_DENIED);
|
||||||
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_ENTRY_DENIED);
|
if (!now.equals(area.getPlot(BukkitUtil.getLocation(from)))) {
|
||||||
if (!now.equals(area.getPlot(BukkitUtil.getLocation(from)))) {
|
tmp_teleport = false;
|
||||||
|
player.teleport(from);
|
||||||
|
tmp_teleport = true;
|
||||||
|
} else {
|
||||||
|
Location spawn = BukkitUtil.getLocation(player.getWorld().getSpawnLocation());
|
||||||
|
if (spawn.getEuclideanDistanceSquared(pp.getLocation()) > 2) {
|
||||||
tmp_teleport = false;
|
tmp_teleport = false;
|
||||||
player.teleport(from);
|
player.teleport(player.getWorld().getSpawnLocation());
|
||||||
tmp_teleport = true;
|
tmp_teleport = true;
|
||||||
} else {
|
|
||||||
Location spawn = BukkitUtil.getLocation(player.getWorld().getSpawnLocation());
|
|
||||||
if (spawn.getEuclideanDistanceSquared(pp.getLocation()) > 2) {
|
|
||||||
tmp_teleport = false;
|
|
||||||
player.teleport(player.getWorld().getSpawnLocation());
|
|
||||||
tmp_teleport = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
event.setCancelled(true);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
event.setCancelled(true);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
final Integer border = area.getBorder();
|
final Integer border = area.getBorder();
|
||||||
if (tmp_teleport) {
|
if (tmp_teleport) {
|
||||||
|
@ -1638,24 +1641,22 @@ public class PlayerEvents extends com.plotsquared.listener.PlotListener implemen
|
||||||
}
|
}
|
||||||
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_BUILD_ROAD);
|
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_BUILD_ROAD);
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
} else {
|
} else if (!plot.hasOwner()) {
|
||||||
if (!plot.hasOwner()) {
|
if (Permissions.hasPermission(pp, C.PERMISSION_ADMIN_BUILD_UNOWNED)) {
|
||||||
if (Permissions.hasPermission(pp, C.PERMISSION_ADMIN_BUILD_UNOWNED)) {
|
return;
|
||||||
return;
|
|
||||||
}
|
|
||||||
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_BUILD_UNOWNED);
|
|
||||||
e.setCancelled(true);
|
|
||||||
} else if (!plot.isAdded(pp.getUUID())) {
|
|
||||||
final Flag use = FlagManager.getPlotFlagRaw(plot, C.FLAG_USE.s());
|
|
||||||
if (use != null && ((HashSet<PlotBlock>) use.getValue()).contains(new PlotBlock((short) e.getBucket().getId(), (byte) 0))) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (Permissions.hasPermission(pp, C.PERMISSION_ADMIN_BUILD_OTHER)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_BUILD_OTHER);
|
|
||||||
e.setCancelled(true);
|
|
||||||
}
|
}
|
||||||
|
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_BUILD_UNOWNED);
|
||||||
|
e.setCancelled(true);
|
||||||
|
} else if (!plot.isAdded(pp.getUUID())) {
|
||||||
|
final Flag use = FlagManager.getPlotFlagRaw(plot, C.FLAG_USE.s());
|
||||||
|
if (use != null && ((HashSet<PlotBlock>) use.getValue()).contains(new PlotBlock((short) e.getBucket().getId(), (byte) 0))) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (Permissions.hasPermission(pp, C.PERMISSION_ADMIN_BUILD_OTHER)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MainUtil.sendMessage(pp, C.NO_PERMISSION_EVENT, C.PERMISSION_ADMIN_BUILD_OTHER);
|
||||||
|
e.setCancelled(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,11 @@ import com.intellectualcrafters.plot.commands.WE_Anywhere;
|
||||||
import com.intellectualcrafters.plot.config.C;
|
import com.intellectualcrafters.plot.config.C;
|
||||||
import com.intellectualcrafters.plot.config.Configuration;
|
import com.intellectualcrafters.plot.config.Configuration;
|
||||||
import com.intellectualcrafters.plot.config.Settings;
|
import com.intellectualcrafters.plot.config.Settings;
|
||||||
import com.intellectualcrafters.plot.database.*;
|
import com.intellectualcrafters.plot.database.DBFunc;
|
||||||
|
import com.intellectualcrafters.plot.database.Database;
|
||||||
|
import com.intellectualcrafters.plot.database.MySQL;
|
||||||
|
import com.intellectualcrafters.plot.database.SQLManager;
|
||||||
|
import com.intellectualcrafters.plot.database.SQLite;
|
||||||
import com.intellectualcrafters.plot.flag.AbstractFlag;
|
import com.intellectualcrafters.plot.flag.AbstractFlag;
|
||||||
import com.intellectualcrafters.plot.flag.FlagManager;
|
import com.intellectualcrafters.plot.flag.FlagManager;
|
||||||
import com.intellectualcrafters.plot.flag.FlagValue;
|
import com.intellectualcrafters.plot.flag.FlagValue;
|
||||||
|
@ -16,21 +20,67 @@ import com.intellectualcrafters.plot.generator.GeneratorWrapper;
|
||||||
import com.intellectualcrafters.plot.generator.HybridPlotWorld;
|
import com.intellectualcrafters.plot.generator.HybridPlotWorld;
|
||||||
import com.intellectualcrafters.plot.generator.HybridUtils;
|
import com.intellectualcrafters.plot.generator.HybridUtils;
|
||||||
import com.intellectualcrafters.plot.generator.IndependentPlotGenerator;
|
import com.intellectualcrafters.plot.generator.IndependentPlotGenerator;
|
||||||
import com.intellectualcrafters.plot.object.*;
|
import com.intellectualcrafters.plot.object.Location;
|
||||||
import com.intellectualcrafters.plot.util.*;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotAnalysis;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotArea;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotCluster;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotFilter;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotId;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotManager;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotPlayer;
|
||||||
|
import com.intellectualcrafters.plot.object.RegionWrapper;
|
||||||
|
import com.intellectualcrafters.plot.object.RunnableVal;
|
||||||
|
import com.intellectualcrafters.plot.util.AbstractTitle;
|
||||||
|
import com.intellectualcrafters.plot.util.ChatManager;
|
||||||
|
import com.intellectualcrafters.plot.util.ChunkManager;
|
||||||
|
import com.intellectualcrafters.plot.util.CommentManager;
|
||||||
|
import com.intellectualcrafters.plot.util.EconHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.EventUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.ExpireManager;
|
||||||
|
import com.intellectualcrafters.plot.util.InventoryUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.MainUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.MathMan;
|
||||||
|
import com.intellectualcrafters.plot.util.PlotGamemode;
|
||||||
|
import com.intellectualcrafters.plot.util.PlotWeather;
|
||||||
|
import com.intellectualcrafters.plot.util.ReflectionUtils;
|
||||||
|
import com.intellectualcrafters.plot.util.SchematicHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.SetQueue;
|
||||||
|
import com.intellectualcrafters.plot.util.SetupUtils;
|
||||||
|
import com.intellectualcrafters.plot.util.StringMan;
|
||||||
|
import com.intellectualcrafters.plot.util.TaskManager;
|
||||||
|
import com.intellectualcrafters.plot.util.UUIDHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.WorldUtil;
|
||||||
import com.intellectualcrafters.plot.util.area.QuadMap;
|
import com.intellectualcrafters.plot.util.area.QuadMap;
|
||||||
import com.plotsquared.listener.WESubscriber;
|
import com.plotsquared.listener.WESubscriber;
|
||||||
import com.sk89q.worldedit.WorldEdit;
|
import com.sk89q.worldedit.WorldEdit;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.net.URLConnection;
|
import java.net.URLConnection;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.*;
|
import java.util.ArrayDeque;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Comparator;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import java.util.zip.ZipEntry;
|
import java.util.zip.ZipEntry;
|
||||||
import java.util.zip.ZipInputStream;
|
import java.util.zip.ZipInputStream;
|
||||||
|
@ -46,12 +96,7 @@ public class PS {
|
||||||
|
|
||||||
// protected static:
|
// protected static:
|
||||||
private static PS instance;
|
private static PS instance;
|
||||||
private HashSet<Integer> plotareaHashCheck = new HashSet<>();
|
private final HashSet<Integer> plotareaHashCheck = new HashSet<>();
|
||||||
private boolean plotareaHasCollision = false;
|
|
||||||
/**
|
|
||||||
* All plot areas (quick global access)
|
|
||||||
*/
|
|
||||||
private PlotArea[] plotareas = new PlotArea[0];
|
|
||||||
/**
|
/**
|
||||||
* All plot areas mapped by world (quick world access)
|
* All plot areas mapped by world (quick world access)
|
||||||
*/
|
*/
|
||||||
|
@ -73,6 +118,11 @@ public class PS {
|
||||||
public TaskManager TASK;
|
public TaskManager TASK;
|
||||||
public WorldEdit worldedit;
|
public WorldEdit worldedit;
|
||||||
public URL update;
|
public URL update;
|
||||||
|
private boolean plotareaHasCollision = false;
|
||||||
|
/**
|
||||||
|
* All plot areas (quick global access)
|
||||||
|
*/
|
||||||
|
private PlotArea[] plotareas = new PlotArea[0];
|
||||||
// private:
|
// private:
|
||||||
private File storageFile;
|
private File storageFile;
|
||||||
private File FILE = null; // This file
|
private File FILE = null; // This file
|
||||||
|
@ -2312,7 +2362,7 @@ public class PS {
|
||||||
*/
|
*/
|
||||||
private void setupStorage() {
|
private void setupStorage() {
|
||||||
storage.set("version", StringMan.join(VERSION, "."));
|
storage.set("version", StringMan.join(VERSION, "."));
|
||||||
final Map<String, Object> options = new HashMap<>();
|
final Map<String, Object> options = new HashMap<>(9);
|
||||||
options.put("mysql.use", false);
|
options.put("mysql.use", false);
|
||||||
options.put("sqlite.use", true);
|
options.put("sqlite.use", true);
|
||||||
options.put("sqlite.db", "storage");
|
options.put("sqlite.db", "storage");
|
||||||
|
@ -2343,7 +2393,7 @@ public class PS {
|
||||||
*/
|
*/
|
||||||
private void showDebug() {
|
private void showDebug() {
|
||||||
if (Settings.DEBUG) {
|
if (Settings.DEBUG) {
|
||||||
final Map<String, String> settings = new HashMap<>();
|
final Map<String, String> settings = new HashMap<>(9);
|
||||||
settings.put("Kill Road Mobs", "" + Settings.KILL_ROAD_MOBS);
|
settings.put("Kill Road Mobs", "" + Settings.KILL_ROAD_MOBS);
|
||||||
settings.put("Use Metrics", "" + Settings.METRICS);
|
settings.put("Use Metrics", "" + Settings.METRICS);
|
||||||
settings.put("Delete Plots On Ban", "" + Settings.DELETE_PLOTS_ON_BAN);
|
settings.put("Delete Plots On Ban", "" + Settings.DELETE_PLOTS_ON_BAN);
|
||||||
|
|
|
@ -20,8 +20,6 @@
|
||||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
package com.intellectualcrafters.plot.commands;
|
package com.intellectualcrafters.plot.commands;
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.config.C;
|
import com.intellectualcrafters.plot.config.C;
|
||||||
import com.intellectualcrafters.plot.database.DBFunc;
|
import com.intellectualcrafters.plot.database.DBFunc;
|
||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
|
@ -32,8 +30,9 @@ import com.intellectualcrafters.plot.object.RunnableVal;
|
||||||
import com.intellectualcrafters.plot.util.MainUtil;
|
import com.intellectualcrafters.plot.util.MainUtil;
|
||||||
import com.plotsquared.general.commands.CommandDeclaration;
|
import com.plotsquared.general.commands.CommandDeclaration;
|
||||||
|
|
||||||
@CommandDeclaration(command = "info", aliases = { "i" }, description = "Display plot info", usage = "/plot info <id>",
|
import java.util.UUID;
|
||||||
category = CommandCategory.INFO)
|
|
||||||
|
@CommandDeclaration(command = "info", aliases = "i", description = "Display plot info", usage = "/plot info <id>", category = CommandCategory.INFO)
|
||||||
public class Info extends SubCommand {
|
public class Info extends SubCommand {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -73,7 +72,7 @@ public class Info extends SubCommand {
|
||||||
plot = player.getCurrentPlot();
|
plot = player.getCurrentPlot();
|
||||||
}
|
}
|
||||||
if (plot == null) {
|
if (plot == null) {
|
||||||
MainUtil.sendMessage(player, C.NOT_IN_PLOT);
|
MainUtil.sendMessage(player, C.NOT_IN_PLOT.s());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (arg != null) {
|
if (arg != null) {
|
||||||
|
@ -116,8 +115,8 @@ public class Info extends SubCommand {
|
||||||
boolean trustedEveryone;
|
boolean trustedEveryone;
|
||||||
// Wildcard player {added}
|
// Wildcard player {added}
|
||||||
{
|
{
|
||||||
containsEveryone = (plot.getTrusted() != null) && plot.getTrusted().contains(DBFunc.everyone);
|
containsEveryone = plot.getTrusted().contains(DBFunc.everyone);
|
||||||
trustedEveryone = (plot.getMembers() != null) && plot.getMembers().contains(DBFunc.everyone);
|
trustedEveryone = plot.getMembers().contains(DBFunc.everyone);
|
||||||
}
|
}
|
||||||
// Unclaimed?
|
// Unclaimed?
|
||||||
if (!hasOwner && !containsEveryone && !trustedEveryone) {
|
if (!hasOwner && !containsEveryone && !trustedEveryone) {
|
||||||
|
|
|
@ -41,7 +41,6 @@ import com.plotsquared.general.commands.CommandManager;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -53,8 +52,7 @@ import java.util.List;
|
||||||
public class MainCommand extends CommandManager<PlotPlayer> {
|
public class MainCommand extends CommandManager<PlotPlayer> {
|
||||||
|
|
||||||
private static MainCommand instance;
|
private static MainCommand instance;
|
||||||
private HashMap<String, Command<PlotPlayer>> setCommands;
|
|
||||||
|
|
||||||
private MainCommand() {
|
private MainCommand() {
|
||||||
super(null, new ArrayList<Command<PlotPlayer>>());
|
super(null, new ArrayList<Command<PlotPlayer>>());
|
||||||
instance = this;
|
instance = this;
|
||||||
|
@ -282,8 +280,8 @@ public class MainCommand extends CommandManager<PlotPlayer> {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// Save meta
|
// Save meta
|
||||||
loc = (Location) player.getMeta("location");
|
loc = player.getMeta("location");
|
||||||
plot = (Plot) player.getMeta("lastplot");
|
plot = player.getMeta("lastplot");
|
||||||
tp = true;
|
tp = true;
|
||||||
// Set loc
|
// Set loc
|
||||||
player.setMeta("location", newPlot.getBottomAbs());
|
player.setMeta("location", newPlot.getBottomAbs());
|
||||||
|
@ -320,7 +318,7 @@ public class MainCommand extends CommandManager<PlotPlayer> {
|
||||||
public int getMatch(String[] args, Command<PlotPlayer> cmd) {
|
public int getMatch(String[] args, Command<PlotPlayer> cmd) {
|
||||||
int count = 0;
|
int count = 0;
|
||||||
String perm = cmd.getPermission();
|
String perm = cmd.getPermission();
|
||||||
HashSet<String> desc = new HashSet<String>();
|
HashSet<String> desc = new HashSet<>();
|
||||||
for (String alias : cmd.getAliases()) {
|
for (String alias : cmd.getAliases()) {
|
||||||
if (alias.startsWith(args[0])) {
|
if (alias.startsWith(args[0])) {
|
||||||
count += 5;
|
count += 5;
|
||||||
|
|
|
@ -122,18 +122,10 @@ public class Settings {
|
||||||
* Max allowed plots
|
* Max allowed plots
|
||||||
*/
|
*/
|
||||||
public static int MAX_PLOTS = 127;
|
public static int MAX_PLOTS = 127;
|
||||||
/**
|
|
||||||
* WorldGuard region on claimed plots
|
|
||||||
*/
|
|
||||||
public static boolean WORLDGUARD = false;
|
|
||||||
/**
|
/**
|
||||||
* metrics
|
* metrics
|
||||||
*/
|
*/
|
||||||
public static boolean METRICS = true;
|
public static boolean METRICS = true;
|
||||||
/**
|
|
||||||
* plot specific resource pack
|
|
||||||
*/
|
|
||||||
public static String PLOT_SPECIFIC_RESOURCE_PACK = "";
|
|
||||||
/**
|
/**
|
||||||
* Kill road mobs?
|
* Kill road mobs?
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -25,15 +25,37 @@ import com.intellectualcrafters.plot.PS;
|
||||||
import com.intellectualcrafters.plot.config.Settings;
|
import com.intellectualcrafters.plot.config.Settings;
|
||||||
import com.intellectualcrafters.plot.flag.Flag;
|
import com.intellectualcrafters.plot.flag.Flag;
|
||||||
import com.intellectualcrafters.plot.flag.FlagManager;
|
import com.intellectualcrafters.plot.flag.FlagManager;
|
||||||
import com.intellectualcrafters.plot.object.*;
|
import com.intellectualcrafters.plot.object.BlockLoc;
|
||||||
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotArea;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotCluster;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotId;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotSettings;
|
||||||
|
import com.intellectualcrafters.plot.object.RunnableVal;
|
||||||
import com.intellectualcrafters.plot.object.comment.PlotComment;
|
import com.intellectualcrafters.plot.object.comment.PlotComment;
|
||||||
import com.intellectualcrafters.plot.util.MainUtil;
|
import com.intellectualcrafters.plot.util.MainUtil;
|
||||||
import com.intellectualcrafters.plot.util.StringMan;
|
import com.intellectualcrafters.plot.util.StringMan;
|
||||||
import com.intellectualcrafters.plot.util.TaskManager;
|
import com.intellectualcrafters.plot.util.TaskManager;
|
||||||
|
|
||||||
import java.sql.*;
|
import java.sql.Connection;
|
||||||
import java.util.*;
|
import java.sql.DatabaseMetaData;
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Statement;
|
||||||
|
import java.sql.Timestamp;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Queue;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.ConcurrentLinkedQueue;
|
import java.util.concurrent.ConcurrentLinkedQueue;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
@ -1224,9 +1246,6 @@ public class SQLManager implements AbstractDB {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void deleteSettings(final Plot plot) {
|
public void deleteSettings(final Plot plot) {
|
||||||
if (plot.settings == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
addPlotTask(plot, new UniqueStatement("delete_plot_settings") {
|
addPlotTask(plot, new UniqueStatement("delete_plot_settings") {
|
||||||
@Override
|
@Override
|
||||||
public void set(final PreparedStatement stmt) throws SQLException {
|
public void set(final PreparedStatement stmt) throws SQLException {
|
||||||
|
@ -1669,10 +1688,7 @@ public class SQLManager implements AbstractDB {
|
||||||
}
|
}
|
||||||
final Plot plot = plots.get(id);
|
final Plot plot = plots.get(id);
|
||||||
if (plot != null) {
|
if (plot != null) {
|
||||||
if (plot.getSettings().ratings == null) {
|
plot.getSettings().getRatings().put(user, r.getInt("rating"));
|
||||||
plot.getSettings().ratings = new HashMap<>();
|
|
||||||
}
|
|
||||||
plot.getSettings().ratings.put(user, r.getInt("rating"));
|
|
||||||
} else if (Settings.AUTO_PURGE) {
|
} else if (Settings.AUTO_PURGE) {
|
||||||
toDelete.add(id);
|
toDelete.add(id);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -115,9 +115,7 @@ public abstract class SquarePlotManager extends GridPlotManager {
|
||||||
end = pathWidthLower + dpw.PLOT_WIDTH;
|
end = pathWidthLower + dpw.PLOT_WIDTH;
|
||||||
}
|
}
|
||||||
int dx;
|
int dx;
|
||||||
int dz;
|
|
||||||
int rx;
|
int rx;
|
||||||
int rz;
|
|
||||||
if (x < 0) {
|
if (x < 0) {
|
||||||
dx = (x / size);
|
dx = (x / size);
|
||||||
rx = size + (x % size);
|
rx = size + (x % size);
|
||||||
|
@ -125,6 +123,8 @@ public abstract class SquarePlotManager extends GridPlotManager {
|
||||||
dx = (x / size) + 1;
|
dx = (x / size) + 1;
|
||||||
rx = (x % size);
|
rx = (x % size);
|
||||||
}
|
}
|
||||||
|
int dz;
|
||||||
|
int rz;
|
||||||
if (z < 0) {
|
if (z < 0) {
|
||||||
dz = (z / size);
|
dz = (z / size);
|
||||||
rz = size + (z % size);
|
rz = size + (z % size);
|
||||||
|
|
|
@ -29,18 +29,34 @@ import com.intellectualcrafters.plot.config.Settings;
|
||||||
import com.intellectualcrafters.plot.database.DBFunc;
|
import com.intellectualcrafters.plot.database.DBFunc;
|
||||||
import com.intellectualcrafters.plot.flag.Flag;
|
import com.intellectualcrafters.plot.flag.Flag;
|
||||||
import com.intellectualcrafters.plot.flag.FlagManager;
|
import com.intellectualcrafters.plot.flag.FlagManager;
|
||||||
import com.intellectualcrafters.plot.util.*;
|
import com.intellectualcrafters.plot.util.BO3Handler;
|
||||||
|
import com.intellectualcrafters.plot.util.ChunkManager;
|
||||||
|
import com.intellectualcrafters.plot.util.EventUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.MainUtil;
|
||||||
|
import com.intellectualcrafters.plot.util.Permissions;
|
||||||
|
import com.intellectualcrafters.plot.util.SchematicHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.SetQueue;
|
||||||
|
import com.intellectualcrafters.plot.util.TaskManager;
|
||||||
|
import com.intellectualcrafters.plot.util.UUIDHandler;
|
||||||
|
import com.intellectualcrafters.plot.util.WorldUtil;
|
||||||
import com.plotsquared.listener.PlotListener;
|
import com.plotsquared.listener.PlotListener;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.Rectangle;
|
||||||
import java.awt.geom.Area;
|
import java.awt.geom.Area;
|
||||||
import java.awt.geom.PathIterator;
|
import java.awt.geom.PathIterator;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.*;
|
import java.util.ArrayDeque;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
|
@ -61,11 +77,9 @@ public class Plot {
|
||||||
private static HashSet<Plot> connected_cache;
|
private static HashSet<Plot> connected_cache;
|
||||||
private static HashSet<RegionWrapper> regions_cache;
|
private static HashSet<RegionWrapper> regions_cache;
|
||||||
/**
|
/**
|
||||||
* plot ID
|
* The {@link PlotId}
|
||||||
* Direct access is Deprecated: use getId()
|
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
private final PlotId id;
|
||||||
public final PlotId id;
|
|
||||||
/**
|
/**
|
||||||
* plot owner
|
* plot owner
|
||||||
* (Merged plots can have multiple owners)
|
* (Merged plots can have multiple owners)
|
||||||
|
@ -73,39 +87,6 @@ public class Plot {
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public UUID owner;
|
public UUID owner;
|
||||||
/**
|
|
||||||
* Plot creation timestamp (not accurate if the plot was created before this was implemented)<br>
|
|
||||||
* - Milliseconds since the epoch<br>
|
|
||||||
* Direct access is Deprecated: use {@link #getTimestamp() getTimestamp}
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public long timestamp;
|
|
||||||
/**
|
|
||||||
* List of trusted (with plot permissions)
|
|
||||||
* Direct access is Deprecated: use getTrusted()
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public HashSet<UUID> trusted;
|
|
||||||
/**
|
|
||||||
* List of members users (with plot permissions)
|
|
||||||
* Direct access is Deprecated: use getMembers()
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public HashSet<UUID> members;
|
|
||||||
/**
|
|
||||||
* List of denied players
|
|
||||||
* Direct access is Deprecated: use getDenied()
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public HashSet<UUID> denied;
|
|
||||||
/**
|
|
||||||
* External settings class<br>
|
|
||||||
* - Please favor the methods over direct access to this class<br>
|
|
||||||
* - The methods are more likely to be left unchanged from version changes<br>
|
|
||||||
* Direct access is Deprecated: use getSettings()
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public PlotSettings settings;
|
|
||||||
/**
|
/**
|
||||||
* Has the plot changed since the last save cycle?
|
* Has the plot changed since the last save cycle?
|
||||||
*/
|
*/
|
||||||
|
@ -119,8 +100,30 @@ public class Plot {
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public int temp;
|
public int temp;
|
||||||
/**
|
/**
|
||||||
* plot world
|
* Plot creation timestamp (not accurate if the plot was created before this was implemented)<br>
|
||||||
* Direct access is Deprecated: use getWorld()
|
* - Milliseconds since the epoch<br>
|
||||||
|
*/
|
||||||
|
private long timestamp;
|
||||||
|
/**
|
||||||
|
* List of trusted (with plot permissions)
|
||||||
|
*/
|
||||||
|
private HashSet<UUID> trusted;
|
||||||
|
/**
|
||||||
|
* List of members users (with plot permissions)
|
||||||
|
*/
|
||||||
|
private HashSet<UUID> members;
|
||||||
|
/**
|
||||||
|
* List of denied players
|
||||||
|
*/
|
||||||
|
private HashSet<UUID> denied;
|
||||||
|
/**
|
||||||
|
* External settings class<br>
|
||||||
|
* - Please favor the methods over direct access to this class<br>
|
||||||
|
* - The methods are more likely to be left unchanged from version changes<br>
|
||||||
|
*/
|
||||||
|
private PlotSettings settings;
|
||||||
|
/**
|
||||||
|
* The {@link PlotArea}
|
||||||
*/
|
*/
|
||||||
private PlotArea area;
|
private PlotArea area;
|
||||||
/**
|
/**
|
||||||
|
@ -486,10 +489,7 @@ public class Plot {
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public boolean isBasePlot() {
|
public boolean isBasePlot() {
|
||||||
if ((this.settings == null) || !this.isMerged()) {
|
return !this.isMerged() || this.equals(this.getBasePlot(false));
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return this.equals(this.getBasePlot(false));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -530,10 +530,7 @@ public class Plot {
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public boolean isMerged() {
|
public boolean isMerged() {
|
||||||
if (this.settings == null) {
|
return getSettings().getMerged(0) || getSettings().getMerged(2) || getSettings().getMerged(1) || getSettings().getMerged(3);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return this.settings.getMerged(0) || this.settings.getMerged(2) || this.settings.getMerged(1) || this.settings.getMerged(3);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -567,40 +564,41 @@ public class Plot {
|
||||||
* @return true if merged in that direction
|
* @return true if merged in that direction
|
||||||
*/
|
*/
|
||||||
public boolean getMerged(final int direction) {
|
public boolean getMerged(final int direction) {
|
||||||
if (this.settings == null) {
|
if (isMerged()) {
|
||||||
return false;
|
switch (direction) {
|
||||||
}
|
case 0:
|
||||||
switch (direction) {
|
case 1:
|
||||||
case 0:
|
case 2:
|
||||||
case 1:
|
case 3:
|
||||||
case 2:
|
return this.getSettings().getMerged(direction);
|
||||||
case 3:
|
case 7:
|
||||||
return this.settings.getMerged(direction);
|
int i = direction - 4;
|
||||||
case 7:
|
int i2 = 0;
|
||||||
int i = direction - 4;
|
if (this.getSettings().getMerged(i2)) {
|
||||||
int i2 = 0;
|
if (this.getSettings().getMerged(i)) {
|
||||||
if (this.settings.getMerged(i2)) {
|
if (this.area.getPlotAbs(this.id.getRelative(i)).getMerged(i2)) {
|
||||||
if (this.settings.getMerged(i)) {
|
if (this.area.getPlotAbs(this.id.getRelative(i2)).getMerged(i)) {
|
||||||
if (this.area.getPlotAbs(this.id.getRelative(i)).getMerged(i2)) {
|
return true;
|
||||||
if (this.area.getPlotAbs(this.id.getRelative(i2)).getMerged(i)) {
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
return false;
|
||||||
return false;
|
case 4:
|
||||||
case 4:
|
case 5:
|
||||||
case 5:
|
case 6:
|
||||||
case 6:
|
i = direction - 4;
|
||||||
i = direction - 4;
|
i2 = direction - 3;
|
||||||
i2 = direction - 3;
|
return this.getSettings().getMerged(i2)
|
||||||
return this.settings.getMerged(i2)
|
&& this.getSettings().getMerged(i)
|
||||||
&& this.settings.getMerged(i)
|
&& this.area.getPlotAbs(this.id.getRelative(i)).getMerged(i2)
|
||||||
&& this.area.getPlotAbs(this.id.getRelative(i)).getMerged(i2)
|
&& this.area.getPlotAbs(this.id.getRelative(i2)).getMerged(i);
|
||||||
&& this.area.getPlotAbs(this.id.getRelative(i2)).getMerged(i);
|
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1132,16 +1130,12 @@ public class Plot {
|
||||||
*/
|
*/
|
||||||
public void setHome(final BlockLoc loc) {
|
public void setHome(final BlockLoc loc) {
|
||||||
final BlockLoc pos = this.getSettings().getPosition();
|
final BlockLoc pos = this.getSettings().getPosition();
|
||||||
if ((((pos == null) || pos.equals(new BlockLoc(0, 0, 0))) && (loc == null)) || ((pos != null) && pos.equals(loc))) {
|
if (pos.equals(new BlockLoc(0, 0, 0)) && loc == null || pos.equals(loc)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final Plot plot = this.getBasePlot(false);
|
final Plot plot = this.getBasePlot(false);
|
||||||
plot.getSettings().setPosition(loc);
|
plot.getSettings().setPosition(loc);
|
||||||
if (plot.getSettings().getPosition() == null) {
|
DBFunc.setPosition(plot, this.getSettings().getPosition().toString());
|
||||||
DBFunc.setPosition(plot, "");
|
|
||||||
} else {
|
|
||||||
DBFunc.setPosition(plot, this.getSettings().getPosition().toString());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1240,11 +1234,7 @@ public class Plot {
|
||||||
|
|
||||||
public boolean hasRatings() {
|
public boolean hasRatings() {
|
||||||
Plot base = this.getBasePlot(false);
|
Plot base = this.getBasePlot(false);
|
||||||
if (base.settings != null && base.settings.ratings != null) {
|
return base.settings != null && base.settings.ratings != null;
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1368,7 +1358,7 @@ public class Plot {
|
||||||
this.getDenied().clear();
|
this.getDenied().clear();
|
||||||
this.settings = new PlotSettings();
|
this.settings = new PlotSettings();
|
||||||
if (this.area.addPlot(this)) {
|
if (this.area.addPlot(this)) {
|
||||||
DBFunc.createPlotAndSettings(Plot.this, new Runnable() {
|
DBFunc.createPlotAndSettings(this, new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
final PlotArea plotworld = Plot.this.area;
|
final PlotArea plotworld = Plot.this.area;
|
||||||
|
@ -1910,10 +1900,7 @@ public class Plot {
|
||||||
* @return boolean [ north, east, south, west ]
|
* @return boolean [ north, east, south, west ]
|
||||||
*/
|
*/
|
||||||
public boolean[] getMerged() {
|
public boolean[] getMerged() {
|
||||||
if (this.settings == null) {
|
return this.getSettings().getMerged();
|
||||||
return new boolean[] { false, false, false, false };
|
|
||||||
}
|
|
||||||
return this.settings.getMerged();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1948,10 +1935,7 @@ public class Plot {
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public BlockLoc getPosition() {
|
public BlockLoc getPosition() {
|
||||||
if (this.settings == null) {
|
return this.getSettings().getPosition();
|
||||||
return new BlockLoc(0, 0, 0);
|
|
||||||
}
|
|
||||||
return this.settings.getPosition();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2256,10 +2240,10 @@ public class Plot {
|
||||||
PS.debug("Fixing invalid merge: " + this);
|
PS.debug("Fixing invalid merge: " + this);
|
||||||
if (tmp.isOwnerAbs(owner)) {
|
if (tmp.isOwnerAbs(owner)) {
|
||||||
tmp.getSettings().setMerged(2, true);
|
tmp.getSettings().setMerged(2, true);
|
||||||
DBFunc.setMerged(tmp, tmp.settings.getMerged());
|
DBFunc.setMerged(tmp, tmp.getSettings().getMerged());
|
||||||
} else {
|
} else {
|
||||||
this.getSettings().setMerged(0, false);
|
this.getSettings().setMerged(0, false);
|
||||||
DBFunc.setMerged(this, this.settings.getMerged());
|
DBFunc.setMerged(this, this.getSettings().getMerged());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
queuecache.add(tmp);
|
queuecache.add(tmp);
|
||||||
|
@ -2272,10 +2256,10 @@ public class Plot {
|
||||||
PS.debug("Fixing invalid merge: " + this);
|
PS.debug("Fixing invalid merge: " + this);
|
||||||
if (tmp.isOwnerAbs(owner)) {
|
if (tmp.isOwnerAbs(owner)) {
|
||||||
tmp.getSettings().setMerged(3, true);
|
tmp.getSettings().setMerged(3, true);
|
||||||
DBFunc.setMerged(tmp, tmp.settings.getMerged());
|
DBFunc.setMerged(tmp, tmp.getSettings().getMerged());
|
||||||
} else {
|
} else {
|
||||||
this.getSettings().setMerged(1, false);
|
this.getSettings().setMerged(1, false);
|
||||||
DBFunc.setMerged(this, this.settings.getMerged());
|
DBFunc.setMerged(this, this.getSettings().getMerged());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
queuecache.add(tmp);
|
queuecache.add(tmp);
|
||||||
|
@ -2288,10 +2272,10 @@ public class Plot {
|
||||||
PS.debug("Fixing invalid merge: " + this);
|
PS.debug("Fixing invalid merge: " + this);
|
||||||
if (tmp.isOwnerAbs(owner)) {
|
if (tmp.isOwnerAbs(owner)) {
|
||||||
tmp.getSettings().setMerged(0, true);
|
tmp.getSettings().setMerged(0, true);
|
||||||
DBFunc.setMerged(tmp, tmp.settings.getMerged());
|
DBFunc.setMerged(tmp, tmp.getSettings().getMerged());
|
||||||
} else {
|
} else {
|
||||||
this.getSettings().setMerged(2, false);
|
this.getSettings().setMerged(2, false);
|
||||||
DBFunc.setMerged(this, this.settings.getMerged());
|
DBFunc.setMerged(this, this.getSettings().getMerged());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
queuecache.add(tmp);
|
queuecache.add(tmp);
|
||||||
|
@ -2304,10 +2288,10 @@ public class Plot {
|
||||||
PS.debug("Fixing invalid merge: " + this);
|
PS.debug("Fixing invalid merge: " + this);
|
||||||
if (tmp.isOwnerAbs(owner)) {
|
if (tmp.isOwnerAbs(owner)) {
|
||||||
tmp.getSettings().setMerged(1, true);
|
tmp.getSettings().setMerged(1, true);
|
||||||
DBFunc.setMerged(tmp, tmp.settings.getMerged());
|
DBFunc.setMerged(tmp, tmp.getSettings().getMerged());
|
||||||
} else {
|
} else {
|
||||||
this.getSettings().setMerged(3, false);
|
this.getSettings().setMerged(3, false);
|
||||||
DBFunc.setMerged(this, this.settings.getMerged());
|
DBFunc.setMerged(this, this.getSettings().getMerged());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
queuecache.add(tmp);
|
queuecache.add(tmp);
|
||||||
|
@ -2324,6 +2308,9 @@ public class Plot {
|
||||||
connected_cache.add(current);
|
connected_cache.add(current);
|
||||||
queuecache.remove(current);
|
queuecache.remove(current);
|
||||||
merged = current.getMerged();
|
merged = current.getMerged();
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
|
||||||
|
}
|
||||||
if (merged[0]) {
|
if (merged[0]) {
|
||||||
tmp = current.area.getPlotAbs(current.id.getRelative(0));
|
tmp = current.area.getPlotAbs(current.id.getRelative(0));
|
||||||
if ((tmp != null) && !queuecache.contains(tmp) && !connected_cache.contains(tmp)) {
|
if ((tmp != null) && !queuecache.contains(tmp) && !connected_cache.contains(tmp)) {
|
||||||
|
@ -2794,7 +2781,7 @@ public class Plot {
|
||||||
for (final Plot plot : plots) {
|
for (final Plot plot : plots) {
|
||||||
final Plot other = plot.getRelative(offset.x, offset.y);
|
final Plot other = plot.getRelative(offset.x, offset.y);
|
||||||
other.create(other.owner, false);
|
other.create(other.owner, false);
|
||||||
if ((plot.getFlags() != null) && !plot.getFlags().isEmpty()) {
|
if (!plot.getFlags().isEmpty()) {
|
||||||
other.getSettings().flags = plot.getFlags();
|
other.getSettings().flags = plot.getFlags();
|
||||||
DBFunc.setFlags(other, plot.getFlags().values());
|
DBFunc.setFlags(other, plot.getFlags().values());
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,7 +44,7 @@ public class StringMan {
|
||||||
if (obj == null) {
|
if (obj == null) {
|
||||||
return "null";
|
return "null";
|
||||||
}
|
}
|
||||||
if (obj.getClass() == String.class) {
|
if (obj instanceof String) {
|
||||||
return (String) obj;
|
return (String) obj;
|
||||||
}
|
}
|
||||||
if (obj.getClass().isArray()) {
|
if (obj.getClass().isArray()) {
|
||||||
|
|
Loading…
Reference in a new issue