GRPC C++  1.62.0
proto_utils.h
Go to the documentation of this file.
1 //
2 //
3 // Copyright 2015 gRPC authors.
4 //
5 // Licensed under the Apache License, Version 2.0 (the "License");
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
8 //
9 // http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
16 //
17 //
18 
19 #ifndef GRPCPP_IMPL_PROTO_UTILS_H
20 #define GRPCPP_IMPL_PROTO_UTILS_H
21 
22 #include <type_traits>
23 
25 #include <grpc/impl/grpc_types.h>
26 #include <grpc/slice.h>
27 #include <grpc/support/log.h>
33 #include <grpcpp/support/slice.h>
34 #include <grpcpp/support/status.h>
35 
38 
39 namespace grpc {
40 
41 // ProtoBufferWriter must be a subclass of ::protobuf::io::ZeroCopyOutputStream.
42 template <class ProtoBufferWriter, class T>
44  bool* own_buffer) {
45  static_assert(std::is_base_of<protobuf::io::ZeroCopyOutputStream,
46  ProtoBufferWriter>::value,
47  "ProtoBufferWriter must be a subclass of "
48  "::protobuf::io::ZeroCopyOutputStream");
49  *own_buffer = true;
50  int byte_size = static_cast<int>(msg.ByteSizeLong());
51  if (static_cast<size_t>(byte_size) <= GRPC_SLICE_INLINED_SIZE) {
52  Slice slice(byte_size);
53  // We serialize directly into the allocated slices memory
54  GPR_ASSERT(slice.end() == msg.SerializeWithCachedSizesToArray(
55  const_cast<uint8_t*>(slice.begin())));
56  ByteBuffer tmp(&slice, 1);
57  bb->Swap(&tmp);
58 
59  return grpc::Status::OK;
60  }
62  return msg.SerializeToZeroCopyStream(&writer)
64  : Status(StatusCode::INTERNAL, "Failed to serialize message");
65 }
66 
67 // BufferReader must be a subclass of ::protobuf::io::ZeroCopyInputStream.
68 template <class ProtoBufferReader, class T>
71  static_assert(std::is_base_of<protobuf::io::ZeroCopyInputStream,
72  ProtoBufferReader>::value,
73  "ProtoBufferReader must be a subclass of "
74  "::protobuf::io::ZeroCopyInputStream");
75  if (buffer == nullptr) {
76  return Status(StatusCode::INTERNAL, "No payload");
77  }
78  Status result = grpc::Status::OK;
79  {
80  ProtoBufferReader reader(buffer);
81  if (!reader.status().ok()) {
82  return reader.status();
83  }
84  if (!msg->ParseFromZeroCopyStream(&reader)) {
85  result = Status(StatusCode::INTERNAL, msg->InitializationErrorString());
86  }
87  }
88  buffer->Clear();
89  return result;
90 }
91 
92 // this is needed so the following class does not conflict with protobuf
93 // serializers that utilize internal-only tools.
94 #ifdef GRPC_OPEN_SOURCE_PROTO
95 // This class provides a protobuf serializer. It translates between protobuf
96 // objects and grpc_byte_buffers. More information about SerializationTraits can
97 // be found in include/grpcpp/impl/codegen/serialization_traits.h.
98 template <class T>
99 class SerializationTraits<
100  T, typename std::enable_if<
101  std::is_base_of<grpc::protobuf::MessageLite, T>::value>::type> {
102  public:
103  static Status Serialize(const grpc::protobuf::MessageLite& msg,
104  ByteBuffer* bb, bool* own_buffer) {
105  return GenericSerialize<ProtoBufferWriter, T>(msg, bb, own_buffer);
106  }
107 
108  static Status Deserialize(ByteBuffer* buffer,
110  return GenericDeserialize<ProtoBufferReader, T>(buffer, msg);
111  }
112 };
113 #endif
114 
115 } // namespace grpc
116 
117 #endif // GRPCPP_IMPL_PROTO_UTILS_H
grpc::ProtoBufferWriter
This is a specialization of the protobuf class ZeroCopyOutputStream.
Definition: proto_buffer_writer.h:55
grpc
An Alarm posts the user-provided tag to its associated completion queue or invokes the user-provided ...
Definition: alarm.h:33
grpc::protobuf::io::ZeroCopyOutputStream
::google::protobuf::io::ZeroCopyOutputStream ZeroCopyOutputStream
Definition: config_protobuf.h:104
grpc::Slice::begin
const uint8_t * begin() const
Raw pointer to the beginning (first element) of the slice.
Definition: slice.h:102
GPR_ASSERT
#define GPR_ASSERT(x)
abort() the process if x is zero, having written a line to the log.
Definition: log.h:95
grpc::protobuf::io::ZeroCopyInputStream
::google::protobuf::io::ZeroCopyInputStream ZeroCopyInputStream
Definition: config_protobuf.h:105
status.h
grpc::Status::ok
bool ok() const
Is the status OK?
Definition: status.h:126
proto_buffer_reader.h
grpc::Slice::end
const uint8_t * end() const
Raw pointer to the end (one byte past the last element) of the slice.
Definition: slice.h:105
byte_buffer_reader.h
grpc_types.h
grpc::GenericSerialize
Status GenericSerialize(const grpc::protobuf::MessageLite &msg, ByteBuffer *bb, bool *own_buffer)
Definition: proto_utils.h:43
grpc::Status
Did it work? If it didn't, why?
Definition: status.h:35
log.h
grpc::ByteBuffer::Clear
void Clear()
Remove all data.
Definition: byte_buffer.h:128
grpc::ByteBuffer
A sequence of bytes.
Definition: byte_buffer.h:60
grpc::ByteBuffer::Swap
void Swap(ByteBuffer *other)
Swap the state of *this and *other.
Definition: byte_buffer.h:152
grpc::ProtoBufferReader
This is a specialization of the protobuf class ZeroCopyInputStream The principle is to get one chunk ...
Definition: proto_buffer_reader.h:47
proto_buffer_writer.h
grpc::GenericDeserialize
Status GenericDeserialize(ByteBuffer *buffer, grpc::protobuf::MessageLite *msg)
Definition: proto_utils.h:69
grpc::kProtoBufferWriterMaxBufferLength
const int kProtoBufferWriterMaxBufferLength
Definition: proto_buffer_writer.h:46
grpc::Slice
A wrapper around grpc_slice.
Definition: slice.h:33
grpc::ProtoBufferReader::status
Status status() const
Returns the status of the buffer reader.
Definition: proto_buffer_reader.h:95
serialization_traits.h
grpc::Status::OK
static const Status & OK
An OK pre-defined instance.
Definition: status.h:113
config_protobuf.h
slice.h
byte_buffer.h
std
Definition: async_unary_call.h:405
slice.h
grpc::protobuf::util::Status
::absl::Status Status
Definition: config_protobuf.h:97
GRPC_SLICE_INLINED_SIZE
#define GRPC_SLICE_INLINED_SIZE
Definition: slice_type.h:47
grpc::protobuf::MessageLite
::google::protobuf::MessageLite MessageLite
Definition: config_protobuf.h:83
grpc::INTERNAL
@ INTERNAL
Internal errors.
Definition: status_code_enum.h:121