diff options
author | Andrei Karas <akaras@inbox.ru> | 2015-08-30 15:38:03 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2015-08-30 15:38:03 +0300 |
commit | bff3a68b9f8984f0e8c1c530a26927b33b5afad1 (patch) | |
tree | 8301babc2adebea100c563038b579663a16657bc /src/net/eathena | |
parent | 7c8e0e0454f2e9acfde62faf669a1628e3935a58 (diff) | |
download | plus-bff3a68b9f8984f0e8c1c530a26927b33b5afad1.tar.gz plus-bff3a68b9f8984f0e8c1c530a26927b33b5afad1.tar.bz2 plus-bff3a68b9f8984f0e8c1c530a26927b33b5afad1.tar.xz plus-bff3a68b9f8984f0e8c1c530a26927b33b5afad1.zip |
Move receive code from questhandler into separate file.
Diffstat (limited to 'src/net/eathena')
-rw-r--r-- | src/net/eathena/questhandler.cpp | 139 | ||||
-rw-r--r-- | src/net/eathena/questhandler.h | 15 | ||||
-rw-r--r-- | src/net/eathena/questrecv.cpp | 160 | ||||
-rw-r--r-- | src/net/eathena/questrecv.h | 42 |
4 files changed, 210 insertions, 146 deletions
diff --git a/src/net/eathena/questhandler.cpp b/src/net/eathena/questhandler.cpp index 404069594..db70958a4 100644 --- a/src/net/eathena/questhandler.cpp +++ b/src/net/eathena/questhandler.cpp @@ -25,6 +25,7 @@ #include "net/eathena/messageout.h" #include "net/eathena/protocol.h" +#include "net/eathena/questrecv.h" #include "resources/skillconsts.h" @@ -58,31 +59,31 @@ void QuestHandler::handleMessage(Net::MessageIn &msg) switch (msg.getId()) { case SMSG_QUEST_ADD: - processAddQuest(msg); + QuestRecv::processAddQuest(msg); break; case SMSG_QUEST_LIST: - processAddQuests(msg); + QuestRecv::processAddQuests(msg); break; case SMSG_QUEST_LIST_OBJECTIVES: - processAddQuestsObjectives(msg); + QuestRecv::processAddQuestsObjectives(msg); break; case SMSG_QUEST_UPDATE_OBJECTIVES: - processUpdateQuestsObjectives(msg); + QuestRecv::processUpdateQuestsObjectives(msg); break; case SMSG_QUEST_REMOVE: - processRemoveQuest(msg); + QuestRecv::processRemoveQuest(msg); break; case SMSG_QUEST_ACTIVATE: - processActivateQuest(msg); + QuestRecv::processActivateQuest(msg); break; case SMSG_QUEST_NPC_EFFECT: - processNpcQuestEffect(msg); + QuestRecv::processNpcQuestEffect(msg); break; default: @@ -91,130 +92,6 @@ void QuestHandler::handleMessage(Net::MessageIn &msg) BLOCK_END("QuestHandler::handleMessage") } -void QuestHandler::processAddQuest(Net::MessageIn &msg) -{ - const int var = msg.readInt32("quest id"); - const int val = msg.readUInt8("state"); - msg.readUInt8("time diff"); - msg.readInt32("time"); - const int num = msg.readInt16("objectives count"); - for (int f = 0; f < num; f ++) - { - // need use in quests kills list - msg.readInt32("monster id"); - msg.readInt16("count"); - msg.readString(24, "monster name"); - } - - msg.skipToEnd("unused"); - - if (questsWindow) - { - questsWindow->updateQuest(var, val); - questsWindow->rebuild(true); - } - if (skillDialog) - { - skillDialog->updateQuest(var, val); - skillDialog->playUpdateEffect(var + SKILL_VAR_MIN_ID); - } -} - -void QuestHandler::processAddQuests(Net::MessageIn &msg) -{ - msg.readInt16("len"); - const int num = msg.readInt32("quests count"); - for (int f = 0; f < num; f ++) - { - const int var = msg.readInt32("quest id"); - const int val = msg.readUInt8("state"); - msg.readInt32("time diff"); - msg.readInt32("time"); - msg.readInt16("objectives count"); - if (questsWindow) - questsWindow->updateQuest(var, val); - if (skillDialog) - skillDialog->updateQuest(var, val); - } - - if (questsWindow) - questsWindow->rebuild(false); -} - -void QuestHandler::processAddQuestsObjectives(Net::MessageIn &msg) -{ - msg.readInt16("len"); - const int quests = msg.readInt32("quests count"); - for (int f = 0; f < quests; f ++) - { - msg.readInt32("quest id"); - msg.readInt32("time diff"); - msg.readInt32("time"); - const int num = msg.readInt16("objectives count"); - for (int d = 0; d < num; d ++) - { - // need use in quests kills list - msg.readInt32("monster id"); - msg.readInt16("count"); - msg.readString(24, "monster name"); - } - } - msg.skipToEnd("unused"); -} - -void QuestHandler::processUpdateQuestsObjectives(Net::MessageIn &msg) -{ - // ignored - msg.readInt16("len"); - const int num = msg.readInt16("objectives count"); - for (int f = 0; f < num; f ++) - { - msg.readInt32("quest id"); - msg.readInt32("monster id"); - msg.readInt16("count old"); - msg.readInt16("count new"); - } -} - -void QuestHandler::processRemoveQuest(Net::MessageIn &msg) -{ - const int var = msg.readInt32("quest id"); - const int val = -1; - - // not removing quest, because this is impossible, - // but changing status to -1 - if (questsWindow) - { - questsWindow->updateQuest(var, val); - questsWindow->rebuild(true); - } - if (skillDialog) - { - skillDialog->updateQuest(var, val); - skillDialog->playUpdateEffect(var + SKILL_VAR_MIN_ID); - } -} - -void QuestHandler::processActivateQuest(Net::MessageIn &msg) -{ - UNIMPLIMENTEDPACKET; - // +++ need enable/disable quests depend on this packet - msg.readInt32("quest id"); - msg.readUInt8("activate"); -} - -void QuestHandler::processNpcQuestEffect(Net::MessageIn &msg) -{ - UNIMPLIMENTEDPACKET; - // this packed mostly useless, because manaplus can show any - // kind of effects based on quest states. - msg.readInt32("npc id"); - msg.readInt16("x"); - msg.readInt16("y"); - msg.readInt16("state"); - msg.readInt16("color"); -} - void QuestHandler::setQeustActiveState(const int questId, const bool active) const { diff --git a/src/net/eathena/questhandler.h b/src/net/eathena/questhandler.h index 971ba6cc1..2ec83767f 100644 --- a/src/net/eathena/questhandler.h +++ b/src/net/eathena/questhandler.h @@ -39,21 +39,6 @@ class QuestHandler final : public MessageHandler, public Net::QuestHandler void setQeustActiveState(const int questId, const bool active) const override final; - - protected: - static void processAddQuest(Net::MessageIn &msg); - - static void processAddQuests(Net::MessageIn &msg); - - static void processAddQuestsObjectives(Net::MessageIn &msg); - - static void processUpdateQuestsObjectives(Net::MessageIn &msg); - - static void processRemoveQuest(Net::MessageIn &msg); - - static void processActivateQuest(Net::MessageIn &msg); - - static void processNpcQuestEffect(Net::MessageIn &msg); }; } // namespace EAthena diff --git a/src/net/eathena/questrecv.cpp b/src/net/eathena/questrecv.cpp new file mode 100644 index 000000000..e08d663c9 --- /dev/null +++ b/src/net/eathena/questrecv.cpp @@ -0,0 +1,160 @@ +/* + * The ManaPlus Client + * Copyright (C) 2012-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/questrecv.h" + +#include "gui/windows/skilldialog.h" +#include "gui/windows/questswindow.h" + +#include "net/eathena/messageout.h" +#include "net/eathena/protocol.h" + +#include "resources/skillconsts.h" + +#include "debug.h" + +namespace EAthena +{ + +void QuestRecv::processAddQuest(Net::MessageIn &msg) +{ + const int var = msg.readInt32("quest id"); + const int val = msg.readUInt8("state"); + msg.readUInt8("time diff"); + msg.readInt32("time"); + const int num = msg.readInt16("objectives count"); + for (int f = 0; f < num; f ++) + { + // need use in quests kills list + msg.readInt32("monster id"); + msg.readInt16("count"); + msg.readString(24, "monster name"); + } + + msg.skipToEnd("unused"); + + if (questsWindow) + { + questsWindow->updateQuest(var, val); + questsWindow->rebuild(true); + } + if (skillDialog) + { + skillDialog->updateQuest(var, val); + skillDialog->playUpdateEffect(var + SKILL_VAR_MIN_ID); + } +} + +void QuestRecv::processAddQuests(Net::MessageIn &msg) +{ + msg.readInt16("len"); + const int num = msg.readInt32("quests count"); + for (int f = 0; f < num; f ++) + { + const int var = msg.readInt32("quest id"); + const int val = msg.readUInt8("state"); + msg.readInt32("time diff"); + msg.readInt32("time"); + msg.readInt16("objectives count"); + if (questsWindow) + questsWindow->updateQuest(var, val); + if (skillDialog) + skillDialog->updateQuest(var, val); + } + + if (questsWindow) + questsWindow->rebuild(false); +} + +void QuestRecv::processAddQuestsObjectives(Net::MessageIn &msg) +{ + msg.readInt16("len"); + const int quests = msg.readInt32("quests count"); + for (int f = 0; f < quests; f ++) + { + msg.readInt32("quest id"); + msg.readInt32("time diff"); + msg.readInt32("time"); + const int num = msg.readInt16("objectives count"); + for (int d = 0; d < num; d ++) + { + // need use in quests kills list + msg.readInt32("monster id"); + msg.readInt16("count"); + msg.readString(24, "monster name"); + } + } + msg.skipToEnd("unused"); +} + +void QuestRecv::processUpdateQuestsObjectives(Net::MessageIn &msg) +{ + // ignored + msg.readInt16("len"); + const int num = msg.readInt16("objectives count"); + for (int f = 0; f < num; f ++) + { + msg.readInt32("quest id"); + msg.readInt32("monster id"); + msg.readInt16("count old"); + msg.readInt16("count new"); + } +} + +void QuestRecv::processRemoveQuest(Net::MessageIn &msg) +{ + const int var = msg.readInt32("quest id"); + const int val = -1; + + // not removing quest, because this is impossible, + // but changing status to -1 + if (questsWindow) + { + questsWindow->updateQuest(var, val); + questsWindow->rebuild(true); + } + if (skillDialog) + { + skillDialog->updateQuest(var, val); + skillDialog->playUpdateEffect(var + SKILL_VAR_MIN_ID); + } +} + +void QuestRecv::processActivateQuest(Net::MessageIn &msg) +{ + UNIMPLIMENTEDPACKET; + // +++ need enable/disable quests depend on this packet + msg.readInt32("quest id"); + msg.readUInt8("activate"); +} + +void QuestRecv::processNpcQuestEffect(Net::MessageIn &msg) +{ + UNIMPLIMENTEDPACKET; + // this packed mostly useless, because manaplus can show any + // kind of effects based on quest states. + msg.readInt32("npc id"); + msg.readInt16("x"); + msg.readInt16("y"); + msg.readInt16("state"); + msg.readInt16("color"); +} + +} // namespace EAthena diff --git a/src/net/eathena/questrecv.h b/src/net/eathena/questrecv.h new file mode 100644 index 000000000..7b2e351cb --- /dev/null +++ b/src/net/eathena/questrecv.h @@ -0,0 +1,42 @@ +/* + * The ManaPlus Client + * Copyright (C) 2012-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_QUESTRECV_H +#define NET_EATHENA_QUESTRECV_H + +#include "net/eathena/messagehandler.h" + +#include "net/questhandler.h" + +namespace EAthena +{ + namespace QuestRecv + { + void processAddQuest(Net::MessageIn &msg); + void processAddQuests(Net::MessageIn &msg); + void processAddQuestsObjectives(Net::MessageIn &msg); + void processUpdateQuestsObjectives(Net::MessageIn &msg); + void processRemoveQuest(Net::MessageIn &msg); + void processActivateQuest(Net::MessageIn &msg); + void processNpcQuestEffect(Net::MessageIn &msg); + } // namespace QuestRecv +} // namespace EAthena + +#endif // NET_EATHENA_QUESTRECV_H |