diff options
author | Andrei Karas <akaras@inbox.ru> | 2014-09-30 22:14:53 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2014-09-30 22:14:53 +0300 |
commit | d82994bca93b4278c4751a2a4c1313ba2f41bd4b (patch) | |
tree | 67917fb2dae7f57c62c75981dc62f5d9679241b0 | |
parent | cee0e9966fb9ec9068aa7483cf38ff128508193b (diff) | |
download | manaplus-d82994bca93b4278c4751a2a4c1313ba2f41bd4b.tar.gz manaplus-d82994bca93b4278c4751a2a4c1313ba2f41bd4b.tar.bz2 manaplus-d82994bca93b4278c4751a2a4c1313ba2f41bd4b.tar.xz manaplus-d82994bca93b4278c4751a2a4c1313ba2f41bd4b.zip |
eathena: add packet SMSG_GUILD_UPDATE_COORDS 0x01eb.
-rw-r--r-- | src/net/eathena/guildhandler.cpp | 18 | ||||
-rw-r--r-- | src/net/eathena/guildhandler.h | 3 | ||||
-rw-r--r-- | src/net/eathena/protocol.h | 1 |
3 files changed, 22 insertions, 0 deletions
diff --git a/src/net/eathena/guildhandler.cpp b/src/net/eathena/guildhandler.cpp index 5508b13d9..27d848e74 100644 --- a/src/net/eathena/guildhandler.cpp +++ b/src/net/eathena/guildhandler.cpp @@ -68,6 +68,7 @@ GuildHandler::GuildHandler() : SMSG_GUILD_DEL_ALLIANCE, SMSG_GUILD_OPPOSITION_ACK, SMSG_GUILD_BROKEN, + SMSG_GUILD_UPDATE_COORDS, 0 }; handledMessages = _messages; @@ -187,11 +188,28 @@ void GuildHandler::handleMessage(Net::MessageIn &msg) processGuildBroken(msg); break; + case SMSG_GUILD_UPDATE_COORDS: + processGuildUpdateCoords(msg); + break; + default: break; } } +void GuildHandler::processGuildUpdateCoords(Net::MessageIn &msg) const +{ + const int id = msg.readInt32("account id"); + const int x = msg.readInt16("x"); + const int y = msg.readInt16("y"); + if (Ea::taGuild) + { + GuildMember *const m = Ea::taGuild->getMember(id); + m->setX(x); + m->setY(y); + } +} + void GuildHandler::create(const std::string &name) const { MessageOut msg(CMSG_GUILD_CREATE); diff --git a/src/net/eathena/guildhandler.h b/src/net/eathena/guildhandler.h index aeda0c210..a32a398f5 100644 --- a/src/net/eathena/guildhandler.h +++ b/src/net/eathena/guildhandler.h @@ -72,6 +72,9 @@ class GuildHandler final : public Ea::GuildHandler, public MessageHandler const override final; void checkMaster() const; + + protected: + void processGuildUpdateCoords(Net::MessageIn &msg) const; }; extern Ea::GuildTab *guildTab; diff --git a/src/net/eathena/protocol.h b/src/net/eathena/protocol.h index 45356938e..005d1c863 100644 --- a/src/net/eathena/protocol.h +++ b/src/net/eathena/protocol.h @@ -204,6 +204,7 @@ #define SMSG_GUILD_DEL_ALLIANCE 0x0184 #define SMSG_GUILD_OPPOSITION_ACK 0x0181 #define SMSG_GUILD_BROKEN 0x015e +#define SMSG_GUILD_UPDATE_COORDS 0x01eb #define SMSG_QUEST_ADD 0x02b3 #define SMSG_QUEST_LIST 0x02b1 |