mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-22 21:26:45 +01:00
Cleanup
This commit is contained in:
parent
ce387333d2
commit
cf517d5be0
5
pom.xml
5
pom.xml
@ -147,11 +147,6 @@
|
|||||||
<artifactId>javax.websocket-api</artifactId>
|
<artifactId>javax.websocket-api</artifactId>
|
||||||
<version>1.1</version>
|
<version>1.1</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<!--<dependency>
|
|
||||||
<groupId>org.spongepowered</groupId>
|
|
||||||
<artifactId>sponge</artifactId>
|
|
||||||
<version>1.8-1519-2.1DEV-693</version>
|
|
||||||
</dependency>-->
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.spongepowered</groupId>
|
<groupId>org.spongepowered</groupId>
|
||||||
<artifactId>spongeapi</artifactId>
|
<artifactId>spongeapi</artifactId>
|
||||||
|
@ -381,7 +381,7 @@ public class PlotAPI {
|
|||||||
* @see MainUtil#sendConsoleMessage(String)
|
* @see MainUtil#sendConsoleMessage(String)
|
||||||
*/
|
*/
|
||||||
public void sendConsoleMessage(final String msg) {
|
public void sendConsoleMessage(final String msg) {
|
||||||
MainUtil.sendConsoleMessage(msg);
|
PS.log(msg);;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -112,8 +112,8 @@ public class Cluster extends SubCommand {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// check pos1 / pos2
|
// check pos1 / pos2
|
||||||
PlotId pos1 = MainUtil.parseId(args[2]);
|
PlotId pos1 = PlotId.fromString(args[2]);
|
||||||
PlotId pos2 = MainUtil.parseId(args[3]);
|
PlotId pos2 = PlotId.fromString(args[3]);
|
||||||
if ((pos1 == null) || (pos2 == null)) {
|
if ((pos1 == null) || (pos2 == null)) {
|
||||||
MainUtil.sendMessage(plr, C.NOT_VALID_PLOT_ID);
|
MainUtil.sendMessage(plr, C.NOT_VALID_PLOT_ID);
|
||||||
return false;
|
return false;
|
||||||
|
@ -126,27 +126,22 @@ public class Configuration {
|
|||||||
@Override
|
@Override
|
||||||
public boolean validateValue(final String string) {
|
public boolean validateValue(final String string) {
|
||||||
try {
|
try {
|
||||||
if (string.contains(":")) {
|
final StringComparison<PlotBlock>.ComparisonResult value = BlockManager.manager.getClosestBlock(string);
|
||||||
final String[] split = string.split(":");
|
if ((value == null) || (value.match > 1)) {
|
||||||
Short.parseShort(split[0]);
|
|
||||||
Short.parseShort(split[1]);
|
|
||||||
} else {
|
|
||||||
Short.parseShort(string);
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
} catch (final Exception e) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
|
} catch (final Exception e) {}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PlotBlock parseString(final String string) {
|
public PlotBlock parseString(final String string) {
|
||||||
if (string.contains(":")) {
|
final StringComparison<PlotBlock>.ComparisonResult value = BlockManager.manager.getClosestBlock(string);
|
||||||
final String[] split = string.split(":");
|
if ((value == null) || (value.match > 1)) {
|
||||||
return new PlotBlock(Short.parseShort(split[0]), Byte.parseByte(split[1]));
|
return null;
|
||||||
} else {
|
|
||||||
return new PlotBlock(Short.parseShort(string), (byte) 0);
|
|
||||||
}
|
}
|
||||||
|
return value.best;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
public static final SettingValue<PlotBlock[]> BLOCKLIST = new SettingValue<PlotBlock[]>("BLOCKLIST") {
|
public static final SettingValue<PlotBlock[]> BLOCKLIST = new SettingValue<PlotBlock[]>("BLOCKLIST") {
|
||||||
|
@ -6,6 +6,8 @@ import java.util.HashSet;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.PlotBlock;
|
import com.intellectualcrafters.plot.object.PlotBlock;
|
||||||
|
import com.intellectualcrafters.plot.util.BlockManager;
|
||||||
|
import com.intellectualcrafters.plot.util.StringComparison;
|
||||||
import com.intellectualcrafters.plot.util.StringMan;
|
import com.intellectualcrafters.plot.util.StringMan;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -276,8 +278,12 @@ public abstract class FlagValue<T> {
|
|||||||
final short id = Short.parseShort(split[0]);
|
final short id = Short.parseShort(split[0]);
|
||||||
return new PlotBlock(id, data);
|
return new PlotBlock(id, data);
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
|
final StringComparison<PlotBlock>.ComparisonResult value = BlockManager.manager.getClosestBlock(t);
|
||||||
|
if ((value == null) || (value.match > 1)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
return value.best;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -309,6 +315,8 @@ public abstract class FlagValue<T> {
|
|||||||
public HashSet<PlotBlock> parse(final String t) {
|
public HashSet<PlotBlock> parse(final String t) {
|
||||||
final HashSet<PlotBlock> list = new HashSet<PlotBlock>();
|
final HashSet<PlotBlock> list = new HashSet<PlotBlock>();
|
||||||
for (final String item : t.split(",")) {
|
for (final String item : t.split(",")) {
|
||||||
|
PlotBlock block;
|
||||||
|
try {
|
||||||
final String[] split = item.split(":");
|
final String[] split = item.split(":");
|
||||||
byte data;
|
byte data;
|
||||||
if (split.length == 2) {
|
if (split.length == 2) {
|
||||||
@ -321,7 +329,14 @@ public abstract class FlagValue<T> {
|
|||||||
data = -1;
|
data = -1;
|
||||||
}
|
}
|
||||||
final short id = Short.parseShort(split[0]);
|
final short id = Short.parseShort(split[0]);
|
||||||
final PlotBlock block = new PlotBlock(id, data);
|
block = new PlotBlock(id, data);
|
||||||
|
} catch (Exception e) {
|
||||||
|
final StringComparison<PlotBlock>.ComparisonResult value = BlockManager.manager.getClosestBlock(t);
|
||||||
|
if ((value == null) || (value.match > 1)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
block = value.best;
|
||||||
|
}
|
||||||
list.add(block);
|
list.add(block);
|
||||||
}
|
}
|
||||||
return list;
|
return list;
|
||||||
|
@ -53,8 +53,6 @@ public abstract class PlotWorld {
|
|||||||
public final static double PLOT_PRICE_DEFAULT = 100;
|
public final static double PLOT_PRICE_DEFAULT = 100;
|
||||||
public final static double MERGE_PRICE_DEFAULT = 100;
|
public final static double MERGE_PRICE_DEFAULT = 100;
|
||||||
public final static double SELL_PRICE_DEFAULT = 75;
|
public final static double SELL_PRICE_DEFAULT = 75;
|
||||||
public final static boolean PVP_DEFAULT = false;
|
|
||||||
public final static boolean PVE_DEFAULT = false;
|
|
||||||
public final static boolean SPAWN_EGGS_DEFAULT = false;
|
public final static boolean SPAWN_EGGS_DEFAULT = false;
|
||||||
public final static boolean SPAWN_CUSTOM_DEFAULT = true;
|
public final static boolean SPAWN_CUSTOM_DEFAULT = true;
|
||||||
public final static boolean SPAWN_BREEDING_DEFAULT = false;
|
public final static boolean SPAWN_BREEDING_DEFAULT = false;
|
||||||
@ -80,8 +78,6 @@ public abstract class PlotWorld {
|
|||||||
public double PLOT_PRICE;
|
public double PLOT_PRICE;
|
||||||
public double MERGE_PRICE;
|
public double MERGE_PRICE;
|
||||||
public double SELL_PRICE;
|
public double SELL_PRICE;
|
||||||
public boolean PVP;
|
|
||||||
public boolean PVE;
|
|
||||||
public boolean SPAWN_EGGS;
|
public boolean SPAWN_EGGS;
|
||||||
public boolean SPAWN_CUSTOM;
|
public boolean SPAWN_CUSTOM;
|
||||||
public boolean SPAWN_BREEDING;
|
public boolean SPAWN_BREEDING;
|
||||||
@ -219,8 +215,6 @@ public abstract class PlotWorld {
|
|||||||
PS.debug("&cInvalid default flags for " + worldname + ": " + StringMan.join(flags, ","));
|
PS.debug("&cInvalid default flags for " + worldname + ": " + StringMan.join(flags, ","));
|
||||||
DEFAULT_FLAGS = new HashMap<>();
|
DEFAULT_FLAGS = new HashMap<>();
|
||||||
}
|
}
|
||||||
PVP = config.getBoolean("event.pvp");
|
|
||||||
PVE = config.getBoolean("event.pve");
|
|
||||||
SPAWN_EGGS = config.getBoolean("event.spawn.egg");
|
SPAWN_EGGS = config.getBoolean("event.spawn.egg");
|
||||||
SPAWN_CUSTOM = config.getBoolean("event.spawn.custom");
|
SPAWN_CUSTOM = config.getBoolean("event.spawn.custom");
|
||||||
SPAWN_BREEDING = config.getBoolean("event.spawn.breeding");
|
SPAWN_BREEDING = config.getBoolean("event.spawn.breeding");
|
||||||
@ -250,8 +244,6 @@ public abstract class PlotWorld {
|
|||||||
options.put("economy.prices.sell", PlotWorld.SELL_PRICE_DEFAULT);
|
options.put("economy.prices.sell", PlotWorld.SELL_PRICE_DEFAULT);
|
||||||
options.put("chat.enabled", PlotWorld.PLOT_CHAT_DEFAULT);
|
options.put("chat.enabled", PlotWorld.PLOT_CHAT_DEFAULT);
|
||||||
options.put("flags.default", null);
|
options.put("flags.default", null);
|
||||||
options.put("event.pvp", PlotWorld.PVP_DEFAULT);
|
|
||||||
options.put("event.pve", PlotWorld.PVE_DEFAULT);
|
|
||||||
options.put("event.spawn.egg", PlotWorld.SPAWN_EGGS_DEFAULT);
|
options.put("event.spawn.egg", PlotWorld.SPAWN_EGGS_DEFAULT);
|
||||||
options.put("event.spawn.custom", PlotWorld.SPAWN_CUSTOM_DEFAULT);
|
options.put("event.spawn.custom", PlotWorld.SPAWN_CUSTOM_DEFAULT);
|
||||||
options.put("event.spawn.breeding", PlotWorld.SPAWN_BREEDING_DEFAULT);
|
options.put("event.spawn.breeding", PlotWorld.SPAWN_BREEDING_DEFAULT);
|
||||||
|
@ -66,14 +66,42 @@ import com.plotsquared.listener.PlotListener;
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class MainUtil {
|
public class MainUtil {
|
||||||
|
/**
|
||||||
|
* The runners are a list of plots that have currect asynchronous actions taking place.<br>
|
||||||
|
* - At some point this could be replaced by using the plot metadata
|
||||||
|
*/
|
||||||
public final static HashMap<Plot, Integer> runners = new HashMap<>();
|
public final static HashMap<Plot, Integer> runners = new HashMap<>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If the NMS code for sending chunk updates is functional<br>
|
||||||
|
* - E.g. If using an older version of Bukkit, or before the plugin is updated to 1.5<br>
|
||||||
|
* - Slower fallback code will be used if not.<br>
|
||||||
|
*/
|
||||||
public static boolean canSendChunk = false;
|
public static boolean canSendChunk = false;
|
||||||
public static boolean canSetFast = true;
|
|
||||||
public static ArrayList<String> runners_p = new ArrayList<>();
|
/**
|
||||||
|
* Cache for last auto claimed plot.<br>
|
||||||
|
* - Used for efficiently calculating the next claimable plot<br>
|
||||||
|
*/
|
||||||
public static HashMap<String, PlotId> lastPlot = new HashMap<>();
|
public static HashMap<String, PlotId> lastPlot = new HashMap<>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cache of the furthest claimed plot<br>
|
||||||
|
* - Used for efficiently calculating the plot border distance
|
||||||
|
*/
|
||||||
public static HashMap<String, Integer> worldBorder = new HashMap<>();
|
public static HashMap<String, Integer> worldBorder = new HashMap<>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pseudorandom object<br>
|
||||||
|
* - Not truly random, but good enough for a game<br>
|
||||||
|
* - A lot more efficient than Random<br>
|
||||||
|
*/
|
||||||
public static PseudoRandom random = new PseudoRandom();
|
public static PseudoRandom random = new PseudoRandom();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cache of mapping x,y,z coordinates to the chunk array<br>
|
||||||
|
* - Used for efficent world generation<br>
|
||||||
|
*/
|
||||||
public static short[][] x_loc;
|
public static short[][] x_loc;
|
||||||
public static short[][] y_loc;
|
public static short[][] y_loc;
|
||||||
public static short[][] z_loc;
|
public static short[][] z_loc;
|
||||||
@ -137,14 +165,6 @@ public class MainUtil {
|
|||||||
regions_cache.add(new RegionWrapper(pos1.getX(), pos2.getX(), pos1.getY(), pos2.getY(), pos1.getZ(), pos2.getZ()));
|
regions_cache.add(new RegionWrapper(pos1.getX(), pos2.getX(), pos1.getY(), pos2.getY(), pos1.getZ(), pos2.getZ()));
|
||||||
return regions_cache;
|
return regions_cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a list of ALL edges from your rectangles. One rectangle has 4 edges.
|
|
||||||
// Let the Edge be a class with properly defined compareTo() and equals().
|
|
||||||
// Sort the edges list (uses comapreTo).
|
|
||||||
// Iterate through the list. If the same edge is present in the list TWICE, remove them both from the list.
|
|
||||||
// The remaining edges are the edges of your polygon.
|
|
||||||
|
|
||||||
|
|
||||||
HashSet<Plot> plots = getConnectedPlots(origin);
|
HashSet<Plot> plots = getConnectedPlots(origin);
|
||||||
regions_cache = new HashSet<>();
|
regions_cache = new HashSet<>();
|
||||||
HashSet<PlotId> visited = new HashSet<>();
|
HashSet<PlotId> visited = new HashSet<>();
|
||||||
@ -247,6 +267,12 @@ public class MainUtil {
|
|||||||
return regions_cache;
|
return regions_cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hashcode of a boolean array.<br>
|
||||||
|
* - Used for traversing mega plots quickly.
|
||||||
|
* @param array
|
||||||
|
* @return hashcode
|
||||||
|
*/
|
||||||
public static int hash(boolean[] array) {
|
public static int hash(boolean[] array) {
|
||||||
if (array.length == 4) {
|
if (array.length == 4) {
|
||||||
if (!array[0] && !array[1] && !array[2] && !array[3]) {
|
if (!array[0] && !array[1] && !array[2] && !array[3]) {
|
||||||
@ -261,6 +287,13 @@ public class MainUtil {
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a location is in a plot area (roads / plots).<br>
|
||||||
|
* - A world that is a plot world may not be a plot area if clusters are used<br>
|
||||||
|
* - A non plot world is not a plot area<br>
|
||||||
|
* @param location
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean isPlotArea(final Location location) {
|
public static boolean isPlotArea(final Location location) {
|
||||||
final PlotWorld plotworld = PS.get().getPlotWorld(location.getWorld());
|
final PlotWorld plotworld = PS.get().getPlotWorld(location.getWorld());
|
||||||
if (plotworld == null) {
|
if (plotworld == null) {
|
||||||
@ -272,6 +305,11 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the name from a UUID<br>
|
||||||
|
* @param owner
|
||||||
|
* @return The player's name, None, Everyone or Unknown
|
||||||
|
*/
|
||||||
public static String getName(final UUID owner) {
|
public static String getName(final UUID owner) {
|
||||||
if (owner == null) {
|
if (owner == null) {
|
||||||
return C.NONE.s();
|
return C.NONE.s();
|
||||||
@ -285,6 +323,12 @@ public class MainUtil {
|
|||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Efficiently get a list of PlotPlayers inside a plot<br>
|
||||||
|
* - PlotSquared caches player locations
|
||||||
|
* @param plot
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static List<PlotPlayer> getPlayersInPlot(final Plot plot) {
|
public static List<PlotPlayer> getPlayersInPlot(final Plot plot) {
|
||||||
final ArrayList<PlotPlayer> players = new ArrayList<>();
|
final ArrayList<PlotPlayer> players = new ArrayList<>();
|
||||||
for (Entry<String, PlotPlayer> entry : UUIDHandler.getPlayers().entrySet()) {
|
for (Entry<String, PlotPlayer> entry : UUIDHandler.getPlayers().entrySet()) {
|
||||||
@ -296,6 +340,11 @@ public class MainUtil {
|
|||||||
return players;
|
return players;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrigger plot entry functions for the players in a plot.<br>
|
||||||
|
* - Used when plot settings are changed<br>
|
||||||
|
* @param plot
|
||||||
|
*/
|
||||||
public static void reEnterPlot(final Plot plot) {
|
public static void reEnterPlot(final Plot plot) {
|
||||||
TaskManager.runTaskLater(new Runnable() {
|
TaskManager.runTaskLater(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
@ -308,6 +357,12 @@ public class MainUtil {
|
|||||||
}, 1);
|
}, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Break up a series of tasks so that they can run without lagging the server
|
||||||
|
* @param objects
|
||||||
|
* @param task
|
||||||
|
* @param whenDone
|
||||||
|
*/
|
||||||
public static <T> void objectTask(Collection<T> objects, final RunnableVal<T> task, final Runnable whenDone) {
|
public static <T> void objectTask(Collection<T> objects, final RunnableVal<T> task, final Runnable whenDone) {
|
||||||
final Iterator<T> iter = objects.iterator();
|
final Iterator<T> iter = objects.iterator();
|
||||||
TaskManager.runTask(new Runnable() {
|
TaskManager.runTask(new Runnable() {
|
||||||
@ -328,21 +383,12 @@ public class MainUtil {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void plotTask(Plot plot, RunnableVal<Plot> run) {
|
/**
|
||||||
if (!plot.isMerged()) {
|
* Fuzzy plot search with spaces separating terms<br>
|
||||||
run.value = plot;
|
* - Terms: id, alias, world, owner, trusted, member
|
||||||
run.run();
|
* @param search
|
||||||
return;
|
* @return
|
||||||
}
|
*/
|
||||||
for (Plot current : getConnectedPlots(plot)) {
|
|
||||||
run.value = current;
|
|
||||||
run.run();
|
|
||||||
if (run.value == null) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static List<Plot> getPlotsBySearch(final String search) {
|
public static List<Plot> getPlotsBySearch(final String search) {
|
||||||
final String[] split = search.split(" ");
|
final String[] split = search.split(" ");
|
||||||
final int size = split.length * 2;
|
final int size = split.length * 2;
|
||||||
@ -420,6 +466,13 @@ public class MainUtil {
|
|||||||
return plots;
|
return plots;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the plot from a string<br>
|
||||||
|
* @param player Provides a context for what world to search in. Prefixing the term with 'world_name;' will override this context.
|
||||||
|
* @param arg The search term
|
||||||
|
* @param message If a message should be sent to the player if a plot cannot be found
|
||||||
|
* @return The plot if only 1 result is found, or null
|
||||||
|
*/
|
||||||
public static Plot getPlotFromString(final PlotPlayer player, final String arg, final boolean message) {
|
public static Plot getPlotFromString(final PlotPlayer player, final String arg, final boolean message) {
|
||||||
if (arg == null) {
|
if (arg == null) {
|
||||||
if (player == null) {
|
if (player == null) {
|
||||||
@ -565,6 +618,12 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a location is a plot area.<br>
|
||||||
|
* - Directly checks the cluster manager<br>
|
||||||
|
* @param location
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean isPlotAreaAbs(final Location location) {
|
public static boolean isPlotAreaAbs(final Location location) {
|
||||||
if (!Settings.ENABLE_CLUSTERS) {
|
if (!Settings.ENABLE_CLUSTERS) {
|
||||||
return true;
|
return true;
|
||||||
@ -579,6 +638,11 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a location corresponds to a plot road i.e. A plot area but not inside a plot
|
||||||
|
* @param location
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean isPlotRoad(final Location location) {
|
public static boolean isPlotRoad(final Location location) {
|
||||||
final PlotWorld plotworld = PS.get().getPlotWorld(location.getWorld());
|
final PlotWorld plotworld = PS.get().getPlotWorld(location.getWorld());
|
||||||
if (plotworld.TYPE == 2) {
|
if (plotworld.TYPE == 2) {
|
||||||
@ -591,6 +655,12 @@ public class MainUtil {
|
|||||||
return manager.getPlotId(plotworld, location.getX(), location.getY(), location.getZ()) == null;
|
return manager.getPlotId(plotworld, location.getX(), location.getY(), location.getZ()) == null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a plot is in a plot area.<br>
|
||||||
|
* - Useful as plot objects can be created with any location which may not be valid.
|
||||||
|
* @param location
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean isPlotArea(final Plot plot) {
|
public static boolean isPlotArea(final Plot plot) {
|
||||||
if (!Settings.ENABLE_CLUSTERS) {
|
if (!Settings.ENABLE_CLUSTERS) {
|
||||||
return true;
|
return true;
|
||||||
@ -602,18 +672,6 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean enteredPlot(final Location l1, final Location l2) {
|
|
||||||
final PlotId p1 = MainUtil.getPlotId(l1);
|
|
||||||
final PlotId p2 = MainUtil.getPlotId(l2);
|
|
||||||
return (p2 != null) && ((p1 == null) || !p1.equals(p2));
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean leftPlot(final Location l1, final Location l2) {
|
|
||||||
final PlotId p1 = MainUtil.getPlotId(l1);
|
|
||||||
final PlotId p2 = MainUtil.getPlotId(l2);
|
|
||||||
return (p1 != null) && ((p2 == null) || !p1.equals(p2));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the number of plots for a player
|
* Get the number of plots for a player
|
||||||
*
|
*
|
||||||
@ -648,6 +706,12 @@ public class MainUtil {
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the base plot for a plot
|
||||||
|
* @see Plot#getBasePlot(boolean)
|
||||||
|
* @param plot
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static Plot getPlot(Plot plot) {
|
public static Plot getPlot(Plot plot) {
|
||||||
if (plot == null) {
|
if (plot == null) {
|
||||||
return null;
|
return null;
|
||||||
@ -655,10 +719,21 @@ public class MainUtil {
|
|||||||
return plot.getBasePlot(false);
|
return plot.getBasePlot(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the plot at a location<br>
|
||||||
|
* @param loc
|
||||||
|
* @return The plot at a location. The base plot will be returned if a mega plot.
|
||||||
|
*/
|
||||||
public static Plot getPlot(Location loc) {
|
public static Plot getPlot(Location loc) {
|
||||||
return getPlot(getPlotAbs(loc));
|
return getPlot(getPlotAbs(loc));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the plot given the world and plot id
|
||||||
|
* @param world
|
||||||
|
* @param id
|
||||||
|
* @return The plot. The base plot will be returned if a mega plot.
|
||||||
|
*/
|
||||||
public static Plot getPlot(String world, PlotId id) {
|
public static Plot getPlot(String world, PlotId id) {
|
||||||
if (id == null) {
|
if (id == null) {
|
||||||
return null;
|
return null;
|
||||||
@ -666,6 +741,12 @@ public class MainUtil {
|
|||||||
return getPlot(getPlotAbs(world, id));
|
return getPlot(getPlotAbs(world, id));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the default home location for a plot<br>
|
||||||
|
* - Ignores any home location set for that specific plot
|
||||||
|
* @param plot
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static Location getDefaultHome(Plot plot) {
|
public static Location getDefaultHome(Plot plot) {
|
||||||
plot = plot.getBasePlot(false);
|
plot = plot.getBasePlot(false);
|
||||||
final PlotWorld plotworld = PS.get().getPlotWorld(plot.world);
|
final PlotWorld plotworld = PS.get().getPlotWorld(plot.world);
|
||||||
@ -695,10 +776,16 @@ public class MainUtil {
|
|||||||
return new Location(plot.world, x, y + 1, z);
|
return new Location(plot.world, x, y + 1, z);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Teleport a player to a plot and send them the teleport message.
|
||||||
|
* @param player
|
||||||
|
* @param from
|
||||||
|
* @param plot
|
||||||
|
* @return If the teleportation is allowed.
|
||||||
|
*/
|
||||||
public static boolean teleportPlayer(final PlotPlayer player, final Location from, Plot plot) {
|
public static boolean teleportPlayer(final PlotPlayer player, final Location from, Plot plot) {
|
||||||
plot = plot.getBasePlot(false);
|
plot = plot.getBasePlot(false);
|
||||||
final boolean result = EventUtil.manager.callTeleport(player, from, plot);
|
final boolean result = EventUtil.manager.callTeleport(player, from, plot);
|
||||||
|
|
||||||
if (result) {
|
if (result) {
|
||||||
final Location location;
|
final Location location;
|
||||||
if (PS.get().getPlotWorld(plot.world).HOME_ALLOW_NONMEMBER || plot.isAdded(player.getUUID())) {
|
if (PS.get().getPlotWorld(plot.world).HOME_ALLOW_NONMEMBER || plot.isAdded(player.getUUID())) {
|
||||||
@ -734,6 +821,11 @@ public class MainUtil {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the plot border distance for a world<br>
|
||||||
|
* @param worldname
|
||||||
|
* @return The border distance or Integer.MAX_VALUE if no border is set
|
||||||
|
*/
|
||||||
public static int getBorder(final String worldname) {
|
public static int getBorder(final String worldname) {
|
||||||
if (worldBorder.containsKey(worldname)) {
|
if (worldBorder.containsKey(worldname)) {
|
||||||
final int border = worldBorder.get(worldname) + 16;
|
final int border = worldBorder.get(worldname) + 16;
|
||||||
@ -746,6 +838,10 @@ public class MainUtil {
|
|||||||
return Integer.MAX_VALUE;
|
return Integer.MAX_VALUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setup the plot border for a world (usually done when the world is created)
|
||||||
|
* @param world
|
||||||
|
*/
|
||||||
public static void setupBorder(final String world) {
|
public static void setupBorder(final String world) {
|
||||||
final PlotWorld plotworld = PS.get().getPlotWorld(world);
|
final PlotWorld plotworld = PS.get().getPlotWorld(world);
|
||||||
if (!plotworld.WORLD_BORDER) {
|
if (!plotworld.WORLD_BORDER) {
|
||||||
@ -759,10 +855,19 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resend the chunk at a location
|
||||||
|
* @param world
|
||||||
|
* @param loc
|
||||||
|
*/
|
||||||
public static void update(final String world, final ChunkLoc loc) {
|
public static void update(final String world, final ChunkLoc loc) {
|
||||||
BlockUpdateUtil.setBlockManager.update(world, Arrays.asList(loc));
|
BlockUpdateUtil.setBlockManager.update(world, Arrays.asList(loc));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resend the chunks in a plot
|
||||||
|
* @param plot
|
||||||
|
*/
|
||||||
public static void update(final Plot plot) {
|
public static void update(final Plot plot) {
|
||||||
TaskManager.runTask(new Runnable() {
|
TaskManager.runTask(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
@ -780,17 +885,6 @@ public class MainUtil {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void createWorld(final String world, final String generator) {}
|
|
||||||
|
|
||||||
public static PlotId parseId(final String arg) {
|
|
||||||
try {
|
|
||||||
final String[] split = arg.split(";");
|
|
||||||
return new PlotId(Integer.parseInt(split[0]), Integer.parseInt(split[1]));
|
|
||||||
} catch (final Exception e) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* direction 0 = north, 1 = south, etc:
|
* direction 0 = north, 1 = south, etc:
|
||||||
*
|
*
|
||||||
@ -952,6 +1046,12 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the south east road section of a plot<br>
|
||||||
|
* - Used when a plot is merged<br>
|
||||||
|
* @param plotworld
|
||||||
|
* @param plot
|
||||||
|
*/
|
||||||
public static void removeRoadSouthEast(final PlotWorld plotworld, final Plot plot) {
|
public static void removeRoadSouthEast(final PlotWorld plotworld, final Plot plot) {
|
||||||
if ((plotworld.TYPE != 0) && (plotworld.TERRAIN > 1)) {
|
if ((plotworld.TYPE != 0) && (plotworld.TERRAIN > 1)) {
|
||||||
if (plotworld.TERRAIN == 3) {
|
if (plotworld.TERRAIN == 3) {
|
||||||
@ -969,6 +1069,12 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the east road section of a plot<br>
|
||||||
|
* - Used when a plot is merged<br>
|
||||||
|
* @param plotworld
|
||||||
|
* @param plot
|
||||||
|
*/
|
||||||
public static void removeRoadEast(final PlotWorld plotworld, final Plot plot) {
|
public static void removeRoadEast(final PlotWorld plotworld, final Plot plot) {
|
||||||
if ((plotworld.TYPE != 0) && (plotworld.TERRAIN > 1)) {
|
if ((plotworld.TYPE != 0) && (plotworld.TERRAIN > 1)) {
|
||||||
if (plotworld.TERRAIN == 3) {
|
if (plotworld.TERRAIN == 3) {
|
||||||
@ -986,6 +1092,12 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the south road section of a plot<br>
|
||||||
|
* - Used when a plot is merged<br>
|
||||||
|
* @param plotworld
|
||||||
|
* @param plot
|
||||||
|
*/
|
||||||
public static void removeRoadSouth(final PlotWorld plotworld, final Plot plot) {
|
public static void removeRoadSouth(final PlotWorld plotworld, final Plot plot) {
|
||||||
if ((plotworld.TYPE != 0) && (plotworld.TERRAIN > 1)) {
|
if ((plotworld.TYPE != 0) && (plotworld.TERRAIN > 1)) {
|
||||||
if (plotworld.TERRAIN == 3) {
|
if (plotworld.TERRAIN == 3) {
|
||||||
@ -1063,6 +1175,12 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Merge the plot settings<br>
|
||||||
|
* - Used when a plot is merged<br>
|
||||||
|
* @param a
|
||||||
|
* @param b
|
||||||
|
*/
|
||||||
public static void mergeData(Plot a, Plot b) {
|
public static void mergeData(Plot a, Plot b) {
|
||||||
HashMap<String, Flag> flags1 = a.getFlags();
|
HashMap<String, Flag> flags1 = a.getFlags();
|
||||||
HashMap<String, Flag> flags2 = b.getFlags();
|
HashMap<String, Flag> flags2 = b.getFlags();
|
||||||
@ -1105,6 +1223,10 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the sign for a plot
|
||||||
|
* @param p
|
||||||
|
*/
|
||||||
public static void removeSign(final Plot p) {
|
public static void removeSign(final Plot p) {
|
||||||
if (!PS.get().isMainThread(Thread.currentThread())) {
|
if (!PS.get().isMainThread(Thread.currentThread())) {
|
||||||
TaskManager.runTask(new Runnable() {
|
TaskManager.runTask(new Runnable() {
|
||||||
@ -1125,6 +1247,10 @@ public class MainUtil {
|
|||||||
BlockManager.setBlocks(world, new int[] { loc.getX() }, new int[] { loc.getY() }, new int[] { loc.getZ() }, new int[] { 0 }, new byte[] { 0 });
|
BlockManager.setBlocks(world, new int[] { loc.getX() }, new int[] { loc.getY() }, new int[] { loc.getZ() }, new int[] { 0 }, new byte[] { 0 });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the sign for a plot
|
||||||
|
* @param p
|
||||||
|
*/
|
||||||
public static void setSign(final Plot p) {
|
public static void setSign(final Plot p) {
|
||||||
if (p.owner == null) {
|
if (p.owner == null) {
|
||||||
setSign(null, p);
|
setSign(null, p);
|
||||||
@ -1133,6 +1259,11 @@ public class MainUtil {
|
|||||||
setSign(UUIDHandler.getName(p.owner), p);
|
setSign(UUIDHandler.getName(p.owner), p);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the sign for a plot to a specific name
|
||||||
|
* @param name
|
||||||
|
* @param p
|
||||||
|
*/
|
||||||
public static void setSign(final String name, final Plot p) {
|
public static void setSign(final String name, final Plot p) {
|
||||||
if (!PS.get().isMainThread(Thread.currentThread())) {
|
if (!PS.get().isMainThread(Thread.currentThread())) {
|
||||||
TaskManager.runTask(new Runnable() {
|
TaskManager.runTask(new Runnable() {
|
||||||
@ -1158,6 +1289,13 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the corner locations for a plot<br>
|
||||||
|
* @see Plot#getCorners()
|
||||||
|
* @param world
|
||||||
|
* @param region
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static Location[] getCorners(String world, RegionWrapper region) {
|
public static Location[] getCorners(String world, RegionWrapper region) {
|
||||||
Location pos1 = new Location(world, region.minX, region.minY, region.minZ);
|
Location pos1 = new Location(world, region.minX, region.minY, region.minZ);
|
||||||
Location pos2 = new Location(world, region.maxX, region.maxY, region.maxZ);
|
Location pos2 = new Location(world, region.maxX, region.maxY, region.maxZ);
|
||||||
@ -1178,6 +1316,13 @@ public class MainUtil {
|
|||||||
return getCorners(plot.world, getRegions(plot));
|
return getCorners(plot.world, getRegions(plot));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the corner locations for a list of regions<br>
|
||||||
|
* @see Plot#getCorners()
|
||||||
|
* @param world
|
||||||
|
* @param region
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static Location[] getCorners(String world, Collection<RegionWrapper> regions) {
|
public static Location[] getCorners(String world, Collection<RegionWrapper> regions) {
|
||||||
Location min = null;
|
Location min = null;
|
||||||
Location max = null;
|
Location max = null;
|
||||||
@ -1206,6 +1351,12 @@ public class MainUtil {
|
|||||||
return new Location[] { min, max };
|
return new Location[] { min, max };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the corner plot ids for a plot<br>
|
||||||
|
* @see Plot#getCornerIds()
|
||||||
|
* @param plot
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static PlotId[] getCornerIds(Plot plot) {
|
public static PlotId[] getCornerIds(Plot plot) {
|
||||||
if (!plot.isMerged()) {
|
if (!plot.isMerged()) {
|
||||||
return new PlotId[] { plot.id, plot.id };
|
return new PlotId[] { plot.id, plot.id };
|
||||||
@ -1229,6 +1380,20 @@ public class MainUtil {
|
|||||||
return new PlotId[] { min, max };
|
return new PlotId[] { min, max };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Auto merge a plot in a specific direction<br>
|
||||||
|
* @param plot The plot to merge
|
||||||
|
* @param dir The direction to merge<br>
|
||||||
|
* -1 = All directions<br>
|
||||||
|
* 0 = north<br>
|
||||||
|
* 1 = east<br>
|
||||||
|
* 2 = south<br>
|
||||||
|
* 3 = west<br>
|
||||||
|
* @param max The max number of merges to do
|
||||||
|
* @param uuid The UUID it is allowed to merge with
|
||||||
|
* @param removeRoads Wether to remove roads
|
||||||
|
* @return true if a merge takes place
|
||||||
|
*/
|
||||||
public static boolean autoMerge(final Plot plot, int dir, int max, final UUID uuid, final boolean removeRoads) {
|
public static boolean autoMerge(final Plot plot, int dir, int max, final UUID uuid, final boolean removeRoads) {
|
||||||
if (plot == null) {
|
if (plot == null) {
|
||||||
return false;
|
return false;
|
||||||
@ -1295,8 +1460,12 @@ public class MainUtil {
|
|||||||
return toReturn;
|
return toReturn;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Expand the world border to include the provided plot (if applicable)
|
||||||
|
* @param plot
|
||||||
|
*/
|
||||||
public static void updateWorldBorder(final Plot plot) {
|
public static void updateWorldBorder(final Plot plot) {
|
||||||
if (!worldBorder.containsKey(plot.world)) {
|
if (!plot.hasOwner() || !worldBorder.containsKey(plot.world)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final String world = plot.world;
|
final String world = plot.world;
|
||||||
@ -1360,22 +1529,6 @@ public class MainUtil {
|
|||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String createId(final int x, final int z) {
|
|
||||||
return x + ";" + z;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static int square(final int x) {
|
|
||||||
return x * x;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static short[] getBlock(final String block) {
|
|
||||||
if (block.contains(":")) {
|
|
||||||
final String[] split = block.split(":");
|
|
||||||
return new short[] { Short.parseShort(split[0]), Short.parseShort(split[1]) };
|
|
||||||
}
|
|
||||||
return new short[] { Short.parseShort(block), 0 };
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clear a plot and associated sections: [sign, entities, border]
|
* Clear a plot and associated sections: [sign, entities, border]
|
||||||
*
|
*
|
||||||
@ -1391,6 +1544,18 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Count the entities in a plot
|
||||||
|
* @see ChunkManager#countEntities(Plot)
|
||||||
|
* 0 = Entity
|
||||||
|
* 1 = Animal
|
||||||
|
* 2 = Monster
|
||||||
|
* 3 = Mob
|
||||||
|
* 4 = Boat
|
||||||
|
* 5 = Misc
|
||||||
|
* @param plot
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static int[] countEntities(Plot plot) {
|
public static int[] countEntities(Plot plot) {
|
||||||
int[] count = new int[6];
|
int[] count = new int[6];
|
||||||
for (Plot current : getConnectedPlots(plot)) {
|
for (Plot current : getConnectedPlots(plot)) {
|
||||||
@ -1405,6 +1570,13 @@ public class MainUtil {
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clear and unclaim a plot
|
||||||
|
* @see Plot#clear(Runnable)
|
||||||
|
* @param plot
|
||||||
|
* @param whenDone
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean delete(final Plot plot, final Runnable whenDone) {
|
public static boolean delete(final Plot plot, final Runnable whenDone) {
|
||||||
// Plot is not claimed
|
// Plot is not claimed
|
||||||
if (!plot.hasOwner()) {
|
if (!plot.hasOwner()) {
|
||||||
@ -1423,6 +1595,14 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clear a plot (does not remove from database)
|
||||||
|
* @param plot
|
||||||
|
* @param isDelete Different procedures take place if the clearing is a deletion:<br>
|
||||||
|
* - The sign, border and walls are also cleared on deletion<br>
|
||||||
|
* @param whenDone A runnable that will execute when the clearing is done, or null
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean clear(final Plot plot, final boolean isDelete, final Runnable whenDone) {
|
public static boolean clear(final Plot plot, final boolean isDelete, final Runnable whenDone) {
|
||||||
if (!EventUtil.manager.callClear(plot.world, plot.id)) {
|
if (!EventUtil.manager.callClear(plot.world, plot.id)) {
|
||||||
return false;
|
return false;
|
||||||
@ -1478,6 +1658,13 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a cuboid in the world to a set of blocks.
|
||||||
|
* @param world
|
||||||
|
* @param pos1
|
||||||
|
* @param pos2
|
||||||
|
* @param blocks If multiple blocks are provided, the result will be a random mix
|
||||||
|
*/
|
||||||
public static void setCuboid(final String world, final Location pos1, final Location pos2, final PlotBlock[] blocks) {
|
public static void setCuboid(final String world, final Location pos1, final Location pos2, final PlotBlock[] blocks) {
|
||||||
if (blocks.length == 1) {
|
if (blocks.length == 1) {
|
||||||
setSimpleCuboid(world, pos1, pos2, blocks[0]);
|
setSimpleCuboid(world, pos1, pos2, blocks[0]);
|
||||||
@ -1507,6 +1694,13 @@ public class MainUtil {
|
|||||||
BlockManager.setBlocks(world, xl, yl, zl, ids, data);
|
BlockManager.setBlocks(world, xl, yl, zl, ids, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a cubioid asynchronously to a set of blocks
|
||||||
|
* @param world
|
||||||
|
* @param pos1
|
||||||
|
* @param pos2
|
||||||
|
* @param blocks
|
||||||
|
*/
|
||||||
public static void setCuboidAsync(final String world, final Location pos1, final Location pos2, final PlotBlock[] blocks) {
|
public static void setCuboidAsync(final String world, final Location pos1, final Location pos2, final PlotBlock[] blocks) {
|
||||||
if (blocks.length == 1) {
|
if (blocks.length == 1) {
|
||||||
setSimpleCuboidAsync(world, pos1, pos2, blocks[0]);
|
setSimpleCuboidAsync(world, pos1, pos2, blocks[0]);
|
||||||
@ -1523,6 +1717,13 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a cuboid to a block
|
||||||
|
* @param world
|
||||||
|
* @param pos1
|
||||||
|
* @param pos2
|
||||||
|
* @param newblock
|
||||||
|
*/
|
||||||
public static void setSimpleCuboid(final String world, final Location pos1, final Location pos2, final PlotBlock newblock) {
|
public static void setSimpleCuboid(final String world, final Location pos1, final Location pos2, final PlotBlock newblock) {
|
||||||
final int length = (pos2.getX() - pos1.getX()) * (pos2.getY() - pos1.getY()) * (pos2.getZ() - pos1.getZ());
|
final int length = (pos2.getX() - pos1.getX()) * (pos2.getY() - pos1.getY()) * (pos2.getZ() - pos1.getZ());
|
||||||
final int[] xl = new int[length];
|
final int[] xl = new int[length];
|
||||||
@ -1546,6 +1747,13 @@ public class MainUtil {
|
|||||||
BlockManager.setBlocks(world, xl, yl, zl, ids, data);
|
BlockManager.setBlocks(world, xl, yl, zl, ids, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a cuboic asynchronously to a block
|
||||||
|
* @param world
|
||||||
|
* @param pos1
|
||||||
|
* @param pos2
|
||||||
|
* @param newblock
|
||||||
|
*/
|
||||||
public static void setSimpleCuboidAsync(final String world, final Location pos1, final Location pos2, final PlotBlock newblock) {
|
public static void setSimpleCuboidAsync(final String world, final Location pos1, final Location pos2, final PlotBlock newblock) {
|
||||||
for (int y = pos1.getY(); y <= Math.min(255, pos2.getY()); y++) {
|
for (int y = pos1.getY(); y <= Math.min(255, pos2.getY()); y++) {
|
||||||
for (int x = pos1.getX(); x <= pos2.getX(); x++) {
|
for (int x = pos1.getX(); x <= pos2.getX(); x++) {
|
||||||
@ -1556,6 +1764,12 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the biome for a plot asynchronously
|
||||||
|
* @param plot
|
||||||
|
* @param biome The biome e.g. "forest"
|
||||||
|
* @param whenDone The task to run when finished, or null
|
||||||
|
*/
|
||||||
public static void setBiome(final Plot plot, final String biome, final Runnable whenDone) {
|
public static void setBiome(final Plot plot, final String biome, final Runnable whenDone) {
|
||||||
final ArrayDeque<RegionWrapper> regions = new ArrayDeque<>(getRegions(plot));
|
final ArrayDeque<RegionWrapper> regions = new ArrayDeque<>(getRegions(plot));
|
||||||
Runnable run = new Runnable() {
|
Runnable run = new Runnable() {
|
||||||
@ -1584,6 +1798,15 @@ public class MainUtil {
|
|||||||
run.run();
|
run.run();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Synchronously set the biome in a selection
|
||||||
|
* @param world
|
||||||
|
* @param p1x
|
||||||
|
* @param p1z
|
||||||
|
* @param p2x
|
||||||
|
* @param p2z
|
||||||
|
* @param biome
|
||||||
|
*/
|
||||||
public static void setBiome(final String world, final int p1x, final int p1z, final int p2x, final int p2z, final String biome) {
|
public static void setBiome(final String world, final int p1x, final int p1z, final int p2x, final int p2z, final String biome) {
|
||||||
final int length = ((p2x - p1x) + 1) * ((p2z - p1z) + 1);
|
final int length = ((p2x - p1x) + 1) * ((p2z - p1z) + 1);
|
||||||
final int[] xl = new int[length];
|
final int[] xl = new int[length];
|
||||||
@ -1599,6 +1822,13 @@ public class MainUtil {
|
|||||||
BlockManager.setBiomes(world, xl, zl, biome);
|
BlockManager.setBiomes(world, xl, zl, biome);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the heighest block at a location
|
||||||
|
* @param world
|
||||||
|
* @param x
|
||||||
|
* @param z
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static int getHeighestBlock(final String world, final int x, final int z) {
|
public static int getHeighestBlock(final String world, final int x, final int z) {
|
||||||
final int result = BlockManager.manager.getHeighestBlock(world, x, z);
|
final int result = BlockManager.manager.getHeighestBlock(world, x, z);
|
||||||
if (result == 0) {
|
if (result == 0) {
|
||||||
@ -1699,6 +1929,15 @@ public class MainUtil {
|
|||||||
return top;
|
return top;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the bottom location for a plot.<br>
|
||||||
|
* - Does not respect mega plots<br>
|
||||||
|
* - Merged plots, only the road will be considered part of the plot<br>
|
||||||
|
*
|
||||||
|
* @param plot
|
||||||
|
*
|
||||||
|
* @return Location bottom of mega plot
|
||||||
|
*/
|
||||||
public static Location getPlotBottomLoc_(Plot plot) {
|
public static Location getPlotBottomLoc_(Plot plot) {
|
||||||
Location bot = getPlotBottomLocAbs(plot.world, plot.id);
|
Location bot = getPlotBottomLocAbs(plot.world, plot.id);
|
||||||
if (!plot.isMerged()) {
|
if (!plot.isMerged()) {
|
||||||
@ -1716,6 +1955,14 @@ public class MainUtil {
|
|||||||
return bot;
|
return bot;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a selection of plots can be claimed
|
||||||
|
* @param player
|
||||||
|
* @param world
|
||||||
|
* @param pos1
|
||||||
|
* @param pos2
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean canClaim(final PlotPlayer player, final String world, final PlotId pos1, final PlotId pos2) {
|
public static boolean canClaim(final PlotPlayer player, final String world, final PlotId pos1, final PlotId pos2) {
|
||||||
for (int x = pos1.x; x <= pos2.x; x++) {
|
for (int x = pos1.x; x <= pos2.x; x++) {
|
||||||
for (int y = pos1.y; y <= pos2.y; y++) {
|
for (int y = pos1.y; y <= pos2.y; y++) {
|
||||||
@ -1809,6 +2056,13 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if the plots in a selection are unowned
|
||||||
|
* @param world
|
||||||
|
* @param pos1
|
||||||
|
* @param pos2
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean isUnowned(final String world, final PlotId pos1, final PlotId pos2) {
|
public static boolean isUnowned(final String world, final PlotId pos1, final PlotId pos2) {
|
||||||
for (int x = pos1.x; x <= pos2.x; x++) {
|
for (int x = pos1.x; x <= pos2.x; x++) {
|
||||||
for (int y = pos1.y; y <= pos2.y; y++) {
|
for (int y = pos1.y; y <= pos2.y; y++) {
|
||||||
@ -1823,6 +2077,13 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Swap the settings for two plots
|
||||||
|
* @param p1
|
||||||
|
* @param p2
|
||||||
|
* @param whenDone
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean swapData(Plot p1, Plot p2, final Runnable whenDone) {
|
public static boolean swapData(Plot p1, Plot p2, final Runnable whenDone) {
|
||||||
if ((p1 == null) || (p1.owner == null)) {
|
if ((p1 == null) || (p1.owner == null)) {
|
||||||
if ((p2 != null) && (p2.owner != null)) {
|
if ((p2 != null) && (p2.owner != null)) {
|
||||||
@ -1857,6 +2118,13 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Move the settings for a plot
|
||||||
|
* @param pos1
|
||||||
|
* @param pos2
|
||||||
|
* @param whenDone
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean moveData(final Plot pos1, final Plot pos2, final Runnable whenDone) {
|
public static boolean moveData(final Plot pos1, final Plot pos2, final Runnable whenDone) {
|
||||||
if (pos1.owner == null) {
|
if (pos1.owner == null) {
|
||||||
PS.debug(pos2 + " is unowned (single)");
|
PS.debug(pos2 + " is unowned (single)");
|
||||||
@ -1879,6 +2147,14 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Move a plot physically, as well as the corresponding settings.
|
||||||
|
* @param origin
|
||||||
|
* @param destination
|
||||||
|
* @param whenDone
|
||||||
|
* @param allowSwap
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean move(final Plot origin, final Plot destination, final Runnable whenDone, boolean allowSwap) {
|
public static boolean move(final Plot origin, final Plot destination, final Runnable whenDone, boolean allowSwap) {
|
||||||
PlotId offset = new PlotId(destination.id.x - origin.id.x, destination.id.y - origin.id.y);
|
PlotId offset = new PlotId(destination.id.x - origin.id.x, destination.id.y - origin.id.y);
|
||||||
Location db = destination.getBottomAbs();
|
Location db = destination.getBottomAbs();
|
||||||
@ -1958,48 +2234,14 @@ public class MainUtil {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
// final com.intellectualcrafters.plot.object.Location bot1 = MainUtil.getPlotBottomLoc(plot1.world, plot1.id);
|
|
||||||
// final com.intellectualcrafters.plot.object.Location bot2 = MainUtil.getPlotBottomLoc(plot2.world, plot2.id);
|
|
||||||
// final Location top = MainUtil.getPlotTopLoc(plot1.world, plot1.id);
|
|
||||||
// if (plot1.owner == null) {
|
|
||||||
// PS.debug(plot2 + " is unowned (single)");
|
|
||||||
// TaskManager.runTask(whenDone);
|
|
||||||
// return false;
|
|
||||||
// }
|
|
||||||
// final Plot pos1 = getBottomPlot(plot1);
|
|
||||||
// final Plot pos2 = getTopPlot(plot1);
|
|
||||||
// final PlotId size = MainUtil.getSize(plot1);
|
|
||||||
// if (!MainUtil.isUnowned(plot2.world, plot2.id, new PlotId((plot2.id.x + size.x) - 1, (plot2.id.y + size.y) - 1))) {
|
|
||||||
// PS.debug(plot2 + " is unowned (multi)");
|
|
||||||
// TaskManager.runTask(whenDone);
|
|
||||||
// return false;
|
|
||||||
// }
|
|
||||||
// final int offset_x = plot2.id.x - pos1.id.x;
|
|
||||||
// final int offset_y = plot2.id.y - pos1.id.y;
|
|
||||||
// final ArrayList<PlotId> selection = getPlotSelectionIds(pos1.id, pos2.id);
|
|
||||||
// for (final PlotId id : selection) {
|
|
||||||
// final String worldOriginal = plot1.world;
|
|
||||||
// final PlotId idOriginal = new PlotId(id.x, id.y);
|
|
||||||
// final Plot plot = PS.get().getPlot(plot1.world, id);
|
|
||||||
// final Map<String, ConcurrentHashMap<PlotId, Plot>> raw = PS.get().getAllPlotsRaw();
|
|
||||||
// raw.get(plot1.world).remove(id);
|
|
||||||
// plot.id.x += offset_x;
|
|
||||||
// plot.id.y += offset_y;
|
|
||||||
// plot.id.recalculateHash();
|
|
||||||
// raw.get(plot2.world).put(plot.id, plot);
|
|
||||||
// DBFunc.movePlot(getPlot(worldOriginal, idOriginal), getPlot(plot2.world, new PlotId(id.x + offset_x, id.y + offset_y)));
|
|
||||||
// }
|
|
||||||
// ChunkManager.manager.copyRegion(bot1, top, bot2, new Runnable() {
|
|
||||||
// @Override
|
|
||||||
// public void run() {
|
|
||||||
// final Location bot = bot1.clone().add(1, 0, 1);
|
|
||||||
// ChunkManager.manager.regenerateRegion(bot, top, null);
|
|
||||||
// TaskManager.runTaskLater(whenDone, 1);
|
|
||||||
// }
|
|
||||||
// });
|
|
||||||
// return true;
|
|
||||||
// }
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy a plot to a location, both physically and the settings
|
||||||
|
* @param origin
|
||||||
|
* @param destination
|
||||||
|
* @param whenDone
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean copy(final Plot origin, final Plot destination, final Runnable whenDone) {
|
public static boolean copy(final Plot origin, final Plot destination, final Runnable whenDone) {
|
||||||
PlotId offset = new PlotId(destination.id.x - origin.id.x, destination.id.y - origin.id.y);
|
PlotId offset = new PlotId(destination.id.x - origin.id.x, destination.id.y - origin.id.y);
|
||||||
Location db = destination.getBottomAbs();
|
Location db = destination.getBottomAbs();
|
||||||
@ -2085,14 +2327,22 @@ public class MainUtil {
|
|||||||
return sendMessage(plr, msg, true);
|
return sendMessage(plr, msg, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void sendConsoleMessage(final String msg) {
|
/**
|
||||||
sendMessage(null, msg);
|
* Send a message to console
|
||||||
}
|
* @param caption
|
||||||
|
* @param args
|
||||||
|
*/
|
||||||
public static void sendConsoleMessage(final C caption, final String... args) {
|
public static void sendConsoleMessage(final C caption, final String... args) {
|
||||||
sendMessage(null, caption, args);
|
sendMessage(null, caption, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send a message to a player
|
||||||
|
* @param plr Can be null to represent console, or use ConsolePlayer.getConsole()
|
||||||
|
* @param msg
|
||||||
|
* @param prefix If the message should be prefixed with the configured prefix
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean sendMessage(final PlotPlayer plr, final String msg, final boolean prefix) {
|
public static boolean sendMessage(final PlotPlayer plr, final String msg, final boolean prefix) {
|
||||||
if ((msg.length() > 0) && !msg.equals("")) {
|
if ((msg.length() > 0) && !msg.equals("")) {
|
||||||
if (plr == null) {
|
if (plr == null) {
|
||||||
@ -2104,73 +2354,6 @@ public class MainUtil {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String[] wordWrap(final String rawString, final int lineLength) {
|
|
||||||
if (rawString == null) {
|
|
||||||
return new String[] { "" };
|
|
||||||
}
|
|
||||||
if ((rawString.length() <= lineLength) && (!rawString.contains("\n"))) {
|
|
||||||
return new String[] { rawString };
|
|
||||||
}
|
|
||||||
final char[] rawChars = (rawString + ' ').toCharArray();
|
|
||||||
StringBuilder word = new StringBuilder();
|
|
||||||
StringBuilder line = new StringBuilder();
|
|
||||||
final ArrayList<String> lines = new ArrayList();
|
|
||||||
int lineColorChars = 0;
|
|
||||||
for (int i = 0; i < rawChars.length; i++) {
|
|
||||||
final char c = rawChars[i];
|
|
||||||
if (c == '\u00A7') {
|
|
||||||
word.append('\u00A7' + (rawChars[(i + 1)]));
|
|
||||||
lineColorChars += 2;
|
|
||||||
i++;
|
|
||||||
} else if ((c == ' ') || (c == '\n')) {
|
|
||||||
if ((line.length() == 0) && (word.length() > lineLength)) {
|
|
||||||
for (final String partialWord : word.toString().split("(?<=\\G.{" + lineLength + "})")) {
|
|
||||||
lines.add(partialWord);
|
|
||||||
}
|
|
||||||
} else if (((line.length() + word.length()) - lineColorChars) == lineLength) {
|
|
||||||
line.append(word);
|
|
||||||
lines.add(line.toString());
|
|
||||||
line = new StringBuilder();
|
|
||||||
lineColorChars = 0;
|
|
||||||
} else if (((line.length() + 1 + word.length()) - lineColorChars) > lineLength) {
|
|
||||||
for (final String partialWord : word.toString().split("(?<=\\G.{" + lineLength + "})")) {
|
|
||||||
lines.add(line.toString());
|
|
||||||
line = new StringBuilder(partialWord);
|
|
||||||
}
|
|
||||||
lineColorChars = 0;
|
|
||||||
} else {
|
|
||||||
if (line.length() > 0) {
|
|
||||||
line.append(' ');
|
|
||||||
}
|
|
||||||
line.append(word);
|
|
||||||
}
|
|
||||||
word = new StringBuilder();
|
|
||||||
if (c == '\n') {
|
|
||||||
lines.add(line.toString());
|
|
||||||
line = new StringBuilder();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
word.append(c);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (line.length() > 0) {
|
|
||||||
lines.add(line.toString());
|
|
||||||
}
|
|
||||||
if ((lines.get(0).length() == 0) || (lines.get(0).charAt(0) != '\u00A7')) {
|
|
||||||
lines.set(0, "\u00A7f" + lines.get(0));
|
|
||||||
}
|
|
||||||
for (int i = 1; i < lines.size(); i++) {
|
|
||||||
final String pLine = lines.get(i - 1);
|
|
||||||
final String subLine = lines.get(i);
|
|
||||||
|
|
||||||
final char color = pLine.charAt(pLine.lastIndexOf('\u00A7') + 1);
|
|
||||||
if ((subLine.length() == 0) || (subLine.charAt(0) != '\u00A7')) {
|
|
||||||
lines.set(i, '\u00A7' + (color) + subLine);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return lines.toArray(new String[lines.size()]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send a message to the player
|
* Send a message to the player
|
||||||
*
|
*
|
||||||
@ -2406,6 +2589,11 @@ public class MainUtil {
|
|||||||
return Permissions.hasPermissionRange(p, "plots.plot", Settings.MAX_PLOTS);
|
return Permissions.hasPermissionRange(p, "plots.plot", Settings.MAX_PLOTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the plot at a location
|
||||||
|
* @param loc
|
||||||
|
* @return The plot
|
||||||
|
*/
|
||||||
public static Plot getPlotAbs(final Location loc) {
|
public static Plot getPlotAbs(final Location loc) {
|
||||||
final PlotId id = getPlotId(loc);
|
final PlotId id = getPlotId(loc);
|
||||||
if (id == null) {
|
if (id == null) {
|
||||||
@ -2414,6 +2602,11 @@ public class MainUtil {
|
|||||||
return getPlotAbs(loc.getWorld(), id);
|
return getPlotAbs(loc.getWorld(), id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the plot and all connected plots at a location
|
||||||
|
* @param loc
|
||||||
|
* @return A set of plots
|
||||||
|
*/
|
||||||
public static Set<Plot> getPlots(final Location loc) {
|
public static Set<Plot> getPlots(final Location loc) {
|
||||||
final PlotId id = getPlotId(loc);
|
final PlotId id = getPlotId(loc);
|
||||||
if (id == null) {
|
if (id == null) {
|
||||||
@ -2422,6 +2615,12 @@ public class MainUtil {
|
|||||||
return getPlots(loc.getWorld(), id);
|
return getPlots(loc.getWorld(), id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the average rating for a plot
|
||||||
|
* @see Plot#getAverageRating()
|
||||||
|
* @param plot
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static double getAverageRating(final Plot plot) {
|
public static double getAverageRating(final Plot plot) {
|
||||||
HashMap<UUID, Integer> rating;
|
HashMap<UUID, Integer> rating;
|
||||||
if (plot.getSettings().ratings != null) {
|
if (plot.getSettings().ratings != null) {
|
||||||
@ -2452,6 +2651,12 @@ public class MainUtil {
|
|||||||
return val / size;
|
return val / size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If rating categories are enabled, get the average rating by category.<br>
|
||||||
|
* - The index corresponds to the index of the category in the config
|
||||||
|
* @param plot
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static double[] getAverageRatings(final Plot plot) {
|
public static double[] getAverageRatings(final Plot plot) {
|
||||||
HashMap<UUID, Integer> rating;
|
HashMap<UUID, Integer> rating;
|
||||||
if (plot.getSettings().ratings != null) {
|
if (plot.getSettings().ratings != null) {
|
||||||
@ -2486,10 +2691,28 @@ public class MainUtil {
|
|||||||
return ratings;
|
return ratings;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a component for a plot to the provided blocks<br>
|
||||||
|
* - E.g. floor, wall, border etc.<br>
|
||||||
|
* - The available components depend on the generator being used<br>
|
||||||
|
* @param plot
|
||||||
|
* @param component
|
||||||
|
* @param blocks
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean setComponent(final Plot plot, final String component, final PlotBlock[] blocks) {
|
public static boolean setComponent(final Plot plot, final String component, final PlotBlock[] blocks) {
|
||||||
return PS.get().getPlotManager(plot.world).setComponent(PS.get().getPlotWorld(plot.world), plot.id, component, blocks);
|
return PS.get().getPlotManager(plot.world).setComponent(PS.get().getPlotWorld(plot.world), plot.id, component, blocks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Format a string with plot information:<br>
|
||||||
|
* %id%, %alias%, %num%, %desc%, %biome%, %owner%, %members%, %trusted%, %helpers%, %denied%, %flags%, %build%, %desc%, %rating%
|
||||||
|
* @param info
|
||||||
|
* @param plot
|
||||||
|
* @param player
|
||||||
|
* @param full
|
||||||
|
* @param whenDone
|
||||||
|
*/
|
||||||
public static void format(String info, final Plot plot, final PlotPlayer player, final boolean full, final RunnableVal<String> whenDone) {
|
public static void format(String info, final Plot plot, final PlotPlayer player, final boolean full, final RunnableVal<String> whenDone) {
|
||||||
final int num = MainUtil.getConnectedPlots(plot).size();
|
final int num = MainUtil.getConnectedPlots(plot).size();
|
||||||
final String alias = plot.getAlias().length() > 0 ? plot.getAlias() : C.NONE.s();
|
final String alias = plot.getAlias().length() > 0 ? plot.getAlias() : C.NONE.s();
|
||||||
@ -2553,6 +2776,12 @@ public class MainUtil {
|
|||||||
whenDone.run(info);
|
whenDone.run(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a list of names given a list of uuids.<br>
|
||||||
|
* - Uses the format {@link C#PLOT_USER_LIST} for the returned string
|
||||||
|
* @param uuids
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static String getPlayerList(final Collection<UUID> uuids) {
|
public static String getPlayerList(final Collection<UUID> uuids) {
|
||||||
final ArrayList<UUID> l = new ArrayList<>(uuids);
|
final ArrayList<UUID> l = new ArrayList<>(uuids);
|
||||||
if ((l == null) || (l.size() < 1)) {
|
if ((l == null) || (l.size() < 1)) {
|
||||||
|
@ -7,11 +7,29 @@ import com.intellectualcrafters.plot.config.Settings;
|
|||||||
import com.intellectualcrafters.plot.object.PlotPlayer;
|
import com.intellectualcrafters.plot.object.PlotPlayer;
|
||||||
import com.plotsquared.general.commands.CommandCaller;
|
import com.plotsquared.general.commands.CommandCaller;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Permissions class handles checking user permissions.<br>
|
||||||
|
* - This will respect * nodes and plots.admin and can be used to check permission ranges (e.g. plots.plot.5)<br>
|
||||||
|
* - Checking the PlotPlayer class directly will not take the above into account<br>
|
||||||
|
*/
|
||||||
public class Permissions {
|
public class Permissions {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a player has a permission (C class helps keep track of permissions)
|
||||||
|
* @param player
|
||||||
|
* @param c
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean hasPermission(final PlotPlayer player, final C c) {
|
public static boolean hasPermission(final PlotPlayer player, final C c) {
|
||||||
return hasPermission(player, c.s());
|
return hasPermission(player, c.s());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a PlotPlayer has a permission
|
||||||
|
* @param player
|
||||||
|
* @param perm
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean hasPermission(final PlotPlayer player, final String perm) {
|
public static boolean hasPermission(final PlotPlayer player, final String perm) {
|
||||||
if (!Settings.PERMISSION_CACHING) {
|
if (!Settings.PERMISSION_CACHING) {
|
||||||
return hasPermission((CommandCaller) player, perm);
|
return hasPermission((CommandCaller) player, perm);
|
||||||
@ -31,6 +49,12 @@ public class Permissions {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a CommandCaller (PlotPlayer implements CommandCaller) has a permission
|
||||||
|
* @param player
|
||||||
|
* @param perm
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean hasPermission(final CommandCaller player, String perm) {
|
public static boolean hasPermission(final CommandCaller player, String perm) {
|
||||||
if (player.hasPermission(perm) || player.hasPermission(C.PERMISSION_ADMIN.s())) {
|
if (player.hasPermission(perm) || player.hasPermission(C.PERMISSION_ADMIN.s())) {
|
||||||
return true;
|
return true;
|
||||||
@ -49,6 +73,13 @@ public class Permissions {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a PlotPlayer has a permission, and optionally send the no perm message if applicable.
|
||||||
|
* @param player
|
||||||
|
* @param perm
|
||||||
|
* @param notify
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean hasPermission(final PlotPlayer player, final String perm, final boolean notify) {
|
public static boolean hasPermission(final PlotPlayer player, final String perm, final boolean notify) {
|
||||||
if (!hasPermission(player, perm)) {
|
if (!hasPermission(player, perm)) {
|
||||||
if (notify) {
|
if (notify) {
|
||||||
@ -59,6 +90,15 @@ public class Permissions {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check the the highest permission a PlotPlayer has within a specified range.<br>
|
||||||
|
* - Excessively high values will lag<br>
|
||||||
|
* - The default range that is checked is {@link Settings#MAX_PLOTS}<br>
|
||||||
|
* @param player
|
||||||
|
* @param stub The permission stub to check e.g. for `plots.plot.#` the stub is `plots.plot`
|
||||||
|
* @param range The range to check
|
||||||
|
* @return The highest permission they have within that range
|
||||||
|
*/
|
||||||
public static int hasPermissionRange(final PlotPlayer player, final String stub, final int range) {
|
public static int hasPermissionRange(final PlotPlayer player, final String stub, final int range) {
|
||||||
if (player.hasPermission(C.PERMISSION_ADMIN.s())) {
|
if (player.hasPermission(C.PERMISSION_ADMIN.s())) {
|
||||||
return Integer.MAX_VALUE;
|
return Integer.MAX_VALUE;
|
||||||
|
@ -428,7 +428,6 @@ public class BukkitMain extends JavaPlugin implements Listener, IPlotMain {
|
|||||||
try {
|
try {
|
||||||
BukkitSetBlockManager.setBlockManager = new SetBlockFast();
|
BukkitSetBlockManager.setBlockManager = new SetBlockFast();
|
||||||
} catch (final Throwable e) {
|
} catch (final Throwable e) {
|
||||||
MainUtil.canSetFast = false;
|
|
||||||
BukkitSetBlockManager.setBlockManager = new SetBlockSlow();
|
BukkitSetBlockManager.setBlockManager = new SetBlockSlow();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,6 @@ import com.intellectualcrafters.plot.object.Location;
|
|||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
import com.intellectualcrafters.plot.object.PlotId;
|
import com.intellectualcrafters.plot.object.PlotId;
|
||||||
import com.intellectualcrafters.plot.object.StringWrapper;
|
import com.intellectualcrafters.plot.object.StringWrapper;
|
||||||
import com.intellectualcrafters.plot.util.MainUtil;
|
|
||||||
import com.intellectualcrafters.plot.util.UUIDHandler;
|
import com.intellectualcrafters.plot.util.UUIDHandler;
|
||||||
|
|
||||||
public class ClassicPlotMeConnector extends APlotMeConnector {
|
public class ClassicPlotMeConnector extends APlotMeConnector {
|
||||||
@ -136,7 +135,7 @@ public class ClassicPlotMeConnector extends APlotMeConnector {
|
|||||||
if (name.length() > 0) {
|
if (name.length() > 0) {
|
||||||
owner = UUID.nameUUIDFromBytes(("OfflinePlayer:" + name.toLowerCase()).getBytes(Charsets.UTF_8));
|
owner = UUID.nameUUIDFromBytes(("OfflinePlayer:" + name.toLowerCase()).getBytes(Charsets.UTF_8));
|
||||||
}
|
}
|
||||||
MainUtil.sendConsoleMessage("&cCould not identify owner for plot: " + id + " -> '" + name + "'");
|
PS.log("&cCould not identify owner for plot: " + id + " -> '" + name + "'");
|
||||||
missing++;
|
missing++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -148,11 +147,10 @@ public class ClassicPlotMeConnector extends APlotMeConnector {
|
|||||||
plots.get(world).put(id, plot);
|
plots.get(world).put(id, plot);
|
||||||
}
|
}
|
||||||
if (missing > 0) {
|
if (missing > 0) {
|
||||||
MainUtil.sendConsoleMessage("&cSome names could not be identified:");
|
PS.log("&cSome names could not be identified:");
|
||||||
MainUtil.sendConsoleMessage("&7 - Empty quotes mean PlotMe just stored an unowned plot in the database");
|
PS.log("&7 - Empty quotes mean PlotMe just stored an unowned plot in the database");
|
||||||
MainUtil.sendConsoleMessage("&7 - Names you have never seen before could be from people mistyping commands");
|
PS.log("&7 - Names you have never seen before could be from people mistyping commands");
|
||||||
MainUtil
|
PS.log("&7 - Converting from a non-uuid version of PlotMe can't identify owners if the playerdata files are deleted (these plots will remain unknown until the player connects)");
|
||||||
.sendConsoleMessage("&7 - Converting from a non-uuid version of PlotMe can't identify owners if the playerdata files are deleted (these plots will remain unknown until the player connects)");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (final Entry<String, HashMap<PlotId, boolean[]>> entry : merges.entrySet()) {
|
for (final Entry<String, HashMap<PlotId, boolean[]>> entry : merges.entrySet()) {
|
||||||
@ -171,7 +169,7 @@ public class ClassicPlotMeConnector extends APlotMeConnector {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
MainUtil.sendConsoleMessage(" - " + prefix + "Denied");
|
PS.log(" - " + prefix + "Denied");
|
||||||
stmt = connection.prepareStatement("SELECT * FROM `" + prefix + "Denied`");
|
stmt = connection.prepareStatement("SELECT * FROM `" + prefix + "Denied`");
|
||||||
r = stmt.executeQuery();
|
r = stmt.executeQuery();
|
||||||
|
|
||||||
@ -207,7 +205,7 @@ public class ClassicPlotMeConnector extends APlotMeConnector {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (denied == null) {
|
if (denied == null) {
|
||||||
MainUtil.sendConsoleMessage("&6Could not identify denied for plot: " + id);
|
PS.log("&6Could not identify denied for plot: " + id);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -251,7 +249,7 @@ public class ClassicPlotMeConnector extends APlotMeConnector {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (helper == null) {
|
if (helper == null) {
|
||||||
MainUtil.sendConsoleMessage("&6Could not identify helper for plot: " + id);
|
PS.log("&6Could not identify helper for plot: " + id);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,6 @@ import com.intellectualcrafters.plot.object.Location;
|
|||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
import com.intellectualcrafters.plot.object.PlotId;
|
import com.intellectualcrafters.plot.object.PlotId;
|
||||||
import com.intellectualcrafters.plot.object.StringWrapper;
|
import com.intellectualcrafters.plot.object.StringWrapper;
|
||||||
import com.intellectualcrafters.plot.util.MainUtil;
|
|
||||||
import com.intellectualcrafters.plot.util.UUIDHandler;
|
import com.intellectualcrafters.plot.util.UUIDHandler;
|
||||||
|
|
||||||
public class PlotMeConnector_017 extends APlotMeConnector {
|
public class PlotMeConnector_017 extends APlotMeConnector {
|
||||||
@ -123,7 +122,7 @@ public class PlotMeConnector_017 extends APlotMeConnector {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (owner == null) {
|
if (owner == null) {
|
||||||
MainUtil.sendConsoleMessage("&cCould not identify owner for plot: " + id + " -> '" + name + "'");
|
PS.log("&cCould not identify owner for plot: " + id + " -> '" + name + "'");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -145,7 +144,7 @@ public class PlotMeConnector_017 extends APlotMeConnector {
|
|||||||
r.close();
|
r.close();
|
||||||
stmt.close();
|
stmt.close();
|
||||||
try {
|
try {
|
||||||
MainUtil.sendConsoleMessage(" - " + plugin + "core_denied");
|
PS.log(" - " + plugin + "core_denied");
|
||||||
stmt = connection.prepareStatement("SELECT * FROM `" + plugin + "core_denied`");
|
stmt = connection.prepareStatement("SELECT * FROM `" + plugin + "core_denied`");
|
||||||
r = stmt.executeQuery();
|
r = stmt.executeQuery();
|
||||||
|
|
||||||
@ -153,14 +152,14 @@ public class PlotMeConnector_017 extends APlotMeConnector {
|
|||||||
final int key = r.getInt("plot_id");
|
final int key = r.getInt("plot_id");
|
||||||
final Plot plot = plots.get(key);
|
final Plot plot = plots.get(key);
|
||||||
if (plot == null) {
|
if (plot == null) {
|
||||||
MainUtil.sendConsoleMessage("&6Denied (" + key + ") references deleted plot; ignoring entry.");
|
PS.log("&6Denied (" + key + ") references deleted plot; ignoring entry.");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
final UUID denied = UUID.fromString(r.getString("player"));
|
final UUID denied = UUID.fromString(r.getString("player"));
|
||||||
plot.getDenied().add(denied);
|
plot.getDenied().add(denied);
|
||||||
}
|
}
|
||||||
|
|
||||||
MainUtil.sendConsoleMessage(" - " + plugin + "core_allowed");
|
PS.log(" - " + plugin + "core_allowed");
|
||||||
stmt = connection.prepareStatement("SELECT * FROM `" + plugin + "core_allowed`");
|
stmt = connection.prepareStatement("SELECT * FROM `" + plugin + "core_allowed`");
|
||||||
r = stmt.executeQuery();
|
r = stmt.executeQuery();
|
||||||
|
|
||||||
@ -168,7 +167,7 @@ public class PlotMeConnector_017 extends APlotMeConnector {
|
|||||||
final int key = r.getInt("plot_id");
|
final int key = r.getInt("plot_id");
|
||||||
final Plot plot = plots.get(key);
|
final Plot plot = plots.get(key);
|
||||||
if (plot == null) {
|
if (plot == null) {
|
||||||
MainUtil.sendConsoleMessage("&6Allowed (" + key + ") references deleted plot; ignoring entry.");
|
PS.log("&6Allowed (" + key + ") references deleted plot; ignoring entry.");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
final UUID allowed = UUID.fromString(r.getString("player"));
|
final UUID allowed = UUID.fromString(r.getString("player"));
|
||||||
|
@ -2,6 +2,7 @@ package com.plotsquared.sponge;
|
|||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
@ -28,7 +29,7 @@ import org.spongepowered.api.event.game.state.GameInitializationEvent;
|
|||||||
import org.spongepowered.api.event.game.state.GamePreInitializationEvent;
|
import org.spongepowered.api.event.game.state.GamePreInitializationEvent;
|
||||||
import org.spongepowered.api.plugin.Plugin;
|
import org.spongepowered.api.plugin.Plugin;
|
||||||
import org.spongepowered.api.plugin.PluginContainer;
|
import org.spongepowered.api.plugin.PluginContainer;
|
||||||
import org.spongepowered.api.service.profile.GameProfileResolver;
|
import org.spongepowered.api.profile.GameProfileManager;
|
||||||
import org.spongepowered.api.text.Text;
|
import org.spongepowered.api.text.Text;
|
||||||
import org.spongepowered.api.text.Texts;
|
import org.spongepowered.api.text.Texts;
|
||||||
import org.spongepowered.api.text.translation.Translatable;
|
import org.spongepowered.api.text.translation.Translatable;
|
||||||
@ -36,6 +37,8 @@ import org.spongepowered.api.text.translation.Translation;
|
|||||||
import org.spongepowered.api.world.DimensionTypes;
|
import org.spongepowered.api.world.DimensionTypes;
|
||||||
import org.spongepowered.api.world.GeneratorTypes;
|
import org.spongepowered.api.world.GeneratorTypes;
|
||||||
import org.spongepowered.api.world.World;
|
import org.spongepowered.api.world.World;
|
||||||
|
import org.spongepowered.api.world.WorldBuilder;
|
||||||
|
import org.spongepowered.api.world.gen.WorldGeneratorModifier;
|
||||||
|
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import com.intellectualcrafters.configuration.ConfigurationSection;
|
import com.intellectualcrafters.configuration.ConfigurationSection;
|
||||||
@ -80,13 +83,12 @@ import com.plotsquared.sponge.util.SpongeUtil;
|
|||||||
import com.plotsquared.sponge.uuid.SpongeLowerOfflineUUIDWrapper;
|
import com.plotsquared.sponge.uuid.SpongeLowerOfflineUUIDWrapper;
|
||||||
import com.plotsquared.sponge.uuid.SpongeOnlineUUIDWrapper;
|
import com.plotsquared.sponge.uuid.SpongeOnlineUUIDWrapper;
|
||||||
import com.plotsquared.sponge.uuid.SpongeUUIDHandler;
|
import com.plotsquared.sponge.uuid.SpongeUUIDHandler;
|
||||||
import org.spongepowered.api.world.WorldBuilder;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by robin on 01/11/2014
|
* Created by robin on 01/11/2014
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Plugin(id = "PlotSquared", name = "PlotSquared", version = "3.0.0", dependencies = "before:WorldEdit")
|
@Plugin(id = "PlotSquared", name = "PlotSquared", version = "3.0.0", dependencies = "before:WorldEdit,required-after:TotalEconomy")
|
||||||
public class SpongeMain implements IPlotMain, PluginContainer {
|
public class SpongeMain implements IPlotMain, PluginContainer {
|
||||||
public static SpongeMain THIS;
|
public static SpongeMain THIS;
|
||||||
|
|
||||||
@ -96,13 +98,12 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
private Game game;
|
private Game game;
|
||||||
private Server server;
|
private Server server;
|
||||||
|
|
||||||
private GameProfileResolver resolver;
|
private GameProfileManager resolver;
|
||||||
|
|
||||||
private WorldModify modify;
|
private WorldModify modify;
|
||||||
|
|
||||||
private Object plugin;
|
|
||||||
|
|
||||||
// stuff //
|
// stuff //
|
||||||
|
@Override
|
||||||
public Logger getLogger() {
|
public Logger getLogger() {
|
||||||
return logger;
|
return logger;
|
||||||
}
|
}
|
||||||
@ -115,12 +116,12 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
return server;
|
return server;
|
||||||
}
|
}
|
||||||
|
|
||||||
public GameProfileResolver getResolver() {
|
public GameProfileManager getResolver() {
|
||||||
return resolver;
|
return resolver;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getPlugin() {
|
public SpongeMain getPlugin() {
|
||||||
return plugin;
|
return THIS;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Text getText(final String m) {
|
public Text getText(final String m) {
|
||||||
@ -192,8 +193,8 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getInstance() {
|
public Optional<Object> getInstance() {
|
||||||
return THIS;
|
return Optional.<Object> of(THIS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -223,7 +224,24 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
|
|
||||||
@Listener
|
@Listener
|
||||||
public void onInit(final GamePreInitializationEvent event) {
|
public void onInit(final GamePreInitializationEvent event) {
|
||||||
log("P^2 PRE INIT");
|
// Hook for Project Worlds
|
||||||
|
hookProjectWorlds();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void hookProjectWorlds() {
|
||||||
|
Optional<PluginContainer> plugin = game.getPluginManager().getPlugin("Project Worlds");
|
||||||
|
if (plugin.isPresent()) {
|
||||||
|
try {
|
||||||
|
Class<?> clazz = Class.forName("com.gmail.trentech.pjw.modifiers.Modifiers");
|
||||||
|
Method method = clazz.getMethod("put", String.class, WorldGeneratorModifier.class);
|
||||||
|
SpongeBasicGen generator = new SpongeBasicGen(null);
|
||||||
|
method.invoke(null, "plotsquared", new WorldModify(generator, false));
|
||||||
|
log("Adding plotsquared modifier to Project Worlds");
|
||||||
|
}
|
||||||
|
catch (Throwable e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Listener
|
@Listener
|
||||||
@ -232,8 +250,7 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
THIS = this;
|
THIS = this;
|
||||||
|
|
||||||
//
|
//
|
||||||
resolver = game.getServiceManager().provide(GameProfileResolver.class).get();
|
resolver = game.getServiceManager().provide(GameProfileManager.class).get();
|
||||||
plugin = this;
|
|
||||||
server = game.getServer();
|
server = game.getServer();
|
||||||
//
|
//
|
||||||
|
|
||||||
@ -318,7 +335,6 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
PS.get().copyFile("data.txt", "config");
|
PS.get().copyFile("data.txt", "config");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
final File id_file = new File(getDirectory(), "config" + File.separator + "ids.txt");
|
final File id_file = new File(getDirectory(), "config" + File.separator + "ids.txt");
|
||||||
final List<String> id_lines = Files.readAllLines(id_file.toPath(), StandardCharsets.UTF_8);
|
final List<String> id_lines = Files.readAllLines(id_file.toPath(), StandardCharsets.UTF_8);
|
||||||
|
|
||||||
@ -494,7 +510,7 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void registerCommands() {
|
public void registerCommands() {
|
||||||
getGame().getCommandDispatcher().register(plugin, new SpongeCommand(), new String[] { "plots", "p", "plot", "ps", "plotsquared", "p2", "2" });
|
getGame().getCommandManager().register(THIS, new SpongeCommand(), new String[] { "plots", "p", "plot", "ps", "plotsquared", "p2", "2" });
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -523,7 +539,6 @@ public class SpongeMain implements IPlotMain, PluginContainer {
|
|||||||
@Override
|
@Override
|
||||||
public boolean initWorldEdit() {
|
public boolean initWorldEdit() {
|
||||||
try {
|
try {
|
||||||
log("CHECKING FOR WORLDEDIT!?");
|
|
||||||
Class.forName("com.sk89q.worldedit.WorldEdit");
|
Class.forName("com.sk89q.worldedit.WorldEdit");
|
||||||
return true;
|
return true;
|
||||||
} catch (final Throwable e) {
|
} catch (final Throwable e) {
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
package com.plotsquared.sponge.events;
|
package com.plotsquared.sponge.events;
|
||||||
|
|
||||||
import org.spongepowered.api.event.impl.AbstractEvent;
|
|
||||||
import org.spongepowered.api.event.Cancellable;
|
import org.spongepowered.api.event.Cancellable;
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
|
import org.spongepowered.api.event.impl.AbstractEvent;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.flag.Flag;
|
import com.intellectualcrafters.plot.flag.Flag;
|
||||||
import com.intellectualcrafters.plot.object.PlotCluster;
|
import com.intellectualcrafters.plot.object.PlotCluster;
|
||||||
@ -44,4 +45,9 @@ public class ClusterFlagRemoveEvent extends AbstractEvent implements Cancellable
|
|||||||
public void setCancelled(final boolean cancel) {
|
public void setCancelled(final boolean cancel) {
|
||||||
cancelled = cancel;
|
cancelled = cancel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package com.plotsquared.sponge.events;
|
|||||||
|
|
||||||
import org.spongepowered.api.entity.living.player.Player;
|
import org.spongepowered.api.entity.living.player.Player;
|
||||||
import org.spongepowered.api.event.Cancellable;
|
import org.spongepowered.api.event.Cancellable;
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
|
|
||||||
@ -48,4 +49,9 @@ public class PlayerClaimPlotEvent extends PlayerEvent implements Cancellable {
|
|||||||
public void setCancelled(final boolean cancel) {
|
public void setCancelled(final boolean cancel) {
|
||||||
cancelled = cancel;
|
cancelled = cancel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package com.plotsquared.sponge.events;
|
package com.plotsquared.sponge.events;
|
||||||
|
|
||||||
import org.spongepowered.api.entity.living.player.Player;
|
import org.spongepowered.api.entity.living.player.Player;
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
|
|
||||||
@ -27,4 +28,9 @@ public class PlayerEnterPlotEvent extends PlayerEvent {
|
|||||||
public Plot getPlot() {
|
public Plot getPlot() {
|
||||||
return plot;
|
return plot;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package com.plotsquared.sponge.events;
|
package com.plotsquared.sponge.events;
|
||||||
|
|
||||||
import org.spongepowered.api.entity.living.player.Player;
|
import org.spongepowered.api.entity.living.player.Player;
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
import org.spongepowered.api.event.impl.AbstractEvent;
|
import org.spongepowered.api.event.impl.AbstractEvent;
|
||||||
|
|
||||||
public abstract class PlayerEvent extends AbstractEvent {
|
public abstract class PlayerEvent extends AbstractEvent {
|
||||||
@ -15,4 +16,9 @@ public abstract class PlayerEvent extends AbstractEvent {
|
|||||||
return player;
|
return player;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
package com.plotsquared.sponge.events;
|
package com.plotsquared.sponge.events;
|
||||||
|
|
||||||
import org.spongepowered.api.event.impl.AbstractEvent;
|
|
||||||
import org.spongepowered.api.event.Cancellable;
|
import org.spongepowered.api.event.Cancellable;
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
|
import org.spongepowered.api.event.impl.AbstractEvent;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.PlotId;
|
import com.intellectualcrafters.plot.object.PlotId;
|
||||||
|
|
||||||
@ -48,4 +49,9 @@ public class PlotClearEvent extends AbstractEvent implements Cancellable {
|
|||||||
public void setCancelled(final boolean cancel) {
|
public void setCancelled(final boolean cancel) {
|
||||||
cancelled = cancel;
|
cancelled = cancel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package com.plotsquared.sponge.events;
|
package com.plotsquared.sponge.events;
|
||||||
|
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
import org.spongepowered.api.event.impl.AbstractEvent;
|
import org.spongepowered.api.event.impl.AbstractEvent;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.PlotId;
|
import com.intellectualcrafters.plot.object.PlotId;
|
||||||
@ -36,4 +37,9 @@ public class PlotDeleteEvent extends AbstractEvent {
|
|||||||
public String getWorld() {
|
public String getWorld() {
|
||||||
return world;
|
return world;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package com.plotsquared.sponge.events;
|
package com.plotsquared.sponge.events;
|
||||||
|
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
import org.spongepowered.api.event.impl.AbstractEvent;
|
import org.spongepowered.api.event.impl.AbstractEvent;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
@ -16,4 +17,9 @@ public abstract class PlotEvent extends AbstractEvent {
|
|||||||
return plot;
|
return plot;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,9 @@ package com.plotsquared.sponge.events;
|
|||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.spongepowered.api.event.impl.AbstractEvent;
|
|
||||||
import org.spongepowered.api.event.Cancellable;
|
import org.spongepowered.api.event.Cancellable;
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
|
import org.spongepowered.api.event.impl.AbstractEvent;
|
||||||
import org.spongepowered.api.world.World;
|
import org.spongepowered.api.world.World;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.Plot;
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
@ -57,4 +58,9 @@ public class PlotMergeEvent extends AbstractEvent implements Cancellable {
|
|||||||
public void setCancelled(final boolean cancel) {
|
public void setCancelled(final boolean cancel) {
|
||||||
cancelled = cancel;
|
cancelled = cancel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,9 @@ package com.plotsquared.sponge.events;
|
|||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.spongepowered.api.event.impl.AbstractEvent;
|
|
||||||
import org.spongepowered.api.event.Cancellable;
|
import org.spongepowered.api.event.Cancellable;
|
||||||
|
import org.spongepowered.api.event.cause.Cause;
|
||||||
|
import org.spongepowered.api.event.impl.AbstractEvent;
|
||||||
import org.spongepowered.api.world.World;
|
import org.spongepowered.api.world.World;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.PlotId;
|
import com.intellectualcrafters.plot.object.PlotId;
|
||||||
@ -46,4 +47,9 @@ public class PlotUnlinkEvent extends AbstractEvent implements Cancellable {
|
|||||||
public void setCancelled(final boolean cancel) {
|
public void setCancelled(final boolean cancel) {
|
||||||
cancelled = cancel;
|
cancelled = cancel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Cause getCause() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,7 @@ import org.spongepowered.api.world.extent.ImmutableBlockVolume;
|
|||||||
import org.spongepowered.api.world.extent.MutableBlockVolume;
|
import org.spongepowered.api.world.extent.MutableBlockVolume;
|
||||||
import org.spongepowered.api.world.extent.StorageType;
|
import org.spongepowered.api.world.extent.StorageType;
|
||||||
import org.spongepowered.api.world.extent.UnmodifiableBlockVolume;
|
import org.spongepowered.api.world.extent.UnmodifiableBlockVolume;
|
||||||
import org.spongepowered.api.world.gen.GeneratorPopulator;
|
import org.spongepowered.api.world.gen.GenerationPopulator;
|
||||||
import org.spongepowered.api.world.gen.Populator;
|
import org.spongepowered.api.world.gen.Populator;
|
||||||
import org.spongepowered.api.world.gen.WorldGenerator;
|
import org.spongepowered.api.world.gen.WorldGenerator;
|
||||||
|
|
||||||
@ -38,7 +38,7 @@ public class AugmentedPopulator implements Populator {
|
|||||||
public final PlotWorld plotworld;
|
public final PlotWorld plotworld;
|
||||||
public final PlotManager manager;
|
public final PlotManager manager;
|
||||||
public final SpongePlotGenerator generator;
|
public final SpongePlotGenerator generator;
|
||||||
public final GeneratorPopulator populator;
|
public final GenerationPopulator populator;
|
||||||
public final PlotCluster cluster;
|
public final PlotCluster cluster;
|
||||||
public final Random r = new Random();
|
public final Random r = new Random();
|
||||||
public final boolean p;
|
public final boolean p;
|
||||||
@ -54,7 +54,7 @@ public class AugmentedPopulator implements Populator {
|
|||||||
// Initialize any chach that's needed
|
// Initialize any chach that's needed
|
||||||
this.cluster = cluster;
|
this.cluster = cluster;
|
||||||
this.generator = generator;
|
this.generator = generator;
|
||||||
populator = generator.getBaseGeneratorPopulator();
|
populator = generator.getBaseGenerationPopulator();
|
||||||
plotworld = generator.getNewPlotWorld(worldname);
|
plotworld = generator.getNewPlotWorld(worldname);
|
||||||
manager = generator.getPlotManager();
|
manager = generator.getPlotManager();
|
||||||
this.p = p;
|
this.p = p;
|
||||||
|
@ -66,7 +66,6 @@ public class SpongeBasicGen extends SpongePlotGenerator {
|
|||||||
}
|
}
|
||||||
pathWidthUpper = (short) (pathWidthLower + plotsize + 1);
|
pathWidthUpper = (short) (pathWidthLower + plotsize + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
roadblock = SpongeMain.THIS.getBlockState(this.plotworld.ROAD_BLOCK);
|
roadblock = SpongeMain.THIS.getBlockState(this.plotworld.ROAD_BLOCK);
|
||||||
wallfilling = SpongeMain.THIS.getBlockState(this.plotworld.WALL_FILLING);
|
wallfilling = SpongeMain.THIS.getBlockState(this.plotworld.WALL_FILLING);
|
||||||
wall = SpongeMain.THIS.getBlockState(this.plotworld.WALL_BLOCK);
|
wall = SpongeMain.THIS.getBlockState(this.plotworld.WALL_BLOCK);
|
||||||
@ -127,5 +126,4 @@ public class SpongeBasicGen extends SpongePlotGenerator {
|
|||||||
}
|
}
|
||||||
return biome;
|
return biome;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,13 @@
|
|||||||
package com.plotsquared.sponge.generator;
|
package com.plotsquared.sponge.generator;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.spongepowered.api.world.biome.BiomeGenerationSettings;
|
||||||
|
import org.spongepowered.api.world.biome.BiomeType;
|
||||||
import org.spongepowered.api.world.gen.BiomeGenerator;
|
import org.spongepowered.api.world.gen.BiomeGenerator;
|
||||||
import org.spongepowered.api.world.gen.GeneratorPopulator;
|
import org.spongepowered.api.world.gen.GenerationPopulator;
|
||||||
import org.spongepowered.api.world.gen.Populator;
|
import org.spongepowered.api.world.gen.Populator;
|
||||||
import org.spongepowered.api.world.gen.WorldGenerator;
|
import org.spongepowered.api.world.gen.WorldGenerator;
|
||||||
|
|
||||||
@ -14,14 +17,14 @@ import com.intellectualcrafters.plot.object.SetupObject;
|
|||||||
|
|
||||||
public abstract class SpongePlotGenerator implements WorldGenerator {
|
public abstract class SpongePlotGenerator implements WorldGenerator {
|
||||||
|
|
||||||
public final String world;
|
public String world;
|
||||||
|
|
||||||
public SpongePlotGenerator(final String world) {
|
public SpongePlotGenerator(final String world) {
|
||||||
this.world = world;
|
this.world = world;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public GeneratorPopulator getBaseGeneratorPopulator() {
|
public GenerationPopulator getBaseGenerationPopulator() {
|
||||||
return getGenerator();
|
return getGenerator();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -30,31 +33,55 @@ public abstract class SpongePlotGenerator implements WorldGenerator {
|
|||||||
return getPlotBiomeProvider();
|
return getPlotBiomeProvider();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<GeneratorPopulator> getGeneratorPopulators() {
|
|
||||||
final List<GeneratorPopulator> pops = new ArrayList<>();
|
|
||||||
pops.addAll(getPlotPopulators());
|
|
||||||
return pops;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<Populator> getPopulators() {
|
public List<Populator> getPopulators() {
|
||||||
return new ArrayList<>();
|
return new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setBaseGeneratorPopulator(final GeneratorPopulator arg0) {
|
|
||||||
// TODO Auto-generated method stub
|
|
||||||
throw new UnsupportedOperationException("NOT IMPLEMENTED YET");
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setBiomeGenerator(final BiomeGenerator biomeGenerator) {
|
public void setBiomeGenerator(final BiomeGenerator biomeGenerator) {
|
||||||
// TODO
|
// TODO
|
||||||
throw new UnsupportedOperationException("NOT IMPLEMENTED YET");
|
throw new UnsupportedOperationException("NOT IMPLEMENTED YET");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BiomeGenerationSettings getBiomeSettings(BiomeType type) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
throw new UnsupportedOperationException("NOT IMPLEMENTED YET");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<GenerationPopulator> getGenerationPopulators() {
|
||||||
|
final List<GenerationPopulator> pops = new ArrayList<>();
|
||||||
|
pops.addAll(getPlotPopulators());
|
||||||
|
return pops;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<GenerationPopulator> getGenerationPopulators(Class<? extends GenerationPopulator> clazz) {
|
||||||
|
List<GenerationPopulator> list = getGenerationPopulators();
|
||||||
|
Iterator<GenerationPopulator> iter = list.iterator();
|
||||||
|
while (iter.hasNext()) {
|
||||||
|
GenerationPopulator pop = iter.next();
|
||||||
|
if (!clazz.isInstance(pop)) {
|
||||||
|
iter.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<Populator> getPopulators(Class<? extends Populator> arg0) {
|
||||||
|
return new ArrayList<>();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setBaseGenerationPopulator(GenerationPopulator arg0) {
|
||||||
|
// TODO
|
||||||
|
throw new UnsupportedOperationException("NOT IMPLEMENTED YET");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public abstract SpongePlotPopulator getGenerator();
|
public abstract SpongePlotPopulator getGenerator();
|
||||||
|
|
||||||
public abstract BiomeGenerator getPlotBiomeProvider();
|
public abstract BiomeGenerator getPlotBiomeProvider();
|
||||||
|
@ -22,7 +22,8 @@ public class WorldModify implements WorldGeneratorModifier {
|
|||||||
@Override
|
@Override
|
||||||
public void modifyWorldGenerator(final WorldCreationSettings world, final DataContainer settings, final WorldGenerator gen) {
|
public void modifyWorldGenerator(final WorldCreationSettings world, final DataContainer settings, final WorldGenerator gen) {
|
||||||
if (augment) {
|
if (augment) {
|
||||||
final String worldname = plotgen.world;
|
final String worldname = world.getWorldName();
|
||||||
|
plotgen.world = worldname;
|
||||||
final PlotWorld plotworld = plotgen.getNewPlotWorld(worldname);
|
final PlotWorld plotworld = plotgen.getNewPlotWorld(worldname);
|
||||||
if (plotworld.TYPE == 2) {
|
if (plotworld.TYPE == 2) {
|
||||||
for (final PlotCluster cluster : ClusterManager.getClusters(worldname)) {
|
for (final PlotCluster cluster : ClusterManager.getClusters(worldname)) {
|
||||||
@ -32,9 +33,9 @@ public class WorldModify implements WorldGeneratorModifier {
|
|||||||
new AugmentedPopulator(worldname, gen, plotgen, null, plotworld.TERRAIN == 2, plotworld.TERRAIN != 2);
|
new AugmentedPopulator(worldname, gen, plotgen, null, plotworld.TERRAIN == 2, plotworld.TERRAIN != 2);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
gen.getGeneratorPopulators().clear();
|
gen.getGenerationPopulators().clear();
|
||||||
gen.getPopulators().clear();
|
gen.getPopulators().clear();
|
||||||
gen.setBaseGeneratorPopulator(plotgen.getBaseGeneratorPopulator());
|
gen.setBaseGenerationPopulator(plotgen.getBaseGenerationPopulator());
|
||||||
gen.setBiomeGenerator(plotgen.getBiomeGenerator());
|
gen.setBiomeGenerator(plotgen.getBiomeGenerator());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -37,6 +37,7 @@ public class SpongeBlockManager extends BlockManager {
|
|||||||
@Override
|
@Override
|
||||||
public StringComparison<PlotBlock>.ComparisonResult getClosestBlock(String name) {
|
public StringComparison<PlotBlock>.ComparisonResult getClosestBlock(String name) {
|
||||||
try {
|
try {
|
||||||
|
|
||||||
double match;
|
double match;
|
||||||
short id;
|
short id;
|
||||||
byte data;
|
byte data;
|
||||||
@ -94,6 +95,7 @@ public class SpongeBlockManager extends BlockManager {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PlotBlock getPlotBlockFromString(final String block) {
|
public PlotBlock getPlotBlockFromString(final String block) {
|
||||||
|
dsa
|
||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -3,17 +3,17 @@ package com.plotsquared.sponge.util;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.spongepowered.api.command.CommandCallable;
|
||||||
|
import org.spongepowered.api.command.CommandException;
|
||||||
|
import org.spongepowered.api.command.CommandResult;
|
||||||
|
import org.spongepowered.api.command.CommandSource;
|
||||||
import org.spongepowered.api.entity.living.player.Player;
|
import org.spongepowered.api.entity.living.player.Player;
|
||||||
import org.spongepowered.api.text.Text;
|
import org.spongepowered.api.text.Text;
|
||||||
import org.spongepowered.api.text.Texts;
|
import org.spongepowered.api.text.Texts;
|
||||||
import org.spongepowered.api.util.command.CommandCallable;
|
|
||||||
import org.spongepowered.api.util.command.CommandException;
|
|
||||||
import org.spongepowered.api.util.command.CommandResult;
|
|
||||||
import org.spongepowered.api.util.command.CommandSource;
|
|
||||||
|
|
||||||
import java.util.Optional;
|
|
||||||
import com.intellectualcrafters.plot.commands.MainCommand;
|
import com.intellectualcrafters.plot.commands.MainCommand;
|
||||||
import com.intellectualcrafters.plot.object.ConsolePlayer;
|
import com.intellectualcrafters.plot.object.ConsolePlayer;
|
||||||
import com.intellectualcrafters.plot.object.PlotPlayer;
|
import com.intellectualcrafters.plot.object.PlotPlayer;
|
||||||
|
@ -1,34 +1,57 @@
|
|||||||
package com.plotsquared.sponge.util;
|
package com.plotsquared.sponge.util;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.apache.commons.lang.NotImplementedException;
|
||||||
|
|
||||||
|
import com.intellectualcrafters.plot.PS;
|
||||||
import com.intellectualcrafters.plot.object.OfflinePlotPlayer;
|
import com.intellectualcrafters.plot.object.OfflinePlotPlayer;
|
||||||
import com.intellectualcrafters.plot.object.PlotPlayer;
|
import com.intellectualcrafters.plot.object.PlotPlayer;
|
||||||
import com.intellectualcrafters.plot.util.EconHandler;
|
import com.intellectualcrafters.plot.util.EconHandler;
|
||||||
import com.intellectualcrafters.plot.util.UUIDHandler;
|
import com.intellectualcrafters.plot.util.UUIDHandler;
|
||||||
|
import com.plotsquared.sponge.SpongeMain;
|
||||||
import com.plotsquared.sponge.object.SpongePlayer;
|
import com.plotsquared.sponge.object.SpongePlayer;
|
||||||
|
|
||||||
public class SpongeEconHandler extends EconHandler {
|
public class SpongeEconHandler extends EconHandler {
|
||||||
|
|
||||||
|
private Object TE_SERVICE;
|
||||||
|
private Object EL_SERVICE;
|
||||||
|
|
||||||
|
public SpongeEconHandler() {
|
||||||
|
try {
|
||||||
|
Class<?> clazz = Class.forName("com.erigitic.service.TEService");
|
||||||
|
this.TE_SERVICE = SpongeMain.THIS.getGame().getServiceManager().provide(clazz).get();
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
try {
|
||||||
|
Class<?> clazz = Class.forName("me.Flibio.EconomyLite.API.EconomyLiteAPI");
|
||||||
|
this.EL_SERVICE = SpongeMain.THIS.getGame().getServiceManager().provide(clazz).get();
|
||||||
|
} catch (Exception e2) {
|
||||||
|
PS.log("No economy service found! (EconomyLite, TotalEconomy)");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void withdrawMoney(PlotPlayer player, double amount) {
|
public void withdrawMoney(PlotPlayer player, double amount) {
|
||||||
// TODO Auto-generated method stub
|
UUID uuid = ((SpongePlayer) player).player.getUniqueId();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void depositMoney(PlotPlayer player, double amount) {
|
public void depositMoney(PlotPlayer player, double amount) {
|
||||||
// TODO Auto-generated method stub
|
UUID uuid = ((SpongePlayer) player).player.getUniqueId();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void depositMoney(OfflinePlotPlayer player, double amount) {
|
public void depositMoney(OfflinePlotPlayer player, double amount) {
|
||||||
// TODO Auto-generated method stub
|
UUID uuid = player.getUUID();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setPermission(String world, String player, String perm, boolean value) {
|
public void setPermission(String world, String player, String perm, boolean value) {
|
||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
|
throw new NotImplementedException("TODO/WIP/NOT IMPLEMENTED!");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -4,7 +4,7 @@ import java.util.ArrayList;
|
|||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.spongepowered.api.event.Event;
|
import org.spongepowered.api.event.Event;
|
||||||
import org.spongepowered.api.service.event.EventManager;
|
import org.spongepowered.api.event.EventManager;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.flag.Flag;
|
import com.intellectualcrafters.plot.flag.Flag;
|
||||||
import com.intellectualcrafters.plot.object.Location;
|
import com.intellectualcrafters.plot.object.Location;
|
||||||
|
@ -51,7 +51,7 @@ import ninja.leaping.configurate.loader.ConfigurationLoader;
|
|||||||
|
|
||||||
import org.spongepowered.api.Game;
|
import org.spongepowered.api.Game;
|
||||||
import org.spongepowered.api.plugin.PluginContainer;
|
import org.spongepowered.api.plugin.PluginContainer;
|
||||||
import org.spongepowered.api.service.scheduler.Task;
|
import org.spongepowered.api.scheduler.Task;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.PS;
|
import com.intellectualcrafters.plot.PS;
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@ package com.plotsquared.sponge.util;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
import org.spongepowered.api.service.scheduler.Task;
|
import org.spongepowered.api.scheduler.Task;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.util.TaskManager;
|
import com.intellectualcrafters.plot.util.TaskManager;
|
||||||
import com.plotsquared.sponge.SpongeMain;
|
import com.plotsquared.sponge.SpongeMain;
|
||||||
|
@ -2,8 +2,8 @@ package com.plotsquared.sponge.uuid;
|
|||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.spongepowered.api.GameProfile;
|
|
||||||
import org.spongepowered.api.entity.living.player.Player;
|
import org.spongepowered.api.entity.living.player.Player;
|
||||||
|
import org.spongepowered.api.profile.GameProfile;
|
||||||
|
|
||||||
import com.google.common.base.Charsets;
|
import com.google.common.base.Charsets;
|
||||||
import com.intellectualcrafters.plot.object.OfflinePlotPlayer;
|
import com.intellectualcrafters.plot.object.OfflinePlotPlayer;
|
||||||
|
@ -2,7 +2,7 @@ package com.plotsquared.sponge.uuid;
|
|||||||
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.spongepowered.api.GameProfile;
|
import org.spongepowered.api.profile.GameProfile;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.database.DBFunc;
|
import com.intellectualcrafters.plot.database.DBFunc;
|
||||||
import com.intellectualcrafters.plot.object.RunnableVal;
|
import com.intellectualcrafters.plot.object.RunnableVal;
|
||||||
|
Loading…
Reference in New Issue
Block a user