diff options
author | Andrei Karas <akaras@inbox.ru> | 2014-09-09 13:24:44 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2014-09-09 13:24:44 +0300 |
commit | c33fe94a01b7a41de0b46aa1c5bc46f76e58a0b3 (patch) | |
tree | 4c62fccf401fbe57d51e0ca5f3ac020e59ced61c /src/net/eathena | |
parent | 72a83628abdde8cb5eb3e0973677266edf91997d (diff) | |
download | manaverse-c33fe94a01b7a41de0b46aa1c5bc46f76e58a0b3.tar.gz manaverse-c33fe94a01b7a41de0b46aa1c5bc46f76e58a0b3.tar.bz2 manaverse-c33fe94a01b7a41de0b46aa1c5bc46f76e58a0b3.tar.xz manaverse-c33fe94a01b7a41de0b46aa1c5bc46f76e58a0b3.zip |
Move processBeingChangeDirection from ea namespace into eathena and tmwa.
Diffstat (limited to 'src/net/eathena')
-rw-r--r-- | src/net/eathena/beinghandler.cpp | 27 | ||||
-rw-r--r-- | src/net/eathena/beinghandler.h | 2 |
2 files changed, 29 insertions, 0 deletions
diff --git a/src/net/eathena/beinghandler.cpp b/src/net/eathena/beinghandler.cpp index 958cd1391..c68be6f24 100644 --- a/src/net/eathena/beinghandler.cpp +++ b/src/net/eathena/beinghandler.cpp @@ -1110,4 +1110,31 @@ void BeingHandler::processRanksList(Net::MessageIn &msg) const msg.readInt32("my points"); } +void BeingHandler::processBeingChangeDirection(Net::MessageIn &msg) const +{ + BLOCK_START("BeingHandler::processBeingChangeDirection") + if (!actorManager) + { + BLOCK_END("BeingHandler::processBeingChangeDirection") + return; + } + + Being *const dstBeing = actorManager->findBeing(msg.readInt32("being id")); + + if (!dstBeing) + { + BLOCK_END("BeingHandler::processBeingChangeDirection") + return; + } + + msg.readInt16("unused"); + + const uint8_t dir = static_cast<uint8_t>( + msg.readUInt8("direction") & 0x0FU); + dstBeing->setDirection(dir); + if (localPlayer) + localPlayer->imitateDirection(dstBeing, dir); + BLOCK_END("BeingHandler::processBeingChangeDirection") +} + } // namespace EAthena diff --git a/src/net/eathena/beinghandler.h b/src/net/eathena/beinghandler.h index 344a672b1..4dceb3388 100644 --- a/src/net/eathena/beinghandler.h +++ b/src/net/eathena/beinghandler.h @@ -69,6 +69,8 @@ class BeingHandler final : public MessageHandler, public Ea::BeingHandler void processSkillAutoCast(Net::MessageIn &msg) const; void processRanksList(Net::MessageIn &msg) const; + + void processBeingChangeDirection(Net::MessageIn &msg) const; }; } // namespace EAthena |