summaryrefslogtreecommitdiff
path: root/src/net/eathena
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2015-08-26 16:44:50 +0300
committerAndrei Karas <akaras@inbox.ru>2015-08-26 16:44:50 +0300
commitda649050e6a92a199e1ba6ec09f456b184e51809 (patch)
tree6dadd6b56e821fe715799f4e6b0c15c225a7134d /src/net/eathena
parent653447ca463eaf573e7123896155b538b8dec869 (diff)
downloadmv-da649050e6a92a199e1ba6ec09f456b184e51809.tar.gz
mv-da649050e6a92a199e1ba6ec09f456b184e51809.tar.bz2
mv-da649050e6a92a199e1ba6ec09f456b184e51809.tar.xz
mv-da649050e6a92a199e1ba6ec09f456b184e51809.zip
Move receive code from generalhandler into separate file.
Diffstat (limited to 'src/net/eathena')
-rw-r--r--src/net/eathena/generalhandler.cpp119
-rw-r--r--src/net/eathena/generalhandler.h4
-rw-r--r--src/net/eathena/generalrecv.cpp193
-rw-r--r--src/net/eathena/generalrecv.h39
4 files changed, 236 insertions, 119 deletions
diff --git a/src/net/eathena/generalhandler.cpp b/src/net/eathena/generalhandler.cpp
index 2f404ce76..d81a05d9d 100644
--- a/src/net/eathena/generalhandler.cpp
+++ b/src/net/eathena/generalhandler.cpp
@@ -32,6 +32,8 @@
#include "gui/widgets/tabs/chat/guildtab.h"
#include "gui/widgets/tabs/chat/partytab.h"
+#include "net/eathena/generalrecv.h"
+
#include "net/eathena/adminhandler.h"
#include "net/eathena/auctionhandler.h"
#include "net/eathena/bankhandler.h"
@@ -79,9 +81,6 @@ extern Net::GeneralHandler *generalHandler;
namespace EAthena
{
-ServerInfo charServer;
-ServerInfo mapServer;
-
GeneralHandler::GeneralHandler() :
MessageHandler(),
mAdminHandler(new AdminHandler),
@@ -149,11 +148,11 @@ void GeneralHandler::handleMessage(Net::MessageIn &msg)
switch (msg.getId())
{
case SMSG_CONNECTION_PROBLEM:
- processConnectionProblem(msg);
+ GeneralRecv::processConnectionProblem(msg);
break;
case SMSG_MAP_NOT_FOUND:
- processMapNotFound(msg);
+ GeneralRecv::processMapNotFound(msg);
break;
default:
@@ -161,116 +160,6 @@ void GeneralHandler::handleMessage(Net::MessageIn &msg)
}
}
-void GeneralHandler::processConnectionProblem(Net::MessageIn &msg)
-{
- const uint8_t code = msg.readUInt8("flag");
- logger->log("Connection problem: %u", static_cast<unsigned int>(code));
-
- switch (code)
- {
- case 0:
- errorMessage = _("Authentication failed.");
- break;
- case 1:
- errorMessage = _("No servers available.");
- break;
- case 2:
- if (client->getState() == STATE_GAME)
- {
- errorMessage = _("Someone else is trying to use "
- "this account.");
- }
- else
- {
- errorMessage = _("This account is already logged in.");
- }
- break;
- case 3:
- errorMessage = _("Speed hack detected.");
- break;
- case 4:
- errorMessage = _("Server full.");
- break;
- case 5:
- errorMessage = _("Sorry, you are underaged.");
- break;
- case 8:
- errorMessage = _("Duplicated login.");
- break;
- case 9:
- errorMessage = _("To many connections from same ip.");
- break;
- case 10:
- errorMessage = _("Not paid for this time.");
- break;
- case 11:
- errorMessage = _("Pay suspended.");
- break;
- case 12:
- errorMessage = _("Pay changed.");
- break;
- case 13:
- errorMessage = _("Pay wrong ip.");
- break;
- case 14:
- errorMessage = _("Pay game room.");
- break;
- case 15:
- errorMessage = _("Disconnect forced by GM.");
- break;
- case 16:
- case 17:
- errorMessage = _("Ban japan refuse.");
- break;
- case 18:
- errorMessage = _("Remained other account.");
- break;
- case 100:
- errorMessage = _("Ip unfair.");
- break;
- case 101:
- errorMessage = _("Ip count all.");
- break;
- case 102:
- errorMessage = _("Ip count.");
- break;
- case 103:
- case 104:
- errorMessage = _("Memory.");
- break;
- case 105:
- errorMessage = _("Han valid.");
- break;
- case 106:
- errorMessage = _("Ip limited access.");
- break;
- case 107:
- errorMessage = _("Over characters list.");
- break;
- case 108:
- errorMessage = _("Ip blocked.");
- break;
- case 109:
- errorMessage = _("Invalid password count.");
- break;
- case 110:
- errorMessage = _("Not allowed race.");
- break;
- default:
- errorMessage = _("Unknown connection error.");
- break;
- }
- client->setState(STATE_ERROR);
-}
-
-void GeneralHandler::processMapNotFound(Net::MessageIn &msg)
-{
- const int sz = msg.readInt16("len") - 4;
- msg.readString(sz, "map name?");
- errorMessage = _("Map not found");
- client->setState(STATE_ERROR);
-}
-
void GeneralHandler::load()
{
(new Network)->registerHandler(this);
diff --git a/src/net/eathena/generalhandler.h b/src/net/eathena/generalhandler.h
index c2cb44787..0a7089c5d 100644
--- a/src/net/eathena/generalhandler.h
+++ b/src/net/eathena/generalhandler.h
@@ -63,10 +63,6 @@ class GeneralHandler final : public MessageHandler,
void gameEnded() const override final;
protected:
- static void processConnectionProblem(Net::MessageIn &msg);
-
- static void processMapNotFound(Net::MessageIn &msg);
-
MessageHandlerPtr mAdminHandler;
MessageHandlerPtr mBeingHandler;
MessageHandlerPtr mBuySellHandler;
diff --git a/src/net/eathena/generalrecv.cpp b/src/net/eathena/generalrecv.cpp
new file mode 100644
index 000000000..bdee78d7d
--- /dev/null
+++ b/src/net/eathena/generalrecv.cpp
@@ -0,0 +1,193 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2009 The Mana World Development Team
+ * Copyright (C) 2009-2010 The Mana Developers
+ * 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/generalrecv.h"
+
+#include "client.h"
+#include "configuration.h"
+
+#include "gui/windows/skilldialog.h"
+#include "gui/windows/socialwindow.h"
+#include "gui/windows/statuswindow.h"
+
+#include "gui/widgets/tabs/chat/guildtab.h"
+#include "gui/widgets/tabs/chat/partytab.h"
+
+#include "net/eathena/adminhandler.h"
+#include "net/eathena/auctionhandler.h"
+#include "net/eathena/bankhandler.h"
+#include "net/eathena/beinghandler.h"
+#include "net/eathena/buyingstorehandler.h"
+#include "net/eathena/buysellhandler.h"
+#include "net/eathena/cashshophandler.h"
+#include "net/eathena/chathandler.h"
+#include "net/eathena/charserverhandler.h"
+#include "net/eathena/elementalhandler.h"
+#include "net/eathena/familyhandler.h"
+#include "net/eathena/friendshandler.h"
+#include "net/eathena/gamehandler.h"
+#include "net/eathena/guildhandler.h"
+#include "net/eathena/homunculushandler.h"
+#include "net/eathena/inventoryhandler.h"
+#include "net/eathena/itemhandler.h"
+#include "net/eathena/loginhandler.h"
+#include "net/eathena/mailhandler.h"
+#include "net/eathena/markethandler.h"
+#include "net/eathena/mercenaryhandler.h"
+#include "net/eathena/network.h"
+#include "net/eathena/npchandler.h"
+#include "net/eathena/partyhandler.h"
+#include "net/eathena/pethandler.h"
+#include "net/eathena/playerhandler.h"
+#include "net/eathena/protocol.h"
+#include "net/eathena/roulettehandler.h"
+#include "net/eathena/searchstorehandler.h"
+#include "net/eathena/serverfeatures.h"
+#include "net/eathena/tradehandler.h"
+#include "net/eathena/skillhandler.h"
+#include "net/eathena/questhandler.h"
+#include "net/eathena/vendinghandler.h"
+
+#include "resources/db/itemdbstat.h"
+
+#include "utils/delete2.h"
+#include "utils/gettext.h"
+
+#include "debug.h"
+
+namespace EAthena
+{
+
+ServerInfo charServer;
+ServerInfo mapServer;
+
+void GeneralRecv::processConnectionProblem(Net::MessageIn &msg)
+{
+ const uint8_t code = msg.readUInt8("flag");
+ logger->log("Connection problem: %u", static_cast<unsigned int>(code));
+
+ switch (code)
+ {
+ case 0:
+ errorMessage = _("Authentication failed.");
+ break;
+ case 1:
+ errorMessage = _("No servers available.");
+ break;
+ case 2:
+ if (client->getState() == STATE_GAME)
+ {
+ errorMessage = _("Someone else is trying to use "
+ "this account.");
+ }
+ else
+ {
+ errorMessage = _("This account is already logged in.");
+ }
+ break;
+ case 3:
+ errorMessage = _("Speed hack detected.");
+ break;
+ case 4:
+ errorMessage = _("Server full.");
+ break;
+ case 5:
+ errorMessage = _("Sorry, you are underaged.");
+ break;
+ case 8:
+ errorMessage = _("Duplicated login.");
+ break;
+ case 9:
+ errorMessage = _("To many connections from same ip.");
+ break;
+ case 10:
+ errorMessage = _("Not paid for this time.");
+ break;
+ case 11:
+ errorMessage = _("Pay suspended.");
+ break;
+ case 12:
+ errorMessage = _("Pay changed.");
+ break;
+ case 13:
+ errorMessage = _("Pay wrong ip.");
+ break;
+ case 14:
+ errorMessage = _("Pay game room.");
+ break;
+ case 15:
+ errorMessage = _("Disconnect forced by GM.");
+ break;
+ case 16:
+ case 17:
+ errorMessage = _("Ban japan refuse.");
+ break;
+ case 18:
+ errorMessage = _("Remained other account.");
+ break;
+ case 100:
+ errorMessage = _("Ip unfair.");
+ break;
+ case 101:
+ errorMessage = _("Ip count all.");
+ break;
+ case 102:
+ errorMessage = _("Ip count.");
+ break;
+ case 103:
+ case 104:
+ errorMessage = _("Memory.");
+ break;
+ case 105:
+ errorMessage = _("Han valid.");
+ break;
+ case 106:
+ errorMessage = _("Ip limited access.");
+ break;
+ case 107:
+ errorMessage = _("Over characters list.");
+ break;
+ case 108:
+ errorMessage = _("Ip blocked.");
+ break;
+ case 109:
+ errorMessage = _("Invalid password count.");
+ break;
+ case 110:
+ errorMessage = _("Not allowed race.");
+ break;
+ default:
+ errorMessage = _("Unknown connection error.");
+ break;
+ }
+ client->setState(STATE_ERROR);
+}
+
+void GeneralRecv::processMapNotFound(Net::MessageIn &msg)
+{
+ const int sz = msg.readInt16("len") - 4;
+ msg.readString(sz, "map name?");
+ errorMessage = _("Map not found");
+ client->setState(STATE_ERROR);
+}
+
+} // namespace EAthena
diff --git a/src/net/eathena/generalrecv.h b/src/net/eathena/generalrecv.h
new file mode 100644
index 000000000..d18c81a09
--- /dev/null
+++ b/src/net/eathena/generalrecv.h
@@ -0,0 +1,39 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2009 The Mana World Development Team
+ * Copyright (C) 2009-2010 The Mana Developers
+ * 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_GENERALRECV_H
+#define NET_EATHENA_GENERALRECV_H
+
+#include "net/generalhandler.h"
+
+#include "net/eathena/messagehandler.h"
+
+namespace EAthena
+{
+ namespace GeneralRecv
+ {
+ void processConnectionProblem(Net::MessageIn &msg);
+ void processMapNotFound(Net::MessageIn &msg);
+ } // namespace GeneralRecv
+} // namespace EAthena
+
+#endif // NET_EATHENA_GENERALRECV_H