diff options
author | rubenwardy <rw@rubenwardy.com> | 2019-03-07 06:41:21 +0000 |
---|---|---|
committer | rubenwardy <rw@rubenwardy.com> | 2019-03-11 22:07:19 +0000 |
commit | da4739a26cb8327d1e6c5d8642692e5fbb0ad4a0 (patch) | |
tree | a0f40c9994043bd23330b9dc47bac90213152b08 /src | |
parent | fc24bf09153f17bec023cde164a039202102a66c (diff) | |
download | minetest-da4739a26cb8327d1e6c5d8642692e5fbb0ad4a0.tar.gz minetest-da4739a26cb8327d1e6c5d8642692e5fbb0ad4a0.tar.bz2 minetest-da4739a26cb8327d1e6c5d8642692e5fbb0ad4a0.zip |
Fix detach inventory serialisation (#8331)
Diffstat (limited to 'src')
-rw-r--r-- | src/network/clientpackethandler.cpp | 6 | ||||
-rw-r--r-- | src/server.cpp | 5 |
2 files changed, 8 insertions, 3 deletions
diff --git a/src/network/clientpackethandler.cpp b/src/network/clientpackethandler.cpp index 3e50173a6..889002a82 100644 --- a/src/network/clientpackethandler.cpp +++ b/src/network/clientpackethandler.cpp @@ -895,8 +895,10 @@ void Client::handleCommand_DetachedInventory(NetworkPacket* pkt) inv = inv_it->second; } - std::string contents; - *pkt >> contents; + u16 ignore; + *pkt >> ignore; // this used to be the length of the following string, ignore it + + std::string contents = pkt->getRemainingString(); std::istringstream is(contents, std::ios::binary); inv->deSerialize(is); } diff --git a/src/server.cpp b/src/server.cpp index ad469d655..701339ad8 100644 --- a/src/server.cpp +++ b/src/server.cpp @@ -2576,7 +2576,10 @@ void Server::sendDetachedInventory(const std::string &name, session_t peer_id) // Serialization & NetworkPacket isn't a love story std::ostringstream os(std::ios_base::binary); inv_it->second->serialize(os); - pkt << os.str(); + + std::string os_str = os.str(); + pkt << static_cast<u16>(os_str.size()); // HACK: to keep compatibility with 5.0.0 clients + pkt.putRawString(os_str); } if (peer_id == PEER_ID_INEXISTENT) |