summaryrefslogtreecommitdiff
path: root/src/net/eathena
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2017-06-30 15:10:14 +0300
committerAndrei Karas <akaras@inbox.ru>2017-06-30 15:10:14 +0300
commit47f3e53850eae9c714ffad0c1197191a782e72e8 (patch)
treedae6f1bd0419c6875a6c2b44c62b127e7daaebf8 /src/net/eathena
parentc51f5a671e5fc6b78e57df46daf0fdba319dadf7 (diff)
downloadmv-47f3e53850eae9c714ffad0c1197191a782e72e8.tar.gz
mv-47f3e53850eae9c714ffad0c1197191a782e72e8.tar.bz2
mv-47f3e53850eae9c714ffad0c1197191a782e72e8.tar.xz
mv-47f3e53850eae9c714ffad0c1197191a782e72e8.zip
Fix packets for 20170329.
Diffstat (limited to 'src/net/eathena')
-rw-r--r--src/net/eathena/charserverrecv.cpp5
-rw-r--r--src/net/eathena/guildrecv.cpp1
-rw-r--r--src/net/eathena/loginrecv.cpp17
3 files changed, 21 insertions, 2 deletions
diff --git a/src/net/eathena/charserverrecv.cpp b/src/net/eathena/charserverrecv.cpp
index 44c90a227..13a374533 100644
--- a/src/net/eathena/charserverrecv.cpp
+++ b/src/net/eathena/charserverrecv.cpp
@@ -276,6 +276,11 @@ void CharServerRecv::processCharMapInfo(Net::MessageIn &restrict msg)
server.hostname = ipToString(msg.readInt32("map ip address"));
}
server.port = msg.readInt16("map ip port");
+ if (msg.getVersion() >= 20170329)
+ {
+ for (int f = 0; f < 32; f ++)
+ msg.readInt32("unused");
+ }
// Prevent the selected local player from being deleted
localPlayer = charServerHandler->mSelectedCharacter->dummy;
diff --git a/src/net/eathena/guildrecv.cpp b/src/net/eathena/guildrecv.cpp
index 741fcd6d8..7f17f57db 100644
--- a/src/net/eathena/guildrecv.cpp
+++ b/src/net/eathena/guildrecv.cpp
@@ -226,6 +226,7 @@ void GuildRecv::processGuildMemberList(Net::MessageIn &msg)
}
else
{
+ msg.readInt32("last login"); // for now unused
continue;
}
diff --git a/src/net/eathena/loginrecv.cpp b/src/net/eathena/loginrecv.cpp
index 38ee44e28..b9abf20aa 100644
--- a/src/net/eathena/loginrecv.cpp
+++ b/src/net/eathena/loginrecv.cpp
@@ -225,7 +225,20 @@ void LoginRecv::processLoginData(Net::MessageIn &msg)
loginHandler->clearWorlds();
- const int worldCount = (msg.getLength() - 47) / 32;
+ int offset = 0;
+ int serverLen = 0;
+ if (msg.getVersion() >= 20170315)
+ {
+ offset = 47 + 17;
+ serverLen = 32 + 128;
+ }
+ else
+ {
+ offset = 47;
+ serverLen = 32;
+ }
+
+ const int worldCount = (msg.getLength() - offset) / serverLen;
Ea::LoginRecv::mToken.session_ID1 = msg.readInt32("session id1");
Ea::LoginRecv::mToken.account_ID = msg.readBeingId("accound id");
@@ -262,7 +275,7 @@ void LoginRecv::processLoginData(Net::MessageIn &msg)
if (msg.getVersion() >= 20170315)
{
for (int f = 0; f < 32; f ++)
- msg.readUInt8("unused2");
+ msg.readInt32("unused2");
}
logger->log("Network: Server: %s (%s:%d)", world->name.c_str(),