xref: /aosp_15_r20/external/grpc-grpc/include/grpcpp/impl/serialization_traits.h (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
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_SERIALIZATION_TRAITS_H
20 #define GRPCPP_IMPL_SERIALIZATION_TRAITS_H
21 
22 namespace grpc {
23 
24 /// Defines how to serialize and deserialize some type.
25 ///
26 /// Used for hooking different message serialization API's into GRPC.
27 /// Each SerializationTraits<Message> implementation must provide the
28 /// following functions:
29 /// 1.  static Status Serialize(const Message& msg,
30 ///                             ByteBuffer* buffer,
31 ///                             bool* own_buffer);
32 ///     OR
33 ///     static Status Serialize(const Message& msg,
34 ///                             grpc_byte_buffer** buffer,
35 ///                             bool* own_buffer);
36 ///     The former is preferred; the latter is deprecated
37 ///
38 /// 2.  static Status Deserialize(ByteBuffer* buffer,
39 ///                               Message* msg);
40 ///     OR
41 ///     static Status Deserialize(grpc_byte_buffer* buffer,
42 ///                               Message* msg);
43 ///     The former is preferred; the latter is deprecated
44 ///
45 /// Serialize is required to convert message to a ByteBuffer, and
46 /// return that byte buffer through *buffer. *own_buffer should
47 /// be set to true if the caller owns said byte buffer, or false if
48 /// ownership is retained elsewhere.
49 ///
50 /// Deserialize is required to convert buffer into the message stored at
51 /// msg. max_receive_message_size is passed in as a bound on the maximum
52 /// number of message bytes Deserialize should accept.
53 ///
54 /// Both functions return a Status, allowing them to explain what went
55 /// wrong if required.
56 template <class Message,
57           class UnusedButHereForPartialTemplateSpecialization = void>
58 class SerializationTraits;
59 
60 }  // namespace grpc
61 
62 #endif  // GRPCPP_IMPL_SERIALIZATION_TRAITS_H
63