summaryrefslogtreecommitdiff
path: root/src/net/eathena
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2015-08-23 17:26:35 +0300
committerAndrei Karas <akaras@inbox.ru>2015-08-23 17:26:35 +0300
commit6690099a0156a2c842e77bf8bd7a306ee917a74a (patch)
tree38c106c77098dfdf6f833b423b60bf6a7f3c0e78 /src/net/eathena
parent93d55e71b137a43149775ac1283f20acea9a9947 (diff)
downloadmv-6690099a0156a2c842e77bf8bd7a306ee917a74a.tar.gz
mv-6690099a0156a2c842e77bf8bd7a306ee917a74a.tar.bz2
mv-6690099a0156a2c842e77bf8bd7a306ee917a74a.tar.xz
mv-6690099a0156a2c842e77bf8bd7a306ee917a74a.zip
Move receive code from auctionhandler into separate file.
Diffstat (limited to 'src/net/eathena')
-rw-r--r--src/net/eathena/auction.cpp83
-rw-r--r--src/net/eathena/auction.h43
-rw-r--r--src/net/eathena/auctionhandler.cpp62
-rw-r--r--src/net/eathena/auctionhandler.h11
4 files changed, 132 insertions, 67 deletions
diff --git a/src/net/eathena/auction.cpp b/src/net/eathena/auction.cpp
new file mode 100644
index 000000000..558e822e0
--- /dev/null
+++ b/src/net/eathena/auction.cpp
@@ -0,0 +1,83 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2011-2015 The ManaPlus Developers
+ *
+ * This file is part of The ManaPlus Client.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "net/eathena/auction.h"
+
+#include "logger.h"
+
+#include "net/eathena/messagein.h"
+
+#include "debug.h"
+
+namespace EAthena
+{
+
+void Auction::processOpenWindow(Net::MessageIn &msg)
+{
+ UNIMPLIMENTEDPACKET;
+ msg.readInt32("flag"); // 0 - open, 1 - close
+}
+
+void Auction::processAuctionResults(Net::MessageIn &msg)
+{
+ UNIMPLIMENTEDPACKET;
+ msg.readInt16("len");
+ msg.readInt32("pages");
+ const int itemCount = msg.readInt32("items count");
+ for (int f = 0; f < itemCount; f ++)
+ {
+ msg.readInt32("auction id");
+ msg.readString(24, "seller name");
+ msg.readInt32("item id");
+ msg.readInt32("auction type");
+ msg.readInt16("item amount"); // always 1
+ msg.readUInt8("identify");
+ msg.readUInt8("attribute");
+ msg.readUInt8("refine");
+ for (int d = 0; d < 4; d ++)
+ msg.readInt16("card");
+ msg.readInt32("price");
+ msg.readInt32("buy now");
+ msg.readString(24, "buyer name");
+ msg.readInt32("timestamp");
+ // +++ need use ItemColorManager for color
+ }
+}
+
+void Auction::processAuctionSetItem(Net::MessageIn &msg)
+{
+ UNIMPLIMENTEDPACKET;
+ msg.readInt16("index");
+ msg.readUInt8("flag");
+}
+
+void Auction::processAuctionMessage(Net::MessageIn &msg)
+{
+ UNIMPLIMENTEDPACKET;
+ msg.readUInt8("message");
+}
+
+void Auction::processAuctionClose(Net::MessageIn &msg)
+{
+ UNIMPLIMENTEDPACKET;
+ msg.readInt16("flag");
+}
+
+} // namespace EAthena
diff --git a/src/net/eathena/auction.h b/src/net/eathena/auction.h
new file mode 100644
index 000000000..675f7423d
--- /dev/null
+++ b/src/net/eathena/auction.h
@@ -0,0 +1,43 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2011-2015 The ManaPlus Developers
+ *
+ * This file is part of The ManaPlus Client.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef NET_EATHENA_AUCTION_H
+#define NET_EATHENA_AUCTION_H
+
+#ifdef EATHENA_SUPPORT
+
+#include "net/auctionhandler.h"
+
+#include "net/eathena/messagehandler.h"
+
+namespace EAthena
+{
+ namespace Auction
+ {
+ void processOpenWindow(Net::MessageIn &msg);
+ void processAuctionResults(Net::MessageIn &msg);
+ void processAuctionSetItem(Net::MessageIn &msg);
+ void processAuctionMessage(Net::MessageIn &msg);
+ void processAuctionClose(Net::MessageIn &msg);
+ } // namespace Admin
+} // namespace EAthena
+
+#endif // EATHENA_SUPPORT
+#endif // NET_EATHENA_AUCTION_H
diff --git a/src/net/eathena/auctionhandler.cpp b/src/net/eathena/auctionhandler.cpp
index f75efd2ea..4ee007953 100644
--- a/src/net/eathena/auctionhandler.cpp
+++ b/src/net/eathena/auctionhandler.cpp
@@ -25,6 +25,7 @@
#include "net/ea/eaprotocol.h"
+#include "net/eathena/auction.h"
#include "net/eathena/messageout.h"
#include "net/eathena/protocol.h"
@@ -56,23 +57,23 @@ void AuctionHandler::handleMessage(Net::MessageIn &msg)
switch (msg.getId())
{
case SMSG_AUCTION_OPEN_WINDOW:
- processOpenWindow(msg);
+ Auction::processOpenWindow(msg);
break;
case SMSG_AUCTION_RESULTS:
- processAuctionResults(msg);
+ Auction::processAuctionResults(msg);
break;
case SMSG_AUCTION_SET_ITEM:
- processAuctionSetItem(msg);
+ Auction::processAuctionSetItem(msg);
break;
case SMSG_AUCTION_MESSAGE:
- processAuctionMessage(msg);
+ Auction::processAuctionMessage(msg);
break;
case SMSG_AUCTION_CLOSE:
- processAuctionClose(msg);
+ Auction::processAuctionClose(msg);
break;
default:
@@ -80,57 +81,6 @@ void AuctionHandler::handleMessage(Net::MessageIn &msg)
}
}
-void AuctionHandler::processOpenWindow(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- msg.readInt32("flag"); // 0 - open, 1 - close
-}
-
-void AuctionHandler::processAuctionResults(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- msg.readInt16("len");
- msg.readInt32("pages");
- const int itemCount = msg.readInt32("items count");
- for (int f = 0; f < itemCount; f ++)
- {
- msg.readInt32("auction id");
- msg.readString(24, "seller name");
- msg.readInt32("item id");
- msg.readInt32("auction type");
- msg.readInt16("item amount"); // always 1
- msg.readUInt8("identify");
- msg.readUInt8("attribute");
- msg.readUInt8("refine");
- for (int d = 0; d < 4; d ++)
- msg.readInt16("card");
- msg.readInt32("price");
- msg.readInt32("buy now");
- msg.readString(24, "buyer name");
- msg.readInt32("timestamp");
- // +++ need use ItemColorManager for color
- }
-}
-
-void AuctionHandler::processAuctionSetItem(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- msg.readInt16("index");
- msg.readUInt8("flag");
-}
-
-void AuctionHandler::processAuctionMessage(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- msg.readUInt8("message");
-}
-
-void AuctionHandler::processAuctionClose(Net::MessageIn &msg)
-{
- UNIMPLIMENTEDPACKET;
- msg.readInt16("flag");
-}
-
void AuctionHandler::cancelReg() const
{
createOutPacket(CMSG_AUCTION_CANCEL_REG);
diff --git a/src/net/eathena/auctionhandler.h b/src/net/eathena/auctionhandler.h
index db20ee341..df0f57e61 100644
--- a/src/net/eathena/auctionhandler.h
+++ b/src/net/eathena/auctionhandler.h
@@ -62,17 +62,6 @@ class AuctionHandler final : public MessageHandler, public Net::AuctionHandler
void buy() const override final;
void sell() const override final;
-
- protected:
- static void processOpenWindow(Net::MessageIn &msg);
-
- static void processAuctionResults(Net::MessageIn &msg);
-
- static void processAuctionSetItem(Net::MessageIn &msg);
-
- static void processAuctionMessage(Net::MessageIn &msg);
-
- static void processAuctionClose(Net::MessageIn &msg);
};
} // namespace EAthena