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_CODEGEN_SERIALIZATION_TRAITS_H
20 #define GRPCPP_IMPL_CODEGEN_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_CODEGEN_SERIALIZATION_TRAITS_H
63