summaryrefslogtreecommitdiff
path: root/src/net/tmwa
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2014-09-03 20:45:24 +0300
committerAndrei Karas <akaras@inbox.ru>2014-09-06 01:18:56 +0300
commit5a90cfe600073fbae6d097080ee88fd41cdcbeb7 (patch)
tree319c34f2cb259d9d8f55bba743182a2d511106c4 /src/net/tmwa
parentdb1548f44fb972c0c60b742dfece7e1f442e0378 (diff)
downloadmv-5a90cfe600073fbae6d097080ee88fd41cdcbeb7.tar.gz
mv-5a90cfe600073fbae6d097080ee88fd41cdcbeb7.tar.bz2
mv-5a90cfe600073fbae6d097080ee88fd41cdcbeb7.tar.xz
mv-5a90cfe600073fbae6d097080ee88fd41cdcbeb7.zip
Move processItemDropped from ea namespace into eathena and tmwa.
Diffstat (limited to 'src/net/tmwa')
-rw-r--r--src/net/tmwa/itemhandler.cpp20
-rw-r--r--src/net/tmwa/itemhandler.h3
2 files changed, 23 insertions, 0 deletions
diff --git a/src/net/tmwa/itemhandler.cpp b/src/net/tmwa/itemhandler.cpp
index 3b41d5bbc..95d1d0971 100644
--- a/src/net/tmwa/itemhandler.cpp
+++ b/src/net/tmwa/itemhandler.cpp
@@ -22,6 +22,8 @@
#include "net/tmwa/itemhandler.h"
+#include "actormanager.h"
+
#include "net/tmwa/protocol.h"
#include "debug.h"
@@ -66,4 +68,22 @@ void ItemHandler::handleMessage(Net::MessageIn &msg)
BLOCK_END("ItemHandler::handleMessage")
}
+void ItemHandler::processItemDropped(Net::MessageIn &msg)
+{
+ const int id = msg.readInt32();
+ const int itemId = msg.readInt16();
+ const uint8_t identify = msg.readUInt8(); // identify flag
+ const int x = msg.readInt16();
+ const int y = msg.readInt16();
+ const int subX = static_cast<int>(msg.readInt8());
+ const int subY = static_cast<int>(msg.readInt8());
+ const int amount = msg.readInt16();
+
+ if (actorManager)
+ {
+ actorManager->createItem(id, itemId,
+ x, y, amount, identify, subX, subY);
+ }
+}
+
} // namespace TmwAthena
diff --git a/src/net/tmwa/itemhandler.h b/src/net/tmwa/itemhandler.h
index 5203da929..8caeda785 100644
--- a/src/net/tmwa/itemhandler.h
+++ b/src/net/tmwa/itemhandler.h
@@ -38,6 +38,9 @@ class ItemHandler final : public MessageHandler, public Ea::ItemHandler
A_DELETE_COPY(ItemHandler)
void handleMessage(Net::MessageIn &msg) override final;
+
+ protected:
+ static void processItemDropped(Net::MessageIn &msg);
};
} // namespace TmwAthena