diff options
Diffstat (limited to 'src/net/eathena/questhandler.cpp')
-rw-r--r-- | src/net/eathena/questhandler.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/net/eathena/questhandler.cpp b/src/net/eathena/questhandler.cpp index 496ea49ad..3dee91b3f 100644 --- a/src/net/eathena/questhandler.cpp +++ b/src/net/eathena/questhandler.cpp @@ -40,6 +40,7 @@ QuestHandler::QuestHandler() : SMSG_QUEST_ADD, SMSG_QUEST_LIST, SMSG_QUEST_LIST_OBJECTIVES, + SMSG_QUEST_UPDATE_OBJECTIVES, 0 }; handledMessages = _messages; @@ -62,6 +63,10 @@ void QuestHandler::handleMessage(Net::MessageIn &msg) processAddQuestsObjectives(msg); break; + case SMSG_QUEST_UPDATE_OBJECTIVES: + processUpdateQuestsObjectives(msg); + break; + default: break; } @@ -77,6 +82,7 @@ void QuestHandler::processAddQuest(Net::MessageIn &msg) 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"); @@ -132,4 +138,18 @@ void QuestHandler::processAddQuestsObjectives(Net::MessageIn &msg) } } +void QuestHandler::processUpdateQuestsObjectives(Net::MessageIn &msg) +{ + msg.readInt16("len"); + const int num = msg.readInt16("objectives count"); + for (int f = 0; f < num; f ++) + { + // need use in quests kills list + msg.readInt32("quest id"); + msg.readInt32("monster id"); + msg.readInt16("count old"); + msg.readInt16("count new"); + } +} + } // namespace TmwAthena |