summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java242
-rw-r--r--Essentials/src/com/earth2me/essentials/EssentialsPlayerListener.java32
2 files changed, 179 insertions, 95 deletions
diff --git a/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java b/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java
index d6ed3e3f0..0189c72a7 100644
--- a/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java
+++ b/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java
@@ -35,8 +35,14 @@ public class EssentialsBlockListener extends BlockListener
@Override
public void onBlockBreak(BlockBreakEvent event)
{
- if (event.isCancelled()) return;
- if (ess.getSettings().areSignsDisabled()) return;
+ if (event.isCancelled())
+ {
+ return;
+ }
+ if (ess.getSettings().areSignsDisabled())
+ {
+ return;
+ }
User user = ess.getUser(event.getPlayer());
if (protectedBlocks.contains(event.getBlock().getType()) && !user.isAuthorized("essentials.signs.protection.override"))
{
@@ -48,8 +54,8 @@ public class EssentialsBlockListener extends BlockListener
}
}
- if (checkProtectionSign(event.getBlock(), user) != NOSIGN &&
- checkProtectionSign(event.getBlock(), user) != OWNER)
+ if (checkProtectionSign(event.getBlock(), user) != NOSIGN
+ && checkProtectionSign(event.getBlock(), user) != OWNER)
{
event.setCancelled(true);
user.sendMessage(Util.format("noDestroyPermission", event.getBlock().getType().toString().toLowerCase()));
@@ -59,8 +65,14 @@ public class EssentialsBlockListener extends BlockListener
@Override
public void onSignChange(SignChangeEvent event)
{
- if (event.isCancelled()) return;
- if (ess.getSettings().areSignsDisabled()) return;
+ if (event.isCancelled())
+ {
+ return;
+ }
+ if (ess.getSettings().areSignsDisabled())
+ {
+ return;
+ }
User user = ess.getUser(event.getPlayer());
String username = user.getName().substring(0, user.getName().length() > 14 ? 14 : user.getName().length());
@@ -70,18 +82,26 @@ public class EssentialsBlockListener extends BlockListener
{
Block block = event.getBlock();
if (user.isAuthorized("essentials.signs.protection.create") && hasAdjacentChest(block) && !isBlockProtected(block, user))
+ {
event.setLine(0, "§1[Protection]");
+ }
else
+ {
event.setLine(0, "§4[Protection]");
+ }
event.setLine(3, username);
return;
}
if (event.getLine(0).equalsIgnoreCase("[Disposal]"))
{
if (user.isAuthorized("essentials.signs.disposal.create"))
+ {
event.setLine(0, "§1[Disposal]");
+ }
else
+ {
event.setLine(0, "§4[Disposal]");
+ }
return;
}
if (event.getLine(0).equalsIgnoreCase("[Heal]"))
@@ -94,8 +114,14 @@ public class EssentialsBlockListener extends BlockListener
String[] l1 = event.getLine(1).split("[ :-]+", 2);
boolean m1 = l1[0].matches("^[^0-9][\\.0-9]+");
double q1 = Double.parseDouble(m1 ? l1[0].substring(1) : l1[0]);
- if (q1 < 1 || (!m1 && (int)q1 < 1)) throw new Exception(Util.i18n("moreThanZero"));
- if (!m1) ItemDb.get(l1[1]);
+ if (q1 < 1 || (!m1 && (int)q1 < 1))
+ {
+ throw new Exception(Util.i18n("moreThanZero"));
+ }
+ if (!m1)
+ {
+ ItemDb.get(l1[1]);
+ }
event.setLine(1, (m1 ? Util.formatCurrency(q1) : (int)q1 + " " + l1[1]));
}
event.setLine(0, "§1[Heal]");
@@ -107,29 +133,40 @@ public class EssentialsBlockListener extends BlockListener
event.setLine(0, "§4[Free]");
ItemDb.get(event.getLine(1));
if (user.isAuthorized("essentials.signs.free.create"))
+ {
event.setLine(0, "§1[Free]");
+ }
return;
}
if (event.getLine(0).equalsIgnoreCase("[Mail]"))
{
if (user.isAuthorized("essentials.signs.mail.create"))
+ {
event.setLine(0, "§1[Mail]");
+ }
else
+ {
event.setLine(0, "§4[Mail]");
+ }
return;
}
if (event.getLine(0).equalsIgnoreCase("[Balance]"))
{
if (user.isAuthorized("essentials.signs.balance.create"))
+ {
event.setLine(0, "§1[Balance]");
+ }
else
+ {
event.setLine(0, "§4[Balance]");
+ }
return;
}
- if (event.getLine(0).equalsIgnoreCase("[Warp]"))
+ if (event.getLine(0).equalsIgnoreCase("[Warp]"))
{
event.setLine(0, "§4[Warp]");
- if (user.isAuthorized("essentials.signs.warp.create")) {
+ if (user.isAuthorized("essentials.signs.warp.create"))
+ {
if (!event.getLine(3).isEmpty())
{
String[] l1 = event.getLine(3).split("[ :-]+", 2);
@@ -139,29 +176,45 @@ public class EssentialsBlockListener extends BlockListener
throw new Exception(Util.format("invalidSignLine", 4));
}
double q1 = Double.parseDouble(m1 ? l1[0].substring(1) : l1[0]);
- if ((int)q1 < 1) throw new Exception(Util.i18n("moreThanZero"));
- if (!m1) ItemDb.get(l1[1]);
+ if ((int)q1 < 1)
+ {
+ throw new Exception(Util.i18n("moreThanZero"));
+ }
+ if (!m1)
+ {
+ ItemDb.get(l1[1]);
+ }
event.setLine(3, (m1 ? Util.formatCurrency(q1) : (int)q1 + " " + l1[1]));
}
- if (event.getLine(1).isEmpty()) {
+ if (event.getLine(1).isEmpty())
+ {
event.setLine(1, "§dWarp name!");
return;
- } else {
+ }
+ else
+ {
ess.getWarps().getWarp(event.getLine(1));
- if (event.getLine(2).equalsIgnoreCase("Everyone")) {
+ if (event.getLine(2).equalsIgnoreCase("Everyone"))
+ {
event.setLine(2, "§2Everyone");
}
- event.setLine(0, "§1[Warp]");
+ event.setLine(0, "§1[Warp]");
}
}
return;
}
if (event.getLine(0).equalsIgnoreCase("[Time]"))
{
- if (user.isAuthorized("essentials.signs.time.create"))
+ if (user.isAuthorized("essentials.signs.time.create")
+ && (event.getLine(1).equalsIgnoreCase("day")
+ || event.getLine(1).equalsIgnoreCase("night")))
+ {
event.setLine(0, "§1[Time]");
+ }
else
+ {
event.setLine(0, "§4[Time]");
+ }
return;
}
}
@@ -178,7 +231,10 @@ public class EssentialsBlockListener extends BlockListener
@Override
public void onBlockPlace(BlockPlaceEvent event)
{
- if (event.isCancelled()) return;
+ if (event.isCancelled())
+ {
+ return;
+ }
Block signBlock = event.getBlockAgainst();
if (signBlock.getType() == Material.WALL_SIGN || signBlock.getType() == Material.SIGN_POST)
{
@@ -193,75 +249,78 @@ public class EssentialsBlockListener extends BlockListener
// Do not rely on getItemInHand();
// http://leaky.bukkit.org/issues/663
final ItemStack is = new ItemStack(event.getBlockPlaced().getType(), 1, (short)0, event.getBlockPlaced().getData());
- switch(is.getType()) {
- case WOODEN_DOOR:
- is.setType(Material.WOOD_DOOR);
- is.setDurability((short)0);
- break;
- case IRON_DOOR_BLOCK:
- is.setType(Material.IRON_DOOR);
- is.setDurability((short)0);
- break;
- case SIGN_POST:
- case WALL_SIGN:
- is.setType(Material.SIGN);
- is.setDurability((short)0);
- break;
- case CROPS:
- is.setType(Material.SEEDS);
- is.setDurability((short)0);
- break;
- case CAKE_BLOCK:
- is.setType(Material.CAKE);
- is.setDurability((short)0);
- break;
- case BED_BLOCK:
- is.setType(Material.BED);
- is.setDurability((short)0);
- break;
- case REDSTONE_WIRE:
- is.setType(Material.REDSTONE);
- is.setDurability((short)0);
- break;
- case REDSTONE_TORCH_OFF:
- case REDSTONE_TORCH_ON:
- is.setType(Material.REDSTONE_TORCH_ON);
- is.setDurability((short)0);
- break;
- case DIODE_BLOCK_OFF:
- case DIODE_BLOCK_ON:
- is.setType(Material.DIODE);
- is.setDurability((short)0);
- break;
- case DOUBLE_STEP:
- is.setType(Material.STEP);
- break;
- case TORCH:
- case RAILS:
- case LADDER:
- case WOOD_STAIRS:
- case COBBLESTONE_STAIRS:
- case LEVER:
- case STONE_BUTTON:
- case FURNACE:
- case DISPENSER:
- case PUMPKIN:
- case JACK_O_LANTERN:
- case WOOD_PLATE:
- case STONE_PLATE:
- is.setDurability((short)0);
- break;
+ switch (is.getType())
+ {
+ case WOODEN_DOOR:
+ is.setType(Material.WOOD_DOOR);
+ is.setDurability((short)0);
+ break;
+ case IRON_DOOR_BLOCK:
+ is.setType(Material.IRON_DOOR);
+ is.setDurability((short)0);
+ break;
+ case SIGN_POST:
+ case WALL_SIGN:
+ is.setType(Material.SIGN);
+ is.setDurability((short)0);
+ break;
+ case CROPS:
+ is.setType(Material.SEEDS);
+ is.setDurability((short)0);
+ break;
+ case CAKE_BLOCK:
+ is.setType(Material.CAKE);
+ is.setDurability((short)0);
+ break;
+ case BED_BLOCK:
+ is.setType(Material.BED);
+ is.setDurability((short)0);
+ break;
+ case REDSTONE_WIRE:
+ is.setType(Material.REDSTONE);
+ is.setDurability((short)0);
+ break;
+ case REDSTONE_TORCH_OFF:
+ case REDSTONE_TORCH_ON:
+ is.setType(Material.REDSTONE_TORCH_ON);
+ is.setDurability((short)0);
+ break;
+ case DIODE_BLOCK_OFF:
+ case DIODE_BLOCK_ON:
+ is.setType(Material.DIODE);
+ is.setDurability((short)0);
+ break;
+ case DOUBLE_STEP:
+ is.setType(Material.STEP);
+ break;
+ case TORCH:
+ case RAILS:
+ case LADDER:
+ case WOOD_STAIRS:
+ case COBBLESTONE_STAIRS:
+ case LEVER:
+ case STONE_BUTTON:
+ case FURNACE:
+ case DISPENSER:
+ case PUMPKIN:
+ case JACK_O_LANTERN:
+ case WOOD_PLATE:
+ case STONE_PLATE:
+ is.setDurability((short)0);
+ break;
}
boolean unlimitedForUser = user.hasUnlimited(is);
- if (unlimitedForUser) {
+ if (unlimitedForUser)
+ {
ess.scheduleSyncDelayedTask(
- new Runnable() {
-
- public void run() {
- user.getInventory().addItem(is);
- user.updateInventory();
- }
- });
+ new Runnable()
+ {
+ public void run()
+ {
+ user.getInventory().addItem(is);
+ user.updateInventory();
+ }
+ });
}
}
@@ -290,14 +349,19 @@ public class EssentialsBlockListener extends BlockListener
Sign sign = new CraftSign(block);
if (sign.getLine(0).equalsIgnoreCase("§1[Protection]") && !user.isAuthorized("essentials.signs.protection.override"))
{
- for (int i = 1; i <= 2; i++) {
+ for (int i = 1; i <= 2; i++)
+ {
String line = sign.getLine(i);
- if (line.startsWith("(") && line.endsWith(")")) {
+ if (line.startsWith("(") && line.endsWith(")"))
+ {
line = line.substring(1, line.length() - 1);
- if (user.inGroup(line)) {
+ if (user.inGroup(line))
+ {
return ALLOWED;
}
- } else if (line.equalsIgnoreCase(username)) {
+ }
+ else if (line.equalsIgnoreCase(username))
+ {
return ALLOWED;
}
}
@@ -360,7 +424,7 @@ public class EssentialsBlockListener extends BlockListener
}
return protect;
}
-
+
public static boolean isBlockProtected(Block block)
{
Block[] faces = getAdjacentBlocks(block);
diff --git a/Essentials/src/com/earth2me/essentials/EssentialsPlayerListener.java b/Essentials/src/com/earth2me/essentials/EssentialsPlayerListener.java
index 81e24311d..bc63eff52 100644
--- a/Essentials/src/com/earth2me/essentials/EssentialsPlayerListener.java
+++ b/Essentials/src/com/earth2me/essentials/EssentialsPlayerListener.java
@@ -52,7 +52,8 @@ public class EssentialsPlayerListener extends PlayerListener
User user = ess.getUser(event.getPlayer());
user.setDisplayName(user.getNick());
updateCompass(user);
- if (user.isJailed() && user.getJail() != null && !user.getJail().isEmpty()) {
+ if (user.isJailed() && user.getJail() != null && !user.getJail().isEmpty())
+ {
try
{
event.setRespawnLocation(ess.getJail().getJail(user.getJail()));
@@ -109,15 +110,18 @@ public class EssentialsPlayerListener extends PlayerListener
Location loc = event.getTo();
World nether = server.getWorld(ess.getSettings().getNetherName());
- if (nether == null) {
+ if (nether == null)
+ {
for (World world : worlds)
{
- if (world.getEnvironment() == World.Environment.NETHER) {
+ if (world.getEnvironment() == World.Environment.NETHER)
+ {
nether = world;
break;
}
}
- if (nether == null) {
+ if (nether == null)
+ {
return;
}
}
@@ -465,7 +469,7 @@ public class EssentialsPlayerListener extends PlayerListener
}
if (sign.getLine(0).equals("§1[Warp]"))
{
-
+
if (!sign.getLine(2).isEmpty())
{
if (sign.getLine(2).equals("§2Everyone"))
@@ -489,6 +493,22 @@ public class EssentialsPlayerListener extends PlayerListener
}
return;
}
+ if (sign.getLine(0).equals("§1[Time]") && user.isAuthorized("essentials.signs.time.use"))
+ {
+ long time = user.getWorld().getTime();
+ time -= time % 24000;
+ if ("day".equalsIgnoreCase(sign.getLine(1)))
+ {
+ user.getWorld().setTime(time + 24000);
+ return;
+ }
+ if ("night".equalsIgnoreCase(sign.getLine(1)))
+ {
+ user.getWorld().setTime(time + 37700);
+ return;
+ }
+ throw new Exception(Util.i18n("onlyDayNight"));
+ }
}
catch (Throwable ex)
{
@@ -499,7 +519,7 @@ public class EssentialsPlayerListener extends PlayerListener
}
}
}
-
+
private Charge chargeUserForWarp(Sign sign, User user) throws Exception
{
if (!sign.getLine(3).isEmpty())