summaryrefslogtreecommitdiff
path: root/src/net/eathena/searchstorehandler.cpp
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2015-08-30 16:10:55 +0300
committerAndrei Karas <akaras@inbox.ru>2015-08-30 16:10:55 +0300
commit4e343cd6e657f2b747b67fb688af53087199b097 (patch)
tree47b057faf67ac6f7dc574d69a9ca1a59ca073a33 /src/net/eathena/searchstorehandler.cpp
parenta50b0441ca5197f58823f2e47e74700c653fcb9c (diff)
downloadmv-4e343cd6e657f2b747b67fb688af53087199b097.tar.gz
mv-4e343cd6e657f2b747b67fb688af53087199b097.tar.bz2
mv-4e343cd6e657f2b747b67fb688af53087199b097.tar.xz
mv-4e343cd6e657f2b747b67fb688af53087199b097.zip
Move receive code from searchstorehandler into separate file.
Diffstat (limited to 'src/net/eathena/searchstorehandler.cpp')
-rw-r--r--src/net/eathena/searchstorehandler.cpp80
1 files changed, 5 insertions, 75 deletions
diff --git a/src/net/eathena/searchstorehandler.cpp b/src/net/eathena/searchstorehandler.cpp
index 6151a161c..e4225b6ee 100644
--- a/src/net/eathena/searchstorehandler.cpp
+++ b/src/net/eathena/searchstorehandler.cpp
@@ -27,6 +27,7 @@
#include "net/eathena/messageout.h"
#include "net/eathena/protocol.h"
+#include "net/eathena/searchstorerecv.h"
#include "debug.h"
@@ -55,19 +56,19 @@ void SearchStoreHandler::handleMessage(Net::MessageIn &msg)
switch (msg.getId())
{
case SMSG_SEARCHSTORE_SEARCH_ACK:
- processSearchAck(msg);
+ SearchStoreRecv::processSearchAck(msg);
break;
case SMSG_SEARCHSTORE_SEARCH_FAILED:
- processSearchFailed(msg);
+ SearchStoreRecv::processSearchFailed(msg);
break;
case SMSG_SEARCHSTORE_OPEN:
- processSearchOpen(msg);
+ SearchStoreRecv::processSearchOpen(msg);
break;
case SMSG_SEARCHSTORE_CLICK_ACK:
- processSearchClickAck(msg);
+ SearchStoreRecv::processSearchClickAck(msg);
break;
default:
@@ -110,75 +111,4 @@ void SearchStoreHandler::select(const int accountId,
outMsg.writeInt16(static_cast<int16_t>(itemId), "item id");
}
-void SearchStoreHandler::processSearchAck(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- const int count = (msg.readInt16("len") - 7) / 106;
- msg.readUInt8("is first page");
- msg.readUInt8("is next page");
- msg.readUInt8("remain uses");
- for (int f = 0; f < count; f ++)
- {
- msg.readInt32("store id");
- msg.readInt32("aoount id");
- msg.readString(80, "store name");
- msg.readInt16("item id");
- msg.readUInt8("item type");
- msg.readInt32("price");
- msg.readInt16("amount");
- msg.readUInt8("refine");
- for (int d = 0; d < 4; d++)
- msg.readInt16("card");
-
- // +++ need use ItemColorManager for colors
- }
-}
-
-void SearchStoreHandler::processSearchFailed(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- const int result = msg.readUInt8("result");
- switch (result)
- {
- case 0:
- NotifyManager::notify(
- NotifyTypes::SEARCH_STORE_FAILED_NO_STORES);
- break;
- case 1:
- NotifyManager::notify(
- NotifyTypes::SEARCH_STORE_FAILED_MANY_RESULTS);
- break;
- case 2:
- NotifyManager::notify(
- NotifyTypes::SEARCH_STORE_FAILED_CANT_SEARCH_ANYMORE);
- break;
- case 3:
- NotifyManager::notify(
- NotifyTypes::SEARCH_STORE_FAILED_CANT_SEARCH_YET);
- break;
- case 4:
- NotifyManager::notify(
- NotifyTypes::SEARCH_STORE_FAILED_NO_INFORMATION);
- break;
- default:
- NotifyManager::notify(
- NotifyTypes::SEARCH_STORE_FAILED);
- break;
- }
-}
-
-void SearchStoreHandler::processSearchOpen(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- msg.readInt16("effect");
- msg.readUInt8("uses");
-}
-
-void SearchStoreHandler::processSearchClickAck(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- msg.readInt16("x");
- msg.readInt16("y");
-}
-
} // namespace EAthena