summaryrefslogtreecommitdiffstats
path: root/EssentialsSigns/src/com/earth2me/essentials/signs/SignBuy.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/SignBuy.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/SignBuy.java')
-rw-r--r--EssentialsSigns/src/com/earth2me/essentials/signs/SignBuy.java38
1 files changed, 38 insertions, 0 deletions
diff --git a/EssentialsSigns/src/com/earth2me/essentials/signs/SignBuy.java b/EssentialsSigns/src/com/earth2me/essentials/signs/SignBuy.java
new file mode 100644
index 000000000..fd84bd0f3
--- /dev/null
+++ b/EssentialsSigns/src/com/earth2me/essentials/signs/SignBuy.java
@@ -0,0 +1,38 @@
+package com.earth2me.essentials.signs;
+
+import com.earth2me.essentials.ChargeException;
+import com.earth2me.essentials.api.IEssentials;
+import com.earth2me.essentials.Trade;
+import com.earth2me.essentials.api.IUser;
+
+
+public class SignBuy extends EssentialsSign
+{
+ public SignBuy()
+ {
+ super("Buy");
+ }
+
+ @Override
+ protected boolean onSignCreate(final ISign sign, final IUser player, final String username, final IEssentials ess) throws SignException
+ {
+ validateTrade(sign, 1, 2, player, ess);
+ validateTrade(sign, 3, ess);
+ return true;
+ }
+
+ @Override
+ protected boolean onSignInteract(final ISign sign, final IUser player, final String username, final IEssentials ess) throws SignException, ChargeException
+ {
+ final Trade items = getTrade(sign, 1, 2, player, ess);
+ final Trade charge = getTrade(sign, 3, ess);
+ charge.isAffordableFor(player);
+ if (!items.pay(player, false))
+ {
+ throw new ChargeException("Inventory full");
+ }
+ charge.charge(player);
+ Trade.log("Sign", "Buy", "Interact", username, charge, username, items, sign.getBlock().getLocation(), ess);
+ return true;
+ }
+}