diff options
author | KHobbits <rob@khobbits.co.uk> | 2011-08-17 15:28:58 +0100 |
---|---|---|
committer | KHobbits <rob@khobbits.co.uk> | 2011-08-17 15:28:58 +0100 |
commit | 5d95d1fca60606c83b3e61790afbb273f5e92079 (patch) | |
tree | a3120ff1b65a001283509fcc7cf0f11bcb8288ea | |
parent | 2541efb682a8f889ed2a4e04535ddf35ca912927 (diff) | |
download | Essentials-5d95d1fca60606c83b3e61790afbb273f5e92079.tar Essentials-5d95d1fca60606c83b3e61790afbb273f5e92079.tar.gz Essentials-5d95d1fca60606c83b3e61790afbb273f5e92079.tar.lz Essentials-5d95d1fca60606c83b3e61790afbb273f5e92079.tar.xz Essentials-5d95d1fca60606c83b3e61790afbb273f5e92079.zip |
Adding command cost for !shout and ?question.
-rw-r--r-- | Essentials/src/config.yml | 1 | ||||
-rw-r--r-- | EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListener.java | 52 |
2 files changed, 37 insertions, 16 deletions
diff --git a/Essentials/src/config.yml b/Essentials/src/config.yml index d369a704d..68842fef7 100644 --- a/Essentials/src/config.yml +++ b/Essentials/src/config.yml @@ -299,6 +299,7 @@ hide-permissionless-help: true # Note that users with the "essentials.chat.spy" permission will hear everything, regardless of this setting. # Users with essentials.chat.shout can override this by prefixing text with an exclamation mark (!) # Or with essentials.chat.question can override this by prefixing text with a question mark (?) +# You can add command costs for shout/question by adding chat-shout and chat-question to the command costs section." chat: radius: 0 diff --git a/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListener.java b/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListener.java index 6b3039d0b..85e821e7f 100644 --- a/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListener.java +++ b/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListener.java @@ -1,6 +1,8 @@ package com.earth2me.essentials.chat; +import com.earth2me.essentials.ChargeException; import com.earth2me.essentials.IEssentials; +import com.earth2me.essentials.Trade; import com.earth2me.essentials.User; import com.earth2me.essentials.Util; import java.util.Map; @@ -8,6 +10,7 @@ import java.util.logging.Logger; import org.bukkit.Location; import org.bukkit.Server; import org.bukkit.World; +import org.bukkit.command.CommandSender; import org.bukkit.entity.Player; import org.bukkit.event.player.PlayerChatEvent; import org.bukkit.event.player.PlayerListener; @@ -59,29 +62,38 @@ public class EssentialsChatPlayerListener extends PlayerListener } radius *= radius; - if (event.getMessage().startsWith("!") && event.getMessage().length() > 1) - { - if (user.isAuthorized("essentials.chat.shout")) + try { + if (event.getMessage().startsWith("!") && event.getMessage().length() > 1) { - event.setMessage(event.getMessage().substring(1)); - event.setFormat(Util.format("shoutFormat", event.getFormat())); + if (user.isAuthorized("essentials.chat.shout")) + { + charge(user,"chat-shout"); + event.setMessage(event.getMessage().substring(1)); + event.setFormat(Util.format("shoutFormat", event.getFormat())); + return; + } + user.sendMessage(Util.i18n("notAllowedToShout")); + event.setCancelled(true); return; } - user.sendMessage(Util.i18n("notAllowedToShout")); - event.setCancelled(true); - return; - } - if (event.getMessage().startsWith("?") && event.getMessage().length() > 1) - { - if (user.isAuthorized("essentials.chat.question")) + if (event.getMessage().startsWith("?") && event.getMessage().length() > 1) { - event.setMessage(event.getMessage().substring(1)); - event.setFormat(Util.format("questionFormat", event.getFormat())); + if (user.isAuthorized("essentials.chat.question")) + { + charge(user,"chat-question"); + event.setMessage(event.getMessage().substring(1)); + event.setFormat(Util.format("questionFormat", event.getFormat())); + return; + } + user.sendMessage(Util.i18n("notAllowedToQuestion")); + event.setCancelled(true); return; } - user.sendMessage(Util.i18n("notAllowedToQuestion")); - event.setCancelled(true); + } + catch (ChargeException ex) + { + ess.showError(user, ex, "Shout"); return; } @@ -123,4 +135,12 @@ public class EssentialsChatPlayerListener extends PlayerListener u.sendMessage(message); } } + protected void charge(final CommandSender sender, final String command) throws ChargeException + { + if (sender instanceof Player) + { + final Trade charge = new Trade(command, ess); + charge.charge(ess.getUser((Player)sender)); + } + } } |