Destroy archives to force flushing binary data
Summary: It is possible that boost's archive didn't write all data to a stream before the archive is destroyed. To make sure everything works, archives are now wrapped in a nested block. Additionally, there may be some issues if the stream isn't set for binary reading/writing due to new line character conversion. This shouldn't pose problems on Linux, but just to make sure it doesn't bite us in the a$% down the line. Reviewers: mferencevic, mculinovic Reviewed By: mferencevic Subscribers: pullbot Differential Revision: https://phabricator.memgraph.io/D1194
This commit is contained in:
parent
0616eb0aa4
commit
cc6f6f4b35
@ -62,9 +62,12 @@ std::unique_ptr<Message> Client::Call(std::unique_ptr<Message> request) {
|
||||
}
|
||||
|
||||
// Serialize and send request.
|
||||
std::stringstream request_stream;
|
||||
std::stringstream request_stream(std::ios_base::out | std::ios_base::binary);
|
||||
{
|
||||
boost::archive::binary_oarchive request_archive(request_stream);
|
||||
request_archive << request;
|
||||
// Archive destructor ensures everything is written.
|
||||
}
|
||||
|
||||
const std::string &request_buffer = request_stream.str();
|
||||
MessageSize request_data_size = request_buffer.size();
|
||||
@ -104,14 +107,17 @@ std::unique_ptr<Message> Client::Call(std::unique_ptr<Message> request) {
|
||||
sizeof(uint32_t) + sizeof(MessageSize) + response_data_size;
|
||||
if (received_bytes_ < response_size) continue;
|
||||
|
||||
std::stringstream response_stream;
|
||||
response_stream.str(
|
||||
std::string(reinterpret_cast<char *>(buffer_.data() + sizeof(uint32_t) +
|
||||
std::unique_ptr<Message> response;
|
||||
{
|
||||
std::stringstream response_stream(std::ios_base::in |
|
||||
std::ios_base::binary);
|
||||
response_stream.str(std::string(
|
||||
reinterpret_cast<char *>(buffer_.data() + sizeof(uint32_t) +
|
||||
sizeof(MessageSize)),
|
||||
response_data_size));
|
||||
boost::archive::binary_iarchive response_archive(response_stream);
|
||||
std::unique_ptr<Message> response;
|
||||
response_archive >> response;
|
||||
}
|
||||
|
||||
std::copy(buffer_.begin() + response_size,
|
||||
buffer_.begin() + received_bytes_, buffer_.begin());
|
||||
|
@ -38,14 +38,16 @@ void Session::Execute() {
|
||||
return;
|
||||
|
||||
// TODO (mferencevic): check for exceptions
|
||||
std::stringstream stream;
|
||||
std::unique_ptr<Message> message;
|
||||
{
|
||||
std::stringstream stream(std::ios_base::in | std::ios_base::binary);
|
||||
stream.str(
|
||||
std::string(reinterpret_cast<char *>(buffer_.data() + sizeof(uint32_t) +
|
||||
sizeof(MessageSize)),
|
||||
message_len));
|
||||
boost::archive::binary_iarchive archive(stream);
|
||||
std::unique_ptr<Message> message;
|
||||
archive >> message;
|
||||
}
|
||||
buffer_.Shift(sizeof(uint32_t) + sizeof(MessageSize) + message_len);
|
||||
|
||||
system_.AddTask(socket_, service_name_, message_id, std::move(message));
|
||||
@ -68,9 +70,12 @@ void SendMessage(Socket &socket, uint32_t message_id,
|
||||
CHECK(message) << "Trying to send nullptr instead of message";
|
||||
|
||||
// Serialize and send message
|
||||
std::stringstream stream;
|
||||
std::stringstream stream(std::ios_base::out | std::ios_base::binary);
|
||||
{
|
||||
boost::archive::binary_oarchive archive(stream);
|
||||
archive << message;
|
||||
// Archive destructor ensures everything is written.
|
||||
}
|
||||
|
||||
const std::string &buffer = stream.str();
|
||||
uint64_t message_size = sizeof(MessageSize) + buffer.size();
|
||||
|
Loading…
Reference in New Issue
Block a user