summaryrefslogtreecommitdiff
path: root/src/commandhandler.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/commandhandler.cpp')
-rw-r--r--src/commandhandler.cpp51
1 files changed, 51 insertions, 0 deletions
diff --git a/src/commandhandler.cpp b/src/commandhandler.cpp
index 888451021..5211c64c3 100644
--- a/src/commandhandler.cpp
+++ b/src/commandhandler.cpp
@@ -35,6 +35,7 @@
#include "gui/gui.h"
#include "gui/outfitwindow.h"
#include "gui/shopwindow.h"
+#include "gui/socialwindow.h"
#include "gui/trade.h"
#include "gui/sdlfont.h"
@@ -259,6 +260,18 @@ void CommandHandler::handleCommand(const std::string &command, ChatTab *tab)
{
handleUptime(args, tab);
}
+ else if (type == "addattack")
+ {
+ handleAddAttack(args, tab);
+ }
+ else if (type == "removeattack" || type == "removeignoreattack")
+ {
+ handleRemoveAttack(args, tab);
+ }
+ else if (type == "addignoreattack")
+ {
+ handleAddIgnoreAttack(args, tab);
+ }
else if (tab->handleCommand(type, args))
{
// Nothing to do
@@ -978,6 +991,44 @@ void CommandHandler::handleUptime(const std::string &args _UNUSED_,
}
}
+void CommandHandler::handleAddAttack(const std::string &args,
+ ChatTab *tab _UNUSED_)
+{
+ if (!player_node || player_node->isInAttackList(args))
+ return;
+
+ player_node->removeAttackMob(args);
+ player_node->addAttackMob(args);
+
+ if (socialWindow)
+ socialWindow->updateAttackFilter();
+}
+
+void CommandHandler::handleRemoveAttack(const std::string &args,
+ ChatTab *tab _UNUSED_)
+{
+ if (!player_node || args.empty() || !player_node->isInAttackList(args))
+ return;
+
+ player_node->removeAttackMob(args);
+
+ if (socialWindow)
+ socialWindow->updateAttackFilter();
+}
+
+void CommandHandler::handleAddIgnoreAttack(const std::string &args,
+ ChatTab *tab _UNUSED_)
+{
+ if (!player_node || player_node->isInIgnoreAttackList(args))
+ return;
+
+ player_node->removeAttackMob(args);
+ player_node->addIgnoreAttackMob(args);
+
+ if (socialWindow)
+ socialWindow->updateAttackFilter();
+}
+
void CommandHandler::handleCacheInfo(const std::string &args _UNUSED_,
ChatTab *tab _UNUSED_)
{