summaryrefslogtreecommitdiffstats
path: root/EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java
diff options
context:
space:
mode:
authorsnowleo <schneeleo@gmail.com>2011-12-14 16:04:15 +0100
committersnowleo <schneeleo@gmail.com>2011-12-14 16:04:15 +0100
commit0f1eb9b4f910b4f61f4c89fbad14b6485c372756 (patch)
tree62257261b99340c51a36b9dbdc97d72ec226a01f /EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java
parent503e837cfdf1eaf0a4ae8b04199fc1c60dd82923 (diff)
downloadEssentials-0f1eb9b4f910b4f61f4c89fbad14b6485c372756.tar
Essentials-0f1eb9b4f910b4f61f4c89fbad14b6485c372756.tar.gz
Essentials-0f1eb9b4f910b4f61f4c89fbad14b6485c372756.tar.lz
Essentials-0f1eb9b4f910b4f61f4c89fbad14b6485c372756.tar.xz
Essentials-0f1eb9b4f910b4f61f4c89fbad14b6485c372756.zip
Moved signs code to a new module
Diffstat (limited to 'EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java')
-rw-r--r--EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java73
1 files changed, 73 insertions, 0 deletions
diff --git a/EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java b/EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java
new file mode 100644
index 000000000..12a2fc2f8
--- /dev/null
+++ b/EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java
@@ -0,0 +1,73 @@
+package com.earth2me.essentials.signs;
+
+import com.earth2me.essentials.api.IEssentials;
+import org.bukkit.Material;
+import org.bukkit.block.Block;
+import org.bukkit.event.entity.EndermanPickupEvent;
+import org.bukkit.event.entity.EntityExplodeEvent;
+import org.bukkit.event.entity.EntityListener;
+
+
+public class SignEntityListener extends EntityListener
+{
+ private final transient IEssentials ess;
+
+ public SignEntityListener(final IEssentials ess)
+ {
+ this.ess = ess;
+ }
+
+ @Override
+ public void onEntityExplode(final EntityExplodeEvent event)
+ {
+ for (Block block : event.blockList())
+ {
+ if (((block.getType() == Material.WALL_SIGN
+ || block.getType() == Material.SIGN_POST)
+ && EssentialsSign.isValidSign(new EssentialsSign.BlockSign(block)))
+ || EssentialsSign.checkIfBlockBreaksSigns(block))
+ {
+ event.setCancelled(true);
+ return;
+ }
+ for (Signs signs : Signs.values())
+ {
+ final EssentialsSign sign = signs.getSign();
+ if (sign.getBlocks().contains(block.getType()))
+ {
+ event.setCancelled(!sign.onBlockExplode(block, ess));
+ return;
+ }
+ }
+ }
+ }
+
+ @Override
+ public void onEndermanPickup(EndermanPickupEvent event)
+ {
+ if (event.isCancelled())
+ {
+ return;
+ }
+
+ final Block block = event.getBlock();
+ if (((block.getType() == Material.WALL_SIGN
+ || block.getType() == Material.SIGN_POST)
+ && EssentialsSign.isValidSign(new EssentialsSign.BlockSign(block)))
+ || EssentialsSign.checkIfBlockBreaksSigns(block))
+ {
+ event.setCancelled(true);
+ return;
+ }
+ for (Signs signs : Signs.values())
+ {
+ final EssentialsSign sign = signs.getSign();
+ if (sign.getBlocks().contains(block.getType())
+ && !sign.onBlockBreak(block, ess))
+ {
+ event.setCancelled(true);
+ return;
+ }
+ }
+ }
+}