diff options
author | snowleo <schneeleo@gmail.com> | 2011-12-14 16:04:15 +0100 |
---|---|---|
committer | snowleo <schneeleo@gmail.com> | 2011-12-14 16:04:15 +0100 |
commit | 0f1eb9b4f910b4f61f4c89fbad14b6485c372756 (patch) | |
tree | 62257261b99340c51a36b9dbdc97d72ec226a01f /EssentialsSigns/src/com/earth2me/essentials/signs/SignEntityListener.java | |
parent | 503e837cfdf1eaf0a4ae8b04199fc1c60dd82923 (diff) | |
download | Essentials-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.java | 73 |
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; + } + } + } +} |