From 12ae270e892d8d7cef9813031e7359c93009ed02 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Tue, 14 Oct 2014 13:38:08 +0300 Subject: eathena: add partial support for packet SMSG_QUEST_NPC_EFFECT 0x0446. --- src/net/eathena/questhandler.cpp | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) (limited to 'src/net/eathena/questhandler.cpp') diff --git a/src/net/eathena/questhandler.cpp b/src/net/eathena/questhandler.cpp index 5c27cbe00..796663bde 100644 --- a/src/net/eathena/questhandler.cpp +++ b/src/net/eathena/questhandler.cpp @@ -45,6 +45,7 @@ QuestHandler::QuestHandler() : SMSG_QUEST_UPDATE_OBJECTIVES, SMSG_QUEST_REMOVE, SMSG_QUEST_ACTIVATE, + SMSG_QUEST_NPC_EFFECT, 0 }; handledMessages = _messages; @@ -80,6 +81,10 @@ void QuestHandler::handleMessage(Net::MessageIn &msg) processActivateQuest(msg); break; + case SMSG_QUEST_NPC_EFFECT: + processNpcQuestEffect(msg); + break; + default: break; } @@ -194,6 +199,17 @@ void QuestHandler::processActivateQuest(Net::MessageIn &msg) msg.readUInt8("activate"); } +void QuestHandler::processNpcQuestEffect(Net::MessageIn &msg) +{ + // 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 { -- cgit v1.2.3-60-g2f50