Introduce InMemoryProtoStreamReader. (#844)
* Introduce InMemoryProtoStreamReader. * Move inmemory*.* to in_memory*.*.master
parent
52527ec6d4
commit
aee1bc46dc
|
@ -0,0 +1,30 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2018 The Cartographer Authors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "cartographer/io/in_memory_proto_stream.h"
|
||||||
|
|
||||||
|
namespace cartographer {
|
||||||
|
namespace io {
|
||||||
|
|
||||||
|
bool InMemoryProtoStreamReader::ReadProto(google::protobuf::Message* proto) {
|
||||||
|
if (eof()) return false;
|
||||||
|
proto->CopyFrom(*map_chunks_.front());
|
||||||
|
map_chunks_.pop();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace io
|
||||||
|
} // namespace cartographer
|
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2018 The Cartographer Authors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef CARTOGRAPHER_IO_IN_MEMORY_PROTO_STREAM_H_
|
||||||
|
#define CARTOGRAPHER_IO_IN_MEMORY_PROTO_STREAM_H_
|
||||||
|
|
||||||
|
#include <queue>
|
||||||
|
|
||||||
|
#include "cartographer/common/make_unique.h"
|
||||||
|
#include "cartographer/common/port.h"
|
||||||
|
#include "cartographer/io/proto_stream_interface.h"
|
||||||
|
#include "google/protobuf/message.h"
|
||||||
|
|
||||||
|
namespace cartographer {
|
||||||
|
namespace io {
|
||||||
|
|
||||||
|
class InMemoryProtoStreamReader
|
||||||
|
: public cartographer::io::ProtoStreamReaderInterface {
|
||||||
|
public:
|
||||||
|
explicit InMemoryProtoStreamReader(
|
||||||
|
std::queue<std::unique_ptr<google::protobuf::Message>>&& map_chunks)
|
||||||
|
: map_chunks_(std::move(map_chunks)){};
|
||||||
|
InMemoryProtoStreamReader() = default;
|
||||||
|
~InMemoryProtoStreamReader() = default;
|
||||||
|
|
||||||
|
InMemoryProtoStreamReader(const InMemoryProtoStreamReader&) = delete;
|
||||||
|
InMemoryProtoStreamReader& operator=(const InMemoryProtoStreamReader&) =
|
||||||
|
delete;
|
||||||
|
|
||||||
|
template <typename MessageType>
|
||||||
|
void AddProto(const MessageType& proto) {
|
||||||
|
map_chunks_.push(common::make_unique<MessageType>(proto));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ReadProto(google::protobuf::Message* proto) override;
|
||||||
|
bool eof() const override { return map_chunks_.empty(); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::queue<std::unique_ptr<google::protobuf::Message>> map_chunks_;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace io
|
||||||
|
} // namespace cartographer
|
||||||
|
|
||||||
|
#endif // CARTOGRAPHER_IO_IN_MEMORY_PROTO_STREAM_H_
|
|
@ -0,0 +1,83 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2018 The Cartographer Authors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "cartographer/io/in_memory_proto_stream.h"
|
||||||
|
#include "cartographer/mapping/proto/pose_graph.pb.h"
|
||||||
|
#include "cartographer/mapping/proto/serialization.pb.h"
|
||||||
|
|
||||||
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
|
namespace cartographer {
|
||||||
|
namespace io {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
using common::make_unique;
|
||||||
|
using google::protobuf::Message;
|
||||||
|
using mapping::proto::PoseGraph;
|
||||||
|
using mapping::proto::SerializedData;
|
||||||
|
|
||||||
|
class InMemoryProtoStreamTest : public ::testing::Test {
|
||||||
|
protected:
|
||||||
|
void SetUp() override {
|
||||||
|
pose_graph_.add_trajectory()->set_trajectory_id(1);
|
||||||
|
serialized_data_.mutable_odometry_data()->set_trajectory_id(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
PoseGraph pose_graph_;
|
||||||
|
SerializedData serialized_data_;
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_F(InMemoryProtoStreamTest, ReadStreamInitializedFromQueue) {
|
||||||
|
std::queue<std::unique_ptr<Message>> proto_queue;
|
||||||
|
proto_queue.push(make_unique<PoseGraph>(pose_graph_));
|
||||||
|
proto_queue.push(make_unique<SerializedData>(serialized_data_));
|
||||||
|
|
||||||
|
InMemoryProtoStreamReader reader(std::move(proto_queue));
|
||||||
|
|
||||||
|
PoseGraph actual_pose_graph;
|
||||||
|
EXPECT_FALSE(reader.eof());
|
||||||
|
EXPECT_TRUE(reader.ReadProto(&actual_pose_graph));
|
||||||
|
EXPECT_EQ(1, actual_pose_graph.trajectory(0).trajectory_id());
|
||||||
|
|
||||||
|
SerializedData actual_serialized_data;
|
||||||
|
EXPECT_FALSE(reader.eof());
|
||||||
|
EXPECT_TRUE(reader.ReadProto(&actual_serialized_data));
|
||||||
|
EXPECT_EQ(2, actual_serialized_data.odometry_data().trajectory_id());
|
||||||
|
|
||||||
|
EXPECT_TRUE(reader.eof());
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(InMemoryProtoStreamTest, ReadStreamInitializedIncrementally) {
|
||||||
|
InMemoryProtoStreamReader reader;
|
||||||
|
reader.AddProto(pose_graph_);
|
||||||
|
reader.AddProto(serialized_data_);
|
||||||
|
|
||||||
|
PoseGraph actual_pose_graph;
|
||||||
|
EXPECT_FALSE(reader.eof());
|
||||||
|
EXPECT_TRUE(reader.ReadProto(&actual_pose_graph));
|
||||||
|
EXPECT_EQ(1, actual_pose_graph.trajectory(0).trajectory_id());
|
||||||
|
|
||||||
|
SerializedData actual_serialized_data;
|
||||||
|
EXPECT_FALSE(reader.eof());
|
||||||
|
EXPECT_TRUE(reader.ReadProto(&actual_serialized_data));
|
||||||
|
EXPECT_EQ(2, actual_serialized_data.odometry_data().trajectory_id());
|
||||||
|
|
||||||
|
EXPECT_TRUE(reader.eof());
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
} // namespace io
|
||||||
|
} // namespace cartographer
|
Loading…
Reference in New Issue