mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2025-01-04 15:38:00 +01:00
Removal of code smells.
Removed a lot of debug code. Refactored some loops into lambas.
This commit is contained in:
parent
01aef76eb5
commit
e881a5bd2b
@ -66,7 +66,6 @@ public class BSkyBlock extends JavaPlugin {
|
|||||||
settings = settings.loadSettings();
|
settings = settings.loadSettings();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
getLogger().severe("Settings could not be loaded " + e.getMessage());
|
getLogger().severe("Settings could not be loaded " + e.getMessage());
|
||||||
e.printStackTrace();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save a backup of settings to the database so it can be checked next time
|
// Save a backup of settings to the database so it can be checked next time
|
||||||
|
@ -27,7 +27,6 @@ import us.tastybento.bskyblock.managers.PlayersManager;
|
|||||||
public abstract class Addon implements AddonInterface {
|
public abstract class Addon implements AddonInterface {
|
||||||
|
|
||||||
private static final String ADDON_CONFIG_FILENAME = "config.yml";
|
private static final String ADDON_CONFIG_FILENAME = "config.yml";
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
private boolean enabled;
|
private boolean enabled;
|
||||||
private AddonDescription description;
|
private AddonDescription description;
|
||||||
private FileConfiguration config;
|
private FileConfiguration config;
|
||||||
@ -188,10 +187,6 @@ public abstract class Addon implements AddonInterface {
|
|||||||
}
|
}
|
||||||
// Make any dirs that need to be made
|
// Make any dirs that need to be made
|
||||||
outFile.getParentFile().mkdirs();
|
outFile.getParentFile().mkdirs();
|
||||||
if (DEBUG) {
|
|
||||||
Bukkit.getLogger().info("DEBUG: outFile = " + outFile.getAbsolutePath());
|
|
||||||
Bukkit.getLogger().info("DEBUG: outFile name = " + outFile.getName());
|
|
||||||
}
|
|
||||||
if (!outFile.exists() || replace) {
|
if (!outFile.exists() || replace) {
|
||||||
java.nio.file.Files.copy(in, outFile.toPath());
|
java.nio.file.Files.copy(in, outFile.toPath());
|
||||||
}
|
}
|
||||||
|
@ -70,7 +70,6 @@ public class BSBLocale {
|
|||||||
YamlConfiguration toBeMerged = YamlConfiguration.loadConfiguration(language);
|
YamlConfiguration toBeMerged = YamlConfiguration.loadConfiguration(language);
|
||||||
for (String key : toBeMerged.getKeys(true)) {
|
for (String key : toBeMerged.getKeys(true)) {
|
||||||
if (!config.contains(key)) {
|
if (!config.contains(key)) {
|
||||||
//Bukkit.getLogger().info("Merging in key " + key );
|
|
||||||
config.set(key, toBeMerged.get(key));
|
config.set(key, toBeMerged.get(key));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -237,8 +237,8 @@ public class User {
|
|||||||
*/
|
*/
|
||||||
public void notify(String reference, String... variables) {
|
public void notify(String reference, String... variables) {
|
||||||
String message = getTranslation(reference, variables);
|
String message = getTranslation(reference, variables);
|
||||||
if (!ChatColor.stripColor(message).trim().isEmpty()) {
|
if (!ChatColor.stripColor(message).trim().isEmpty() && (sender != null || !plugin.getNotifier().notify(this, message))) {
|
||||||
if (sender != null || !plugin.getNotifier().notify(this, message)) sendRawMessage(message);
|
sendRawMessage(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,7 +3,6 @@ package us.tastybento.bskyblock.commands.island.teams;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.GameMode;
|
import org.bukkit.GameMode;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
|
|
||||||
@ -29,8 +28,6 @@ public class IslandTeamInviteAcceptCommand extends AbstractIslandTeamCommand {
|
|||||||
@Override
|
@Override
|
||||||
public boolean execute(User user, List<String> args) {
|
public boolean execute(User user, List<String> args) {
|
||||||
|
|
||||||
Bukkit.getLogger().info("DEBUG: accept - " + inviteList.toString());
|
|
||||||
|
|
||||||
UUID playerUUID = user.getUniqueId();
|
UUID playerUUID = user.getUniqueId();
|
||||||
if(!inviteList.containsKey(playerUUID)) {
|
if(!inviteList.containsKey(playerUUID)) {
|
||||||
return false;
|
return false;
|
||||||
@ -52,9 +49,6 @@ public class IslandTeamInviteAcceptCommand extends AbstractIslandTeamCommand {
|
|||||||
inviteList.remove(playerUUID);
|
inviteList.remove(playerUUID);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (DEBUG) {
|
|
||||||
getPlugin().getLogger().info("DEBUG: Invite is valid");
|
|
||||||
}
|
|
||||||
// Fire event so add-ons can run commands, etc.
|
// Fire event so add-ons can run commands, etc.
|
||||||
IslandBaseEvent event = TeamEvent.builder()
|
IslandBaseEvent event = TeamEvent.builder()
|
||||||
.island(getIslands()
|
.island(getIslands()
|
||||||
@ -67,9 +61,6 @@ public class IslandTeamInviteAcceptCommand extends AbstractIslandTeamCommand {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
// Remove the invite
|
// Remove the invite
|
||||||
if (DEBUG) {
|
|
||||||
getPlugin().getLogger().info("DEBUG: Removing player from invite list");
|
|
||||||
}
|
|
||||||
inviteList.remove(playerUUID);
|
inviteList.remove(playerUUID);
|
||||||
// Put player into Spectator mode
|
// Put player into Spectator mode
|
||||||
user.setGameMode(GameMode.SPECTATOR);
|
user.setGameMode(GameMode.SPECTATOR);
|
||||||
@ -105,9 +96,6 @@ public class IslandTeamInviteAcceptCommand extends AbstractIslandTeamCommand {
|
|||||||
inviter.sendMessage("commands.island.team.invite.accept.name-joined-your-island", "[name]", user.getName());
|
inviter.sendMessage("commands.island.team.invite.accept.name-joined-your-island", "[name]", user.getName());
|
||||||
}
|
}
|
||||||
getIslands().save(false);
|
getIslands().save(false);
|
||||||
if (DEBUG) {
|
|
||||||
getPlugin().getLogger().info(() -> "DEBUG: After save " + getIslands().getIsland(prospectiveTeamLeaderUUID).getMemberSet().toString());
|
|
||||||
}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,8 +2,6 @@ package us.tastybento.bskyblock.commands.island.teams;
|
|||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
|
|
||||||
import us.tastybento.bskyblock.Constants;
|
import us.tastybento.bskyblock.Constants;
|
||||||
import us.tastybento.bskyblock.api.user.User;
|
import us.tastybento.bskyblock.api.user.User;
|
||||||
|
|
||||||
@ -57,10 +55,8 @@ public class IslandTeamPromoteCommand extends AbstractIslandTeamCommand {
|
|||||||
|
|
||||||
private boolean change(User user, User target) {
|
private boolean change(User user, User target) {
|
||||||
int currentRank = getIslands().getIsland(user.getUniqueId()).getRank(target);
|
int currentRank = getIslands().getIsland(user.getUniqueId()).getRank(target);
|
||||||
Bukkit.getLogger().info("DEBUG: current rank = " + currentRank);
|
|
||||||
if (this.getLabel().equals("promote")) {
|
if (this.getLabel().equals("promote")) {
|
||||||
int nextRank = getPlugin().getRanksManager().getNextRankValue(currentRank);
|
int nextRank = getPlugin().getRanksManager().getNextRankValue(currentRank);
|
||||||
Bukkit.getLogger().info("DEBUG: next rank = " + nextRank);
|
|
||||||
if (nextRank > currentRank) {
|
if (nextRank > currentRank) {
|
||||||
getIslands().getIsland(user.getUniqueId()).setRank(target, nextRank);
|
getIslands().getIsland(user.getUniqueId()).setRank(target, nextRank);
|
||||||
String rankName = user.getTranslation(getPlugin().getRanksManager().getRank(nextRank));
|
String rankName = user.getTranslation(getPlugin().getRanksManager().getRank(nextRank));
|
||||||
@ -73,7 +69,6 @@ public class IslandTeamPromoteCommand extends AbstractIslandTeamCommand {
|
|||||||
} else {
|
} else {
|
||||||
// Demote
|
// Demote
|
||||||
int prevRank = getPlugin().getRanksManager().getPreviousRankValue(currentRank);
|
int prevRank = getPlugin().getRanksManager().getPreviousRankValue(currentRank);
|
||||||
Bukkit.getLogger().info("DEBUG: Rev rank = " + prevRank);
|
|
||||||
if (prevRank < currentRank) {
|
if (prevRank < currentRank) {
|
||||||
getIslands().getIsland(user.getUniqueId()).setRank(target, prevRank);
|
getIslands().getIsland(user.getUniqueId()).setRank(target, prevRank);
|
||||||
String rankName = user.getTranslation(getPlugin().getRanksManager().getRank(prevRank));
|
String rankName = user.getTranslation(getPlugin().getRanksManager().getRank(prevRank));
|
||||||
|
@ -60,7 +60,6 @@ public class BSBDatabase<T> {
|
|||||||
} catch (InstantiationException | IllegalAccessException | IllegalArgumentException | InvocationTargetException
|
} catch (InstantiationException | IllegalAccessException | IllegalArgumentException | InvocationTargetException
|
||||||
| ClassNotFoundException | IntrospectionException e) {
|
| ClassNotFoundException | IntrospectionException e) {
|
||||||
logger.severe(() -> "Could not load object from database! " + e.getMessage());
|
logger.severe(() -> "Could not load object from database! " + e.getMessage());
|
||||||
e.printStackTrace();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
|
@ -50,8 +50,8 @@ public class FlatFileDatabaseHandler<T> extends AbstractDatabaseHandler<T> {
|
|||||||
private static final String DATABASE_FOLDER_NAME = "database";
|
private static final String DATABASE_FOLDER_NAME = "database";
|
||||||
protected boolean configFlag;
|
protected boolean configFlag;
|
||||||
|
|
||||||
public FlatFileDatabaseHandler(Plugin plugin, Class<T> type, DatabaseConnecter databaseConnecter) {
|
public FlatFileDatabaseHandler(Plugin plugin, Class<T> type, DatabaseConnecter dbConnecter) {
|
||||||
super(plugin, type, databaseConnecter);
|
super(plugin, type, dbConnecter);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
@ -351,7 +351,6 @@ public class FlatFileDatabaseHandler<T> extends AbstractDatabaseHandler<T> {
|
|||||||
if (object == null) {
|
if (object == null) {
|
||||||
return "null";
|
return "null";
|
||||||
}
|
}
|
||||||
//plugin.getLogger().info("DEBUG: serializing " + object.getClass().getTypeName());
|
|
||||||
if (object instanceof UUID) {
|
if (object instanceof UUID) {
|
||||||
return ((UUID)object).toString();
|
return ((UUID)object).toString();
|
||||||
}
|
}
|
||||||
|
@ -34,8 +34,7 @@ public class MongoDBDatabaseConnecter implements DatabaseConnecter {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MongoDatabase createConnection() {
|
public MongoDatabase createConnection() {
|
||||||
MongoDatabase database = client.getDatabase(dbSettings.getDatabaseName());
|
return client.getDatabase(dbSettings.getDatabaseName());
|
||||||
return database;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -48,7 +48,7 @@ public class MongoDBDatabaseHandler<T> extends AbstractDatabaseHandler<T> {
|
|||||||
*/
|
*/
|
||||||
private MongoDatabase database = null;
|
private MongoDatabase database = null;
|
||||||
private MongoCollection<Document> collection;
|
private MongoCollection<Document> collection;
|
||||||
private DatabaseConnecter databaseConnecter;
|
private DatabaseConnecter dbConnecter;
|
||||||
|
|
||||||
private BSkyBlock bskyblock;
|
private BSkyBlock bskyblock;
|
||||||
|
|
||||||
@ -57,13 +57,13 @@ public class MongoDBDatabaseHandler<T> extends AbstractDatabaseHandler<T> {
|
|||||||
* the class that will be stored.
|
* the class that will be stored.
|
||||||
* @param plugin - BSkyBlock plugin object
|
* @param plugin - BSkyBlock plugin object
|
||||||
* @param type - the type of class to be stored in the database. Must inherit DataObject
|
* @param type - the type of class to be stored in the database. Must inherit DataObject
|
||||||
* @param databaseConnecter - authentication details for the database
|
* @param dbConnecter - authentication details for the database
|
||||||
*/
|
*/
|
||||||
public MongoDBDatabaseHandler(BSkyBlock plugin, Class<T> type, DatabaseConnecter databaseConnecter) {
|
public MongoDBDatabaseHandler(BSkyBlock plugin, Class<T> type, DatabaseConnecter dbConnecter) {
|
||||||
super(plugin, type, databaseConnecter);
|
super(plugin, type, dbConnecter);
|
||||||
this.bskyblock = plugin;
|
this.bskyblock = plugin;
|
||||||
this.databaseConnecter = databaseConnecter;
|
this.dbConnecter = dbConnecter;
|
||||||
database = (MongoDatabase)databaseConnecter.createConnection();
|
database = (MongoDatabase)dbConnecter.createConnection();
|
||||||
collection = database.getCollection(dataObject.getCanonicalName());
|
collection = database.getCollection(dataObject.getCanonicalName());
|
||||||
IndexOptions indexOptions = new IndexOptions().unique(true);
|
IndexOptions indexOptions = new IndexOptions().unique(true);
|
||||||
collection.createIndex(Indexes.text(UNIQUEID), indexOptions);
|
collection.createIndex(Indexes.text(UNIQUEID), indexOptions);
|
||||||
@ -160,7 +160,7 @@ public class MongoDBDatabaseHandler<T> extends AbstractDatabaseHandler<T> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void close() {
|
public void close() {
|
||||||
databaseConnecter.closeConnection();
|
dbConnecter.closeConnection();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,12 +48,12 @@ public class MySQLDatabaseHandler<T> extends AbstractDatabaseHandler<T> {
|
|||||||
* the class that will be stored.
|
* the class that will be stored.
|
||||||
* @param plugin - BSkyBlock plugin object
|
* @param plugin - BSkyBlock plugin object
|
||||||
* @param type - the type of class to be stored in the database. Must inherit DataObject
|
* @param type - the type of class to be stored in the database. Must inherit DataObject
|
||||||
* @param databaseConnecter - authentication details for the database
|
* @param dbConnecter - authentication details for the database
|
||||||
*/
|
*/
|
||||||
public MySQLDatabaseHandler(BSkyBlock plugin, Class<T> type, DatabaseConnecter databaseConnecter) {
|
public MySQLDatabaseHandler(BSkyBlock plugin, Class<T> type, DatabaseConnecter dbConnecter) {
|
||||||
super(plugin, type, databaseConnecter);
|
super(plugin, type, dbConnecter);
|
||||||
this.bskyblock = plugin;
|
this.bskyblock = plugin;
|
||||||
connection = (Connection)databaseConnecter.createConnection();
|
connection = (Connection)dbConnecter.createConnection();
|
||||||
// Check if the table exists in the database and if not, create it
|
// Check if the table exists in the database and if not, create it
|
||||||
createSchema();
|
createSchema();
|
||||||
}
|
}
|
||||||
|
@ -315,7 +315,6 @@ public class Island implements DataObject {
|
|||||||
for (int x = getMinProtectedX() /16; x <= (getMinProtectedX() + getProtectionRange() - 1)/16; x++) {
|
for (int x = getMinProtectedX() /16; x <= (getMinProtectedX() + getProtectionRange() - 1)/16; x++) {
|
||||||
for (int z = getMinProtectedZ() /16; z <= (getMinProtectedZ() + getProtectionRange() - 1)/16; z++) {
|
for (int z = getMinProtectedZ() /16; z <= (getMinProtectedZ() + getProtectionRange() - 1)/16; z++) {
|
||||||
for (BlockState holder : world.getChunkAt(x, z).getTileEntities()) {
|
for (BlockState holder : world.getChunkAt(x, z).getTileEntities()) {
|
||||||
//plugin.getLogger().info("DEBUG: tile entity: " + holder.getType());
|
|
||||||
if (onIsland(holder.getLocation())) {
|
if (onIsland(holder.getLocation())) {
|
||||||
if (holder.getType() == material) {
|
if (holder.getType() == material) {
|
||||||
result++;
|
result++;
|
||||||
@ -339,7 +338,6 @@ public class Island implements DataObject {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (Entity holder : world.getChunkAt(x, z).getEntities()) {
|
for (Entity holder : world.getChunkAt(x, z).getEntities()) {
|
||||||
//plugin.getLogger().info("DEBUG: entity: " + holder.getType());
|
|
||||||
if (holder.getType().toString().equals(material.toString()) && onIsland(holder.getLocation())) {
|
if (holder.getType().toString().equals(material.toString()) && onIsland(holder.getLocation())) {
|
||||||
result++;
|
result++;
|
||||||
}
|
}
|
||||||
|
@ -227,26 +227,21 @@ public class Players implements DataObject {
|
|||||||
public long getInviteCoolDownTime(Location location) {
|
public long getInviteCoolDownTime(Location location) {
|
||||||
// Check the hashmap
|
// Check the hashmap
|
||||||
if (location != null && kickedList.containsKey(location)) {
|
if (location != null && kickedList.containsKey(location)) {
|
||||||
// plugin.getLogger().info("DEBUG: Location is known");
|
|
||||||
// The location is in the list
|
// The location is in the list
|
||||||
// Check the date/time
|
// Check the date/time
|
||||||
Date kickedDate = new Date(kickedList.get(location));
|
Date kickedDate = new Date(kickedList.get(location));
|
||||||
// plugin.getLogger().info("DEBUG: kicked date = " + kickedDate);
|
|
||||||
Calendar coolDownTime = Calendar.getInstance();
|
Calendar coolDownTime = Calendar.getInstance();
|
||||||
coolDownTime.setTime(kickedDate);
|
coolDownTime.setTime(kickedDate);
|
||||||
// coolDownTime.add(Calendar.HOUR_OF_DAY, Settings.inviteWait);
|
// coolDownTime.add(Calendar.HOUR_OF_DAY, Settings.inviteWait);
|
||||||
coolDownTime.add(Calendar.MINUTE, getPlugin().getSettings().getInviteWait());
|
coolDownTime.add(Calendar.MINUTE, getPlugin().getSettings().getInviteWait());
|
||||||
// Add the invite cooldown period
|
// Add the invite cooldown period
|
||||||
Calendar timeNow = Calendar.getInstance();
|
Calendar timeNow = Calendar.getInstance();
|
||||||
// plugin.getLogger().info("DEBUG: date now = " + timeNow);
|
|
||||||
if (coolDownTime.before(timeNow)) {
|
if (coolDownTime.before(timeNow)) {
|
||||||
// The time has expired
|
// The time has expired
|
||||||
kickedList.remove(location);
|
kickedList.remove(location);
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
// Still not there yet
|
// Still not there yet
|
||||||
// long hours = (coolDownTime.getTimeInMillis() -
|
|
||||||
// timeNow.getTimeInMillis())/(1000 * 60 * 60);
|
|
||||||
// Temp minutes
|
// Temp minutes
|
||||||
return (coolDownTime.getTimeInMillis() - timeNow.getTimeInMillis()) / (1000 * 60);
|
return (coolDownTime.getTimeInMillis() - timeNow.getTimeInMillis()) / (1000 * 60);
|
||||||
}
|
}
|
||||||
|
@ -78,8 +78,6 @@ public class ChunkGeneratorWorld extends ChunkGenerator {
|
|||||||
for (int x = 0; x < 16; x++) {
|
for (int x = 0; x < 16; x++) {
|
||||||
for (int z = 0; z < 16; z++) {
|
for (int z = 0; z < 16; z++) {
|
||||||
// Do the ceiling
|
// Do the ceiling
|
||||||
// Bukkit.getLogger().info("debug: " + x + ", " +
|
|
||||||
// (world.getMaxHeight()-1) + ", " + z);
|
|
||||||
int maxHeight = world.getMaxHeight();
|
int maxHeight = world.getMaxHeight();
|
||||||
result.setBlock(x, (maxHeight - 1), z, Material.BEDROCK);
|
result.setBlock(x, (maxHeight - 1), z, Material.BEDROCK);
|
||||||
// Next three layers are a mix of bedrock and netherrack
|
// Next three layers are a mix of bedrock and netherrack
|
||||||
|
@ -112,9 +112,7 @@ public class NetherPopulator extends BlockPopulator {
|
|||||||
world.generateTree(source.getBlock(x, y + 1, z).getLocation(), TreeType.BROWN_MUSHROOM);
|
world.generateTree(source.getBlock(x, y + 1, z).getLocation(), TreeType.BROWN_MUSHROOM);
|
||||||
b.setType(Material.SOUL_SAND);
|
b.setType(Material.SOUL_SAND);
|
||||||
} else if (b.getType().equals(Material.SOUL_SAND) && b.getRelative(BlockFace.UP).getType().equals(Material.AIR)) {
|
} else if (b.getType().equals(Material.SOUL_SAND) && b.getRelative(BlockFace.UP).getType().equals(Material.AIR)) {
|
||||||
//Bukkit.getLogger().info("DEBUG: soul sand found!");
|
|
||||||
if (random.nextInt(9) == 1) {
|
if (random.nextInt(9) == 1) {
|
||||||
//Bukkit.getLogger().info("DEBUG: Setting to NETHER_WARTS");
|
|
||||||
b.getRelative(BlockFace.UP).setType(Material.NETHER_WARTS);
|
b.getRelative(BlockFace.UP).setType(Material.NETHER_WARTS);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,6 @@ import us.tastybento.bskyblock.managers.PlayersManager;
|
|||||||
|
|
||||||
public class JoinLeaveListener implements Listener {
|
public class JoinLeaveListener implements Listener {
|
||||||
|
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
private BSkyBlock plugin;
|
private BSkyBlock plugin;
|
||||||
private PlayersManager players;
|
private PlayersManager players;
|
||||||
|
|
||||||
@ -39,56 +38,31 @@ public class JoinLeaveListener implements Listener {
|
|||||||
}
|
}
|
||||||
UUID playerUUID = user.getUniqueId();
|
UUID playerUUID = user.getUniqueId();
|
||||||
if (plugin.getPlayers().isKnown(playerUUID)) {
|
if (plugin.getPlayers().isKnown(playerUUID)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: known player");
|
|
||||||
}
|
|
||||||
// Load player
|
// Load player
|
||||||
players.addPlayer(playerUUID);
|
players.addPlayer(playerUUID);
|
||||||
// Reset resets if the admin changes it to or from unlimited
|
// Reset resets if the admin changes it to or from unlimited
|
||||||
if (plugin.getSettings().getResetLimit() < players.getResetsLeft(playerUUID) || (plugin.getSettings().getResetLimit() >= 0 && players.getResetsLeft(playerUUID) < 0)) {
|
if (plugin.getSettings().getResetLimit() < players.getResetsLeft(playerUUID) || (plugin.getSettings().getResetLimit() >= 0 && players.getResetsLeft(playerUUID) < 0)) {
|
||||||
players.setResetsLeft(playerUUID, plugin.getSettings().getResetLimit());
|
players.setResetsLeft(playerUUID, plugin.getSettings().getResetLimit());
|
||||||
}
|
}
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: Setting player's name");
|
|
||||||
}
|
|
||||||
// Set the player's name (it may have changed), but only if it isn't empty
|
// Set the player's name (it may have changed), but only if it isn't empty
|
||||||
if (!user.getName().isEmpty()) {
|
if (!user.getName().isEmpty()) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: Player name is " + user.getName());
|
|
||||||
}
|
|
||||||
players.setPlayerName(user);
|
players.setPlayerName(user);
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: Saving player");
|
|
||||||
}
|
|
||||||
players.save(playerUUID);
|
players.save(playerUUID);
|
||||||
} else {
|
} else {
|
||||||
plugin.getLogger().warning("Player that just logged in has no name! " + playerUUID.toString());
|
plugin.getLogger().warning("Player that just logged in has no name! " + playerUUID.toString());
|
||||||
}
|
}
|
||||||
if (plugin.getSettings().isRemoveMobsOnLogin()) {
|
if (plugin.getSettings().isRemoveMobsOnLogin()) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: Removing mobs");
|
|
||||||
}
|
|
||||||
plugin.getIslands().removeMobs(user.getLocation());
|
plugin.getIslands().removeMobs(user.getLocation());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if they logged in to a locked island and expel them or if they are banned
|
// Check if they logged in to a locked island and expel them or if they are banned
|
||||||
Island currentIsland = plugin.getIslands().getIslandAt(user.getLocation()).orElse(null);
|
Island currentIsland = plugin.getIslands().getIslandAt(user.getLocation()).orElse(null);
|
||||||
if (currentIsland != null && (currentIsland.isLocked() || plugin.getPlayers().isBanned(currentIsland.getOwner(),user.getUniqueId()))) {
|
if (currentIsland != null && (currentIsland.isLocked() || plugin.getPlayers().isBanned(currentIsland.getOwner(),user.getUniqueId()))) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: Current island is locked, or player is banned");
|
|
||||||
}
|
|
||||||
if (!currentIsland.getMemberSet().contains(playerUUID) && !user.hasPermission(Constants.PERMPREFIX + "mod.bypassprotect")) {
|
if (!currentIsland.getMemberSet().contains(playerUUID) && !user.hasPermission(Constants.PERMPREFIX + "mod.bypassprotect")) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: No bypass - teleporting");
|
|
||||||
}
|
|
||||||
user.sendMessage("locked.islandlocked");
|
user.sendMessage("locked.islandlocked");
|
||||||
plugin.getIslands().homeTeleport(user.getPlayer());
|
plugin.getIslands().homeTeleport(user.getPlayer());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: not a known player");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +112,6 @@ public class FireListener extends AbstractFlagListener {
|
|||||||
*/
|
*/
|
||||||
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
||||||
public boolean onTNTPrimed(EntityChangeBlockEvent e) {
|
public boolean onTNTPrimed(EntityChangeBlockEvent e) {
|
||||||
//Bukkit.getLogger().info("DEBUG: " + e.getBlock().getType());
|
|
||||||
return e.getBlock().getType().equals(Material.TNT) && checkFire(e, e.getBlock().getLocation(), Flags.FIRE);
|
return e.getBlock().getType().equals(Material.TNT) && checkFire(e, e.getBlock().getLocation(), Flags.FIRE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,7 +30,6 @@ import us.tastybento.bskyblock.util.Util;
|
|||||||
*/
|
*/
|
||||||
public class FlyingMobEvents implements Listener {
|
public class FlyingMobEvents implements Listener {
|
||||||
private final BSkyBlock plugin;
|
private final BSkyBlock plugin;
|
||||||
private final static boolean DEBUG = false;
|
|
||||||
private WeakHashMap<Entity, Island> mobSpawnInfo;
|
private WeakHashMap<Entity, Island> mobSpawnInfo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -41,24 +40,19 @@ public class FlyingMobEvents implements Listener {
|
|||||||
mobSpawnInfo = new WeakHashMap<>();
|
mobSpawnInfo = new WeakHashMap<>();
|
||||||
|
|
||||||
plugin.getServer().getScheduler().runTaskTimer(plugin, () -> {
|
plugin.getServer().getScheduler().runTaskTimer(plugin, () -> {
|
||||||
//Bukkit.getLogger().info("DEBUG: checking - mobspawn size = " + mobSpawnInfo.size());
|
|
||||||
Iterator<Entry<Entity, Island>> it = mobSpawnInfo.entrySet().iterator();
|
Iterator<Entry<Entity, Island>> it = mobSpawnInfo.entrySet().iterator();
|
||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
Entry<Entity, Island> entry = it.next();
|
Entry<Entity, Island> entry = it.next();
|
||||||
if (entry.getKey() == null) {
|
if (entry.getKey() == null) {
|
||||||
//Bukkit.getLogger().info("DEBUG: removing null entity");
|
|
||||||
it.remove();
|
it.remove();
|
||||||
} else {
|
} else {
|
||||||
if (entry.getKey() instanceof LivingEntity) {
|
if (entry.getKey() instanceof LivingEntity) {
|
||||||
if (!entry.getValue().inIslandSpace(entry.getKey().getLocation())) {
|
if (!entry.getValue().inIslandSpace(entry.getKey().getLocation())) {
|
||||||
//Bukkit.getLogger().info("DEBUG: removing entity outside of island");
|
|
||||||
it.remove();
|
it.remove();
|
||||||
// Kill mob
|
// Kill mob
|
||||||
LivingEntity mob = (LivingEntity)entry.getKey();
|
LivingEntity mob = (LivingEntity)entry.getKey();
|
||||||
mob.setHealth(0);
|
mob.setHealth(0);
|
||||||
entry.getKey().remove();
|
entry.getKey().remove();
|
||||||
} else {
|
|
||||||
//Bukkit.getLogger().info("DEBUG: entity " + entry.getKey().getName() + " is in island space");
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Not living entity
|
// Not living entity
|
||||||
@ -82,32 +76,20 @@ public class FlyingMobEvents implements Listener {
|
|||||||
if (!e.getEntityType().equals(EntityType.WITHER) && !e.getEntityType().equals(EntityType.BLAZE) && !e.getEntityType().equals(EntityType.GHAST)) {
|
if (!e.getEntityType().equals(EntityType.WITHER) && !e.getEntityType().equals(EntityType.BLAZE) && !e.getEntityType().equals(EntityType.GHAST)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("Flying mobs " + e.getEventName());
|
|
||||||
}
|
|
||||||
// Store where this mob originated
|
// Store where this mob originated
|
||||||
plugin.getIslands().getIslandAt(e.getLocation()).ifPresent(island->mobSpawnInfo.put(e.getEntity(),island));
|
plugin.getIslands().getIslandAt(e.getLocation()).ifPresent(island->mobSpawnInfo.put(e.getEntity(),island));
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
||||||
public void mobExplosion(EntityExplodeEvent e) {
|
public void mobExplosion(EntityExplodeEvent e) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info(e.getEventName());
|
|
||||||
}
|
|
||||||
// Only cover in the island world
|
// Only cover in the island world
|
||||||
if (e.getEntity() == null || !Util.inWorld(e.getEntity())) {
|
if (e.getEntity() == null || !Util.inWorld(e.getEntity())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (mobSpawnInfo.containsKey(e.getEntity())) {
|
if (mobSpawnInfo.containsKey(e.getEntity())) {
|
||||||
// We know about this mob
|
// We know about this mob
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: We know about this mob");
|
|
||||||
}
|
|
||||||
if (!mobSpawnInfo.get(e.getEntity()).inIslandSpace(e.getLocation())) {
|
if (!mobSpawnInfo.get(e.getEntity()).inIslandSpace(e.getLocation())) {
|
||||||
// Cancel the explosion and block damage
|
// Cancel the explosion and block damage
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: cancel flying mob explosion");
|
|
||||||
}
|
|
||||||
e.blockList().clear();
|
e.blockList().clear();
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
}
|
}
|
||||||
@ -119,50 +101,32 @@ public class FlyingMobEvents implements Listener {
|
|||||||
*/
|
*/
|
||||||
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
||||||
public void witherExplode(ExplosionPrimeEvent e) {
|
public void witherExplode(ExplosionPrimeEvent e) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info(e.getEventName());
|
|
||||||
}
|
|
||||||
// Only cover withers in the island world
|
// Only cover withers in the island world
|
||||||
if (!Util.inWorld(e.getEntity()) || e.getEntity() == null) {
|
if (!Util.inWorld(e.getEntity()) || e.getEntity() == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// The wither or wither skulls can both blow up
|
// The wither or wither skulls can both blow up
|
||||||
if (e.getEntityType() == EntityType.WITHER) {
|
if (e.getEntityType() == EntityType.WITHER) {
|
||||||
//plugin.getLogger().info("DEBUG: Wither");
|
|
||||||
// Check the location
|
// Check the location
|
||||||
if (mobSpawnInfo.containsKey(e.getEntity())) {
|
if (mobSpawnInfo.containsKey(e.getEntity())) {
|
||||||
// We know about this wither
|
// We know about this wither
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: We know about this wither");
|
|
||||||
}
|
|
||||||
if (!mobSpawnInfo.get(e.getEntity()).inIslandSpace(e.getEntity().getLocation())) {
|
if (!mobSpawnInfo.get(e.getEntity()).inIslandSpace(e.getEntity().getLocation())) {
|
||||||
// Cancel the explosion
|
// Cancel the explosion
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: cancelling wither pre-explosion");
|
|
||||||
}
|
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Testing only e.setCancelled(true);
|
// Testing only e.setCancelled(true);
|
||||||
}
|
}
|
||||||
if (e.getEntityType() == EntityType.WITHER_SKULL) {
|
if (e.getEntityType() == EntityType.WITHER_SKULL) {
|
||||||
//plugin.getLogger().info("DEBUG: Wither skull");
|
|
||||||
// Get shooter
|
// Get shooter
|
||||||
Projectile projectile = (Projectile)e.getEntity();
|
Projectile projectile = (Projectile)e.getEntity();
|
||||||
if (projectile.getShooter() instanceof Wither) {
|
if (projectile.getShooter() instanceof Wither) {
|
||||||
//plugin.getLogger().info("DEBUG: shooter is wither");
|
|
||||||
Wither wither = (Wither)projectile.getShooter();
|
Wither wither = (Wither)projectile.getShooter();
|
||||||
// Check the location
|
// Check the location
|
||||||
if (mobSpawnInfo.containsKey(wither)) {
|
if (mobSpawnInfo.containsKey(wither)) {
|
||||||
// We know about this wither
|
// We know about this wither
|
||||||
if (DEBUG) {
|
if (!mobSpawnInfo.get(wither).inIslandSpace(e.getEntity().getLocation())) {
|
||||||
plugin.getLogger().info("DEBUG: We know about this wither");
|
|
||||||
}
|
|
||||||
if (!mobSpawnInfo.get(wither).inIslandSpace(e.getEntity().getLocation())) {
|
|
||||||
// Cancel the explosion
|
// Cancel the explosion
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: cancel wither skull explosion");
|
|
||||||
}
|
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -177,23 +141,14 @@ public class FlyingMobEvents implements Listener {
|
|||||||
*/
|
*/
|
||||||
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.LOW, ignoreCancelled = true)
|
||||||
public void witherChangeBlocks(EntityChangeBlockEvent e) {
|
public void witherChangeBlocks(EntityChangeBlockEvent e) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info(e.getEventName());
|
|
||||||
}
|
|
||||||
// Only cover withers in the island world
|
// Only cover withers in the island world
|
||||||
if (e.getEntityType() != EntityType.WITHER || !Util.inWorld(e.getEntity()) ) {
|
if (e.getEntityType() != EntityType.WITHER || !Util.inWorld(e.getEntity()) ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (mobSpawnInfo.containsKey(e.getEntity())) {
|
if (mobSpawnInfo.containsKey(e.getEntity())) {
|
||||||
// We know about this wither
|
// We know about this wither
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: We know about this wither");
|
|
||||||
}
|
|
||||||
if (!mobSpawnInfo.get(e.getEntity()).inIslandSpace(e.getEntity().getLocation())) {
|
if (!mobSpawnInfo.get(e.getEntity()).inIslandSpace(e.getEntity().getLocation())) {
|
||||||
// Cancel the block changes
|
// Cancel the block changes
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: cancelled wither block change");
|
|
||||||
}
|
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,6 @@ public class InventorySave {
|
|||||||
* @param player - the player
|
* @param player - the player
|
||||||
*/
|
*/
|
||||||
public void savePlayerInventory(Player player) {
|
public void savePlayerInventory(Player player) {
|
||||||
//plugin.getLogger().info("DEBUG: Saving inventory");
|
|
||||||
// Save the player's armor and things
|
// Save the player's armor and things
|
||||||
inventories.put(player.getUniqueId(),new InventoryStore(player.getInventory().getContents(), player.getInventory().getArmorContents()));
|
inventories.put(player.getUniqueId(),new InventoryStore(player.getInventory().getContents(), player.getInventory().getArmorContents()));
|
||||||
}
|
}
|
||||||
@ -38,7 +37,6 @@ public class InventorySave {
|
|||||||
* @param player - the player
|
* @param player - the player
|
||||||
*/
|
*/
|
||||||
public void clearSavedInventory(Player player) {
|
public void clearSavedInventory(Player player) {
|
||||||
//plugin.getLogger().info("DEBUG: Clearing inventory");
|
|
||||||
inventories.remove(player.getUniqueId());
|
inventories.remove(player.getUniqueId());
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
@ -47,11 +45,9 @@ public class InventorySave {
|
|||||||
* @param player - the player
|
* @param player - the player
|
||||||
*/
|
*/
|
||||||
public void loadPlayerInventory(Player player) {
|
public void loadPlayerInventory(Player player) {
|
||||||
//plugin.getLogger().info("DEBUG: Loading inventory");
|
|
||||||
// Get the info for this player
|
// Get the info for this player
|
||||||
if (inventories.containsKey(player.getUniqueId())) {
|
if (inventories.containsKey(player.getUniqueId())) {
|
||||||
InventoryStore inv = inventories.get(player.getUniqueId());
|
InventoryStore inv = inventories.get(player.getUniqueId());
|
||||||
//plugin.getLogger().info("DEBUG: player is known");
|
|
||||||
player.getInventory().setContents(inv.getInventory());
|
player.getInventory().setContents(inv.getInventory());
|
||||||
player.getInventory().setArmorContents(inv.getArmor());
|
player.getInventory().setArmorContents(inv.getArmor());
|
||||||
inventories.remove(player.getUniqueId());
|
inventories.remove(player.getUniqueId());
|
||||||
|
@ -114,7 +114,6 @@ public final class AddonsManager {
|
|||||||
// Open a reader to the jar
|
// Open a reader to the jar
|
||||||
BufferedReader reader = new BufferedReader(new InputStreamReader(jar.getInputStream(entry)));
|
BufferedReader reader = new BufferedReader(new InputStreamReader(jar.getInputStream(entry)));
|
||||||
// Grab the description in the addon.yml file
|
// Grab the description in the addon.yml file
|
||||||
//Map<String, String> data = data(reader);
|
|
||||||
YamlConfiguration data = new YamlConfiguration();
|
YamlConfiguration data = new YamlConfiguration();
|
||||||
data.load(reader);
|
data.load(reader);
|
||||||
// Load the addon
|
// Load the addon
|
||||||
@ -256,7 +255,6 @@ public final class AddonsManager {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//plugin.getLogger().info("DEBUG: jar filename = " + entry.getName());
|
|
||||||
if (entry.getName().endsWith(".yml")) {
|
if (entry.getName().endsWith(".yml")) {
|
||||||
result.add(entry.getName());
|
result.add(entry.getName());
|
||||||
}
|
}
|
||||||
|
@ -10,13 +10,9 @@ import us.tastybento.bskyblock.api.commands.CompositeCommand;
|
|||||||
|
|
||||||
public final class CommandsManager {
|
public final class CommandsManager {
|
||||||
|
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
private HashMap<String, CompositeCommand> commands = new HashMap<>();
|
private HashMap<String, CompositeCommand> commands = new HashMap<>();
|
||||||
|
|
||||||
public void registerCommand(CompositeCommand command) {
|
public void registerCommand(CompositeCommand command) {
|
||||||
if (DEBUG) {
|
|
||||||
Bukkit.getLogger().info("DEBUG: registering command - " + command.getLabel());
|
|
||||||
}
|
|
||||||
commands.put(command.getLabel(), command);
|
commands.put(command.getLabel(), command);
|
||||||
// Use reflection to obtain the commandMap method in Bukkit's server. It used to be visible, but isn't anymore.
|
// Use reflection to obtain the commandMap method in Bukkit's server. It used to be visible, but isn't anymore.
|
||||||
try{
|
try{
|
||||||
|
@ -20,7 +20,6 @@ public class LocalesManager {
|
|||||||
private BSkyBlock plugin;
|
private BSkyBlock plugin;
|
||||||
private HashMap<Locale, BSBLocale> languages = new HashMap<>();
|
private HashMap<Locale, BSBLocale> languages = new HashMap<>();
|
||||||
private static final String LOCALE_FOLDER = "locales";
|
private static final String LOCALE_FOLDER = "locales";
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
|
|
||||||
public LocalesManager(BSkyBlock plugin) {
|
public LocalesManager(BSkyBlock plugin) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
@ -51,26 +50,17 @@ public class LocalesManager {
|
|||||||
* TODO: Make more robust. The file filter is fragile.
|
* TODO: Make more robust. The file filter is fragile.
|
||||||
*/
|
*/
|
||||||
public void loadLocales(String parent) {
|
public void loadLocales(String parent) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: loading locale for " + parent);
|
|
||||||
}
|
|
||||||
// Describe the filter - we only want files that are correctly named
|
// Describe the filter - we only want files that are correctly named
|
||||||
FilenameFilter ymlFilter = (dir, name) -> {
|
FilenameFilter ymlFilter = (dir, name) -> {
|
||||||
// Files must be 9 chars long
|
// Files must be 9 chars long
|
||||||
if (name.toLowerCase().endsWith(".yml") && name.length() == 9) {
|
if (name.toLowerCase().endsWith(".yml") && name.length() == 9) {
|
||||||
if (DEBUG) {
|
return true;
|
||||||
plugin.getLogger().info("DEBUG: bsb locale filename = " + name);
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Run through the files and store the locales
|
// Run through the files and store the locales
|
||||||
File localeDir = new File(plugin.getDataFolder(), LOCALE_FOLDER + File.separator + parent);
|
File localeDir = new File(plugin.getDataFolder(), LOCALE_FOLDER + File.separator + parent);
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: localeDir = " + localeDir.getAbsolutePath());
|
|
||||||
}
|
|
||||||
// If the folder does not exist, then make it and fill with the locale files from the jar
|
// If the folder does not exist, then make it and fill with the locale files from the jar
|
||||||
// If it does exist, then new files will NOT be written!
|
// If it does exist, then new files will NOT be written!
|
||||||
if (!localeDir.exists()) {
|
if (!localeDir.exists()) {
|
||||||
@ -82,9 +72,6 @@ public class LocalesManager {
|
|||||||
// Get the last part of the name
|
// Get the last part of the name
|
||||||
int lastIndex = name.lastIndexOf('/');
|
int lastIndex = name.lastIndexOf('/');
|
||||||
File targetFile = new File(localeDir, name.substring(lastIndex >= 0 ? lastIndex : 0, name.length()));
|
File targetFile = new File(localeDir, name.substring(lastIndex >= 0 ? lastIndex : 0, name.length()));
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: targetFile = " + targetFile.getAbsolutePath());
|
|
||||||
}
|
|
||||||
copyFile(name, targetFile);
|
copyFile(name, targetFile);
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
@ -95,23 +82,11 @@ public class LocalesManager {
|
|||||||
|
|
||||||
// Store all the locales available
|
// Store all the locales available
|
||||||
for (File language : localeDir.listFiles(ymlFilter)) {
|
for (File language : localeDir.listFiles(ymlFilter)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: parent = " + parent + " language = " + language.getName().substring(0, language.getName().length() - 4));
|
|
||||||
}
|
|
||||||
Locale localeObject = Locale.forLanguageTag(language.getName().substring(0, language.getName().length() - 4));
|
Locale localeObject = Locale.forLanguageTag(language.getName().substring(0, language.getName().length() - 4));
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: locale country found = " + localeObject.getCountry());
|
|
||||||
}
|
|
||||||
if (languages.containsKey(localeObject)) {
|
if (languages.containsKey(localeObject)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: this locale is known");
|
|
||||||
}
|
|
||||||
// Merge into current language
|
// Merge into current language
|
||||||
languages.get(localeObject).merge(language);
|
languages.get(localeObject).merge(language);
|
||||||
} else {
|
} else {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: this locale is not known - new language");
|
|
||||||
}
|
|
||||||
// New language
|
// New language
|
||||||
languages.put(localeObject, new BSBLocale(localeObject, language));
|
languages.put(localeObject, new BSBLocale(localeObject, language));
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,6 @@ import us.tastybento.bskyblock.database.objects.Players;
|
|||||||
|
|
||||||
public class PlayersManager{
|
public class PlayersManager{
|
||||||
|
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
private BSkyBlock plugin;
|
private BSkyBlock plugin;
|
||||||
private BSBDatabase<Players> handler;
|
private BSBDatabase<Players> handler;
|
||||||
|
|
||||||
@ -51,13 +50,7 @@ public class PlayersManager{
|
|||||||
public void load(){
|
public void load(){
|
||||||
playerCache.clear();
|
playerCache.clear();
|
||||||
inTeleport.clear();
|
inTeleport.clear();
|
||||||
try {
|
handler.loadObjects().forEach(p -> playerCache.put(p.getPlayerUUID(), p));
|
||||||
for (Players player : handler.loadObjects()) {
|
|
||||||
playerCache.put(player.getPlayerUUID(), player);
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
plugin.getLogger().severe("Could not load players from the database!" + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -65,35 +58,12 @@ public class PlayersManager{
|
|||||||
* @param async - if true, save async
|
* @param async - if true, save async
|
||||||
*/
|
*/
|
||||||
public void save(boolean async){
|
public void save(boolean async){
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: saving " + async);
|
|
||||||
}
|
|
||||||
Collection<Players> set = Collections.unmodifiableCollection(playerCache.values());
|
Collection<Players> set = Collections.unmodifiableCollection(playerCache.values());
|
||||||
if(async){
|
if(async) {
|
||||||
Runnable save = () -> {
|
Runnable save = () -> set.forEach(handler::saveObject);
|
||||||
for(Players player : set){
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: saving player " + player.getPlayerName() + " "+ player.getUniqueId());
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
handler.saveObject(player);
|
|
||||||
} catch (Exception e) {
|
|
||||||
plugin.getLogger().severe("Could not save player " + player.getPlayerName() + " "+ player.getUniqueId() + " " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
plugin.getServer().getScheduler().runTaskAsynchronously(plugin, save);
|
plugin.getServer().getScheduler().runTaskAsynchronously(plugin, save);
|
||||||
} else {
|
} else {
|
||||||
for(Players player : set){
|
set.forEach(handler::saveObject);
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: saving player " + player.getPlayerName() + " "+ player.getUniqueId());
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
handler.saveObject(player);
|
|
||||||
} catch (Exception e) {
|
|
||||||
plugin.getLogger().severe("Could not save player " + player.getPlayerName() + " "+ player.getUniqueId() + " " + e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -122,37 +92,16 @@ public class PlayersManager{
|
|||||||
if (playerUUID == null) {
|
if (playerUUID == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: adding player " + playerUUID);
|
|
||||||
}
|
|
||||||
if (!playerCache.containsKey(playerUUID)) {
|
if (!playerCache.containsKey(playerUUID)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: player not in cache");
|
|
||||||
}
|
|
||||||
Players player = null;
|
Players player = null;
|
||||||
// If the player is in the database, load it, otherwise create a new player
|
// If the player is in the database, load it, otherwise create a new player
|
||||||
if (handler.objectExists(playerUUID.toString())) {
|
if (handler.objectExists(playerUUID.toString())) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: player in database");
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
player = handler.loadObject(playerUUID.toString());
|
player = handler.loadObject(playerUUID.toString());
|
||||||
} catch (Exception e) {
|
|
||||||
plugin.getLogger().severe("Could not load player " + playerUUID + " " + e.getMessage());
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: new player");
|
|
||||||
}
|
|
||||||
player = new Players(plugin, playerUUID);
|
player = new Players(plugin, playerUUID);
|
||||||
}
|
}
|
||||||
playerCache.put(playerUUID, player);
|
playerCache.put(playerUUID, player);
|
||||||
return;
|
return;
|
||||||
} else {
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: known player");
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,9 +120,7 @@ public class PlayersManager{
|
|||||||
* Saves all players on the server and clears the cache
|
* Saves all players on the server and clears the cache
|
||||||
*/
|
*/
|
||||||
public void removeAllPlayers() {
|
public void removeAllPlayers() {
|
||||||
for (UUID pl : playerCache.keySet()) {
|
playerCache.keySet().forEach(this::save);
|
||||||
save(pl);
|
|
||||||
}
|
|
||||||
playerCache.clear();
|
playerCache.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -244,7 +191,6 @@ public class PlayersManager{
|
|||||||
public void setHomeLocation(UUID playerUUID, Location location, int number) {
|
public void setHomeLocation(UUID playerUUID, Location location, int number) {
|
||||||
addPlayer(playerUUID);
|
addPlayer(playerUUID);
|
||||||
playerCache.get(playerUUID).setHomeLocation(location,number);
|
playerCache.get(playerUUID).setHomeLocation(location,number);
|
||||||
//this.save(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -255,7 +201,6 @@ public class PlayersManager{
|
|||||||
public void setHomeLocation(UUID playerUUID, Location location) {
|
public void setHomeLocation(UUID playerUUID, Location location) {
|
||||||
addPlayer(playerUUID);
|
addPlayer(playerUUID);
|
||||||
playerCache.get(playerUUID).setHomeLocation(location,1);
|
playerCache.get(playerUUID).setHomeLocation(location,1);
|
||||||
//this.save(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -319,9 +264,6 @@ public class PlayersManager{
|
|||||||
* @param user - the User
|
* @param user - the User
|
||||||
*/
|
*/
|
||||||
public void setPlayerName(User user) {
|
public void setPlayerName(User user) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: Setting player name to " + user.getName() + " for " + user.getUniqueId());
|
|
||||||
}
|
|
||||||
addPlayer(user.getUniqueId());
|
addPlayer(user.getUniqueId());
|
||||||
playerCache.get(user.getUniqueId()).setPlayerName(user.getName());
|
playerCache.get(user.getUniqueId()).setPlayerName(user.getName());
|
||||||
}
|
}
|
||||||
@ -334,16 +276,10 @@ public class PlayersManager{
|
|||||||
* @return String - playerName
|
* @return String - playerName
|
||||||
*/
|
*/
|
||||||
public String getName(UUID playerUUID) {
|
public String getName(UUID playerUUID) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: Geting player name");
|
|
||||||
}
|
|
||||||
if (playerUUID == null) {
|
if (playerUUID == null) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
addPlayer(playerUUID);
|
addPlayer(playerUUID);
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: name is " + playerCache.get(playerUUID).getPlayerName());
|
|
||||||
}
|
|
||||||
return playerCache.get(playerUUID).getPlayerName();
|
return playerCache.get(playerUUID).getPlayerName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,8 +21,6 @@ import us.tastybento.bskyblock.database.objects.Island;
|
|||||||
import us.tastybento.bskyblock.util.Util;
|
import us.tastybento.bskyblock.util.Util;
|
||||||
|
|
||||||
public class IslandCache {
|
public class IslandCache {
|
||||||
private static final boolean DEBUG2 = false;
|
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
private BSkyBlock plugin = BSkyBlock.getInstance();
|
private BSkyBlock plugin = BSkyBlock.getInstance();
|
||||||
private BiMap<Location, Island> islandsByLocation;
|
private BiMap<Location, Island> islandsByLocation;
|
||||||
/**
|
/**
|
||||||
@ -43,17 +41,8 @@ public class IslandCache {
|
|||||||
*/
|
*/
|
||||||
public void addIsland(Island island) {
|
public void addIsland(Island island) {
|
||||||
islandsByLocation.put(island.getCenter(), island);
|
islandsByLocation.put(island.getCenter(), island);
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: owner = " + island.getOwner());
|
|
||||||
}
|
|
||||||
islandsByUUID.put(island.getOwner(), island);
|
islandsByUUID.put(island.getOwner(), island);
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: island has " + island.getMemberSet().size() + " members");
|
|
||||||
}
|
|
||||||
for (UUID member: island.getMemberSet()) {
|
for (UUID member: island.getMemberSet()) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: " + member);
|
|
||||||
}
|
|
||||||
islandsByUUID.put(member, island);
|
islandsByUUID.put(member, island);
|
||||||
}
|
}
|
||||||
addToGrid(island);
|
addToGrid(island);
|
||||||
@ -69,14 +58,8 @@ public class IslandCache {
|
|||||||
*/
|
*/
|
||||||
private void addToGrid(Island newIsland) {
|
private void addToGrid(Island newIsland) {
|
||||||
if (islandGrid.containsKey(newIsland.getMinX())) {
|
if (islandGrid.containsKey(newIsland.getMinX())) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: min x is in the grid :" + newIsland.getMinX());
|
|
||||||
}
|
|
||||||
TreeMap<Integer, Island> zEntry = islandGrid.get(newIsland.getMinX());
|
TreeMap<Integer, Island> zEntry = islandGrid.get(newIsland.getMinX());
|
||||||
if (zEntry.containsKey(newIsland.getMinZ())) {
|
if (zEntry.containsKey(newIsland.getMinZ())) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: min z is in the grid :" + newIsland.getMinZ());
|
|
||||||
}
|
|
||||||
// Island already exists
|
// Island already exists
|
||||||
Island conflict = islandGrid.get(newIsland.getMinX()).get(newIsland.getMinZ());
|
Island conflict = islandGrid.get(newIsland.getMinX()).get(newIsland.getMinZ());
|
||||||
plugin.getLogger().warning("*** Duplicate or overlapping islands! ***");
|
plugin.getLogger().warning("*** Duplicate or overlapping islands! ***");
|
||||||
@ -99,18 +82,11 @@ public class IslandCache {
|
|||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
// Add island
|
// Add island
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: added island to grid at " + newIsland.getMinX() + "," + newIsland.getMinZ());
|
|
||||||
}
|
|
||||||
zEntry.put(newIsland.getMinZ(), newIsland);
|
zEntry.put(newIsland.getMinZ(), newIsland);
|
||||||
islandGrid.put(newIsland.getMinX(), zEntry);
|
islandGrid.put(newIsland.getMinX(), zEntry);
|
||||||
// plugin.getLogger().info("Debug: " + newIsland.toString());
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Add island
|
// Add island
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: added island to grid at " + newIsland.getMinX() + "," + newIsland.getMinZ());
|
|
||||||
}
|
|
||||||
TreeMap<Integer, Island> zEntry = new TreeMap<>();
|
TreeMap<Integer, Island> zEntry = new TreeMap<>();
|
||||||
zEntry.put(newIsland.getMinZ(), newIsland);
|
zEntry.put(newIsland.getMinZ(), newIsland);
|
||||||
islandGrid.put(newIsland.getMinX(), zEntry);
|
islandGrid.put(newIsland.getMinX(), zEntry);
|
||||||
@ -145,9 +121,6 @@ public class IslandCache {
|
|||||||
* @param owner - the island owner UUID
|
* @param owner - the island owner UUID
|
||||||
*/
|
*/
|
||||||
public Island createIsland(Location location, UUID owner){
|
public Island createIsland(Location location, UUID owner){
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: adding island for " + owner + " at " + location);
|
|
||||||
}
|
|
||||||
Island island = new Island(location, owner, plugin.getSettings().getIslandProtectionRange());
|
Island island = new Island(location, owner, plugin.getSettings().getIslandProtectionRange());
|
||||||
islandsByLocation.put(location, island);
|
islandsByLocation.put(location, island);
|
||||||
if (owner != null) {
|
if (owner != null) {
|
||||||
@ -173,31 +146,15 @@ public class IslandCache {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Remove from grid
|
// Remove from grid
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: deleting island at " + island.getCenter());
|
|
||||||
}
|
|
||||||
if (island != null) {
|
if (island != null) {
|
||||||
int x = island.getMinX();
|
int x = island.getMinX();
|
||||||
int z = island.getMinZ();
|
int z = island.getMinZ();
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: x = " + x + " z = " + z);
|
|
||||||
}
|
|
||||||
if (islandGrid.containsKey(x)) {
|
if (islandGrid.containsKey(x)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: x found");
|
|
||||||
}
|
|
||||||
TreeMap<Integer, Island> zEntry = islandGrid.get(x);
|
TreeMap<Integer, Island> zEntry = islandGrid.get(x);
|
||||||
if (zEntry.containsKey(z)) {
|
if (zEntry.containsKey(z)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: z found - deleting the island");
|
|
||||||
}
|
|
||||||
// Island exists - delete it
|
// Island exists - delete it
|
||||||
zEntry.remove(z);
|
zEntry.remove(z);
|
||||||
islandGrid.put(x, zEntry);
|
islandGrid.put(x, zEntry);
|
||||||
} else {
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: could not find z");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -229,10 +186,6 @@ public class IslandCache {
|
|||||||
* @return Island or null
|
* @return Island or null
|
||||||
*/
|
*/
|
||||||
public Island getIslandAt(int x, int z) {
|
public Island getIslandAt(int x, int z) {
|
||||||
if (DEBUG2) {
|
|
||||||
plugin.getLogger().info("DEBUG: getting island at " + x + "," + z);
|
|
||||||
plugin.getLogger().info("DEBUG: island grid is " + islandGrid.size());
|
|
||||||
}
|
|
||||||
Entry<Integer, TreeMap<Integer, Island>> en = islandGrid.floorEntry(x);
|
Entry<Integer, TreeMap<Integer, Island>> en = islandGrid.floorEntry(x);
|
||||||
if (en != null) {
|
if (en != null) {
|
||||||
Entry<Integer, Island> ent = en.getValue().floorEntry(z);
|
Entry<Integer, Island> ent = en.getValue().floorEntry(z);
|
||||||
@ -240,14 +193,8 @@ public class IslandCache {
|
|||||||
// Check if in the island range
|
// Check if in the island range
|
||||||
Island island = ent.getValue();
|
Island island = ent.getValue();
|
||||||
if (island.inIslandSpace(x, z)) {
|
if (island.inIslandSpace(x, z)) {
|
||||||
if (DEBUG2) {
|
|
||||||
plugin.getLogger().info("DEBUG: In island space");
|
|
||||||
}
|
|
||||||
return island;
|
return island;
|
||||||
}
|
}
|
||||||
if (DEBUG2) {
|
|
||||||
plugin.getLogger().info("DEBUG: not in island space");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
@ -262,12 +209,10 @@ public class IslandCache {
|
|||||||
*/
|
*/
|
||||||
public Island getIslandAt(Location location) {
|
public Island getIslandAt(Location location) {
|
||||||
if (location == null) {
|
if (location == null) {
|
||||||
//plugin.getLogger().info("DEBUG: location is null");
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
// World check
|
// World check
|
||||||
if (!Util.inWorld(location)) {
|
if (!Util.inWorld(location)) {
|
||||||
//plugin.getLogger().info("DEBUG: not in right world");
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return getIslandAt(location.getBlockX(), location.getBlockZ());
|
return getIslandAt(location.getBlockX(), location.getBlockZ());
|
||||||
@ -327,52 +272,20 @@ public class IslandCache {
|
|||||||
* @return true if player has island and owns it
|
* @return true if player has island and owns it
|
||||||
*/
|
*/
|
||||||
public boolean hasIsland(UUID playerUUID) {
|
public boolean hasIsland(UUID playerUUID) {
|
||||||
if (DEBUG) {
|
return (islandsByUUID.containsKey(playerUUID) && islandsByUUID.get(playerUUID).getOwner() != null
|
||||||
plugin.getLogger().info("DEBUG: checking if " + playerUUID + " has an island");
|
&& (islandsByUUID.get(playerUUID).getOwner().equals(playerUUID))) ? true : false;
|
||||||
plugin.getLogger().info("DEBUG: islandsByUUID : " + islandsByUUID.toString());
|
|
||||||
|
|
||||||
if (!islandsByUUID.containsKey(playerUUID)) {
|
|
||||||
plugin.getLogger().info("DEBUG: player is not in islandsByUUID");
|
|
||||||
} else {
|
|
||||||
plugin.getLogger().info("DEBUG: owner = " + islandsByUUID.get(playerUUID).getOwner());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (islandsByUUID.containsKey(playerUUID) && islandsByUUID.get(playerUUID).getOwner() != null) {
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: checking for equals");
|
|
||||||
}
|
|
||||||
if (islandsByUUID.get(playerUUID).getOwner().equals(playerUUID)) {
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: has island");
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: doesn't have island");
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removePlayer(UUID playerUUID) {
|
public void removePlayer(UUID playerUUID) {
|
||||||
Island island = islandsByUUID.get(playerUUID);
|
Island island = islandsByUUID.get(playerUUID);
|
||||||
if (island != null) {
|
if (island != null) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: island found");
|
|
||||||
}
|
|
||||||
if (island.getOwner() != null && island.getOwner().equals(playerUUID)) {
|
if (island.getOwner() != null && island.getOwner().equals(playerUUID)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: player is the owner of this island");
|
|
||||||
}
|
|
||||||
// Clear ownership and members
|
// Clear ownership and members
|
||||||
island.getMembers().clear();
|
island.getMembers().clear();
|
||||||
island.setOwner(null);
|
island.setOwner(null);
|
||||||
}
|
}
|
||||||
island.removeMember(playerUUID);
|
island.removeMember(playerUUID);
|
||||||
}
|
}
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: removing reference to island by UUID");
|
|
||||||
}
|
|
||||||
islandsByUUID.remove(playerUUID);
|
islandsByUUID.remove(playerUUID);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,6 @@ import us.tastybento.bskyblock.island.builders.IslandBuilder.IslandType;
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class NewIsland {
|
public class NewIsland {
|
||||||
private static final boolean DEBUG = false;
|
|
||||||
private BSkyBlock plugin;
|
private BSkyBlock plugin;
|
||||||
private Island island;
|
private Island island;
|
||||||
private final Player player;
|
private final Player player;
|
||||||
@ -92,51 +91,25 @@ public class NewIsland {
|
|||||||
* Makes an island.
|
* Makes an island.
|
||||||
*/
|
*/
|
||||||
public void newIsland() {
|
public void newIsland() {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: new island");
|
|
||||||
}
|
|
||||||
//long time = System.nanoTime();
|
|
||||||
final UUID playerUUID = player.getUniqueId();
|
final UUID playerUUID = player.getUniqueId();
|
||||||
/*
|
|
||||||
boolean firstTime = false;
|
|
||||||
if (!plugin.getPlayers().hasIsland(playerUUID)) {
|
|
||||||
firstTime = true;
|
|
||||||
}*/
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: finding island location");
|
|
||||||
}
|
|
||||||
Location next = getNextIsland();
|
Location next = getNextIsland();
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: found " + next);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add to the grid
|
// Add to the grid
|
||||||
island = plugin.getIslands().createIsland(next, playerUUID);
|
island = plugin.getIslands().createIsland(next, playerUUID);
|
||||||
// Save the player so that if the server is reset weird things won't happen
|
// Save the player so that if the server is reset weird things won't happen
|
||||||
//plugin.getPlayers().save(true);
|
|
||||||
//plugin.getIslands().save(true);
|
|
||||||
|
|
||||||
// Clear any old home locations (they should be clear, but just in case)
|
// Clear any old home locations (they should be clear, but just in case)
|
||||||
plugin.getPlayers().clearHomeLocations(playerUUID);
|
plugin.getPlayers().clearHomeLocations(playerUUID);
|
||||||
|
|
||||||
// Set the biome
|
|
||||||
//BiomesPanel.setIslandBiome(next, schematic.getBiome());
|
|
||||||
// Set home loction
|
// Set home loction
|
||||||
plugin.getPlayers().setHomeLocation(playerUUID, next, 1);
|
plugin.getPlayers().setHomeLocation(playerUUID, next, 1);
|
||||||
|
|
||||||
// Fire event
|
// Fire event
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: firing event");
|
|
||||||
}
|
|
||||||
IslandBaseEvent event = IslandEvent.builder()
|
IslandBaseEvent event = IslandEvent.builder()
|
||||||
.involvedPlayer(player.getUniqueId())
|
.involvedPlayer(player.getUniqueId())
|
||||||
.reason(reason)
|
.reason(reason)
|
||||||
.island(island)
|
.island(island)
|
||||||
.location(island.getCenter())
|
.location(island.getCenter())
|
||||||
.build();
|
.build();
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: event cancelled status = " + event.isCancelled());
|
|
||||||
}
|
|
||||||
if (!event.isCancelled()) {
|
if (!event.isCancelled()) {
|
||||||
// Create island
|
// Create island
|
||||||
new IslandBuilder(plugin, island)
|
new IslandBuilder(plugin, island)
|
||||||
@ -187,31 +160,16 @@ public class NewIsland {
|
|||||||
*/
|
*/
|
||||||
private Location getNextIsland() {
|
private Location getNextIsland() {
|
||||||
Location last = plugin.getIslands().getLast();
|
Location last = plugin.getIslands().getLast();
|
||||||
|
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: last = " + last);
|
|
||||||
// Find the next free spot
|
|
||||||
}
|
|
||||||
|
|
||||||
if (last == null) {
|
if (last == null) {
|
||||||
last = new Location(plugin.getIslandWorldManager().getIslandWorld(), plugin.getSettings().getIslandXOffset() + plugin.getSettings().getIslandStartX(),
|
last = new Location(plugin.getIslandWorldManager().getIslandWorld(), plugin.getSettings().getIslandXOffset() + plugin.getSettings().getIslandStartX(),
|
||||||
plugin.getSettings().getIslandHeight(), plugin.getSettings().getIslandZOffset() + plugin.getSettings().getIslandStartZ());
|
plugin.getSettings().getIslandHeight(), plugin.getSettings().getIslandZOffset() + plugin.getSettings().getIslandStartZ());
|
||||||
}
|
}
|
||||||
Location next = last.clone();
|
Location next = last.clone();
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: last 2 = " + last);
|
|
||||||
}
|
|
||||||
while (plugin.getIslands().isIsland(next)) {
|
while (plugin.getIslands().isIsland(next)) {
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: getting next loc");
|
|
||||||
}
|
|
||||||
next = nextGridLocation(next);
|
next = nextGridLocation(next);
|
||||||
}
|
}
|
||||||
// Make the last next, last
|
// Make the last next, last
|
||||||
last = next.clone();
|
last = next.clone();
|
||||||
if (DEBUG) {
|
|
||||||
plugin.getLogger().info("DEBUG: last 3 = " + last);
|
|
||||||
}
|
|
||||||
return next;
|
return next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,7 +24,6 @@ public class DeleteIslandChunks {
|
|||||||
* @param island
|
* @param island
|
||||||
*/
|
*/
|
||||||
public DeleteIslandChunks(final BSkyBlock plugin, final Island island) {
|
public DeleteIslandChunks(final BSkyBlock plugin, final Island island) {
|
||||||
//plugin.getLogger().info("DEBUG: deleting the island");
|
|
||||||
// Fire event
|
// Fire event
|
||||||
IslandBaseEvent event = IslandEvent.builder().island(island).reason(Reason.DELETE).build();
|
IslandBaseEvent event = IslandEvent.builder().island(island).reason(Reason.DELETE).build();
|
||||||
if (event.isCancelled()) {
|
if (event.isCancelled()) {
|
||||||
|
@ -74,7 +74,6 @@ public class FileLister{
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//plugin.getLogger().info("DEBUG: jar filename = " + entry.getName());
|
|
||||||
if (entry.getName().endsWith(".yml")) {
|
if (entry.getName().endsWith(".yml")) {
|
||||||
result.add(entry.getName());
|
result.add(entry.getName());
|
||||||
}
|
}
|
||||||
@ -119,7 +118,6 @@ public class FileLister{
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//plugin.getLogger().info("DEBUG: jar filename = " + entry.getName());
|
|
||||||
if (entry.getName().endsWith(".yml")) {
|
if (entry.getName().endsWith(".yml")) {
|
||||||
result.add(entry.getName());
|
result.add(entry.getName());
|
||||||
}
|
}
|
||||||
|
@ -66,7 +66,6 @@ public class HeadGetter {
|
|||||||
requester.setHead(panelItem);
|
requester.setHead(panelItem);
|
||||||
} else {
|
} else {
|
||||||
// Get the name
|
// Get the name
|
||||||
//Bukkit.getLogger().info("DEBUG:Not in cache. Adding");
|
|
||||||
headRequesters.putIfAbsent(panelItem.getName(), new HashSet<>());
|
headRequesters.putIfAbsent(panelItem.getName(), new HashSet<>());
|
||||||
Set<HeadRequester> requesters = headRequesters.get(panelItem.getName());
|
Set<HeadRequester> requesters = headRequesters.get(panelItem.getName());
|
||||||
requesters.add(requester);
|
requesters.add(requester);
|
||||||
|
Loading…
Reference in New Issue
Block a user