/* * 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/cloud/internal/handlers/write_state_handler.h" #include "async_grpc/rpc_handler.h" #include "cartographer/cloud/internal/map_builder_context_interface.h" #include "cartographer/cloud/internal/map_builder_server.h" #include "cartographer/cloud/proto/map_builder_service.pb.h" #include "cartographer/io/internal/in_memory_proto_stream.h" namespace cartographer { namespace cloud { namespace handlers { void WriteStateHandler::OnRequest(const google::protobuf::Empty& request) { auto writer = GetWriter(); io::ForwardingProtoStreamWriter proto_stream_writer( [writer](const google::protobuf::Message* proto) { if (!proto) { writer.WritesDone(); return true; } auto response = absl::make_unique(); if (proto->GetTypeName() == "cartographer.mapping.proto.SerializationHeader") { response->mutable_header()->CopyFrom(*proto); } else if (proto->GetTypeName() == "cartographer.mapping.proto.SerializedData") { response->mutable_serialized_data()->CopyFrom(*proto); } else { LOG(FATAL) << "Unsupported message type: " << proto->GetTypeName(); } writer.Write(std::move(response)); return true; }); GetContext()->map_builder().SerializeState( /*include_unfinished_submaps=*/false, &proto_stream_writer); proto_stream_writer.Close(); } } // namespace handlers } // namespace cloud } // namespace cartographer