1*cc02d7e2SAndroid Build Coastguard Worker // 2*cc02d7e2SAndroid Build Coastguard Worker // 3*cc02d7e2SAndroid Build Coastguard Worker // Copyright 2015 gRPC authors. 4*cc02d7e2SAndroid Build Coastguard Worker // 5*cc02d7e2SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); 6*cc02d7e2SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License. 7*cc02d7e2SAndroid Build Coastguard Worker // You may obtain a copy of the License at 8*cc02d7e2SAndroid Build Coastguard Worker // 9*cc02d7e2SAndroid Build Coastguard Worker // http://www.apache.org/licenses/LICENSE-2.0 10*cc02d7e2SAndroid Build Coastguard Worker // 11*cc02d7e2SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 12*cc02d7e2SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, 13*cc02d7e2SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*cc02d7e2SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and 15*cc02d7e2SAndroid Build Coastguard Worker // limitations under the License. 16*cc02d7e2SAndroid Build Coastguard Worker // 17*cc02d7e2SAndroid Build Coastguard Worker // 18*cc02d7e2SAndroid Build Coastguard Worker 19*cc02d7e2SAndroid Build Coastguard Worker #ifndef GRPCPP_IMPL_SERIALIZATION_TRAITS_H 20*cc02d7e2SAndroid Build Coastguard Worker #define GRPCPP_IMPL_SERIALIZATION_TRAITS_H 21*cc02d7e2SAndroid Build Coastguard Worker 22*cc02d7e2SAndroid Build Coastguard Worker namespace grpc { 23*cc02d7e2SAndroid Build Coastguard Worker 24*cc02d7e2SAndroid Build Coastguard Worker /// Defines how to serialize and deserialize some type. 25*cc02d7e2SAndroid Build Coastguard Worker /// 26*cc02d7e2SAndroid Build Coastguard Worker /// Used for hooking different message serialization API's into GRPC. 27*cc02d7e2SAndroid Build Coastguard Worker /// Each SerializationTraits<Message> implementation must provide the 28*cc02d7e2SAndroid Build Coastguard Worker /// following functions: 29*cc02d7e2SAndroid Build Coastguard Worker /// 1. static Status Serialize(const Message& msg, 30*cc02d7e2SAndroid Build Coastguard Worker /// ByteBuffer* buffer, 31*cc02d7e2SAndroid Build Coastguard Worker /// bool* own_buffer); 32*cc02d7e2SAndroid Build Coastguard Worker /// OR 33*cc02d7e2SAndroid Build Coastguard Worker /// static Status Serialize(const Message& msg, 34*cc02d7e2SAndroid Build Coastguard Worker /// grpc_byte_buffer** buffer, 35*cc02d7e2SAndroid Build Coastguard Worker /// bool* own_buffer); 36*cc02d7e2SAndroid Build Coastguard Worker /// The former is preferred; the latter is deprecated 37*cc02d7e2SAndroid Build Coastguard Worker /// 38*cc02d7e2SAndroid Build Coastguard Worker /// 2. static Status Deserialize(ByteBuffer* buffer, 39*cc02d7e2SAndroid Build Coastguard Worker /// Message* msg); 40*cc02d7e2SAndroid Build Coastguard Worker /// OR 41*cc02d7e2SAndroid Build Coastguard Worker /// static Status Deserialize(grpc_byte_buffer* buffer, 42*cc02d7e2SAndroid Build Coastguard Worker /// Message* msg); 43*cc02d7e2SAndroid Build Coastguard Worker /// The former is preferred; the latter is deprecated 44*cc02d7e2SAndroid Build Coastguard Worker /// 45*cc02d7e2SAndroid Build Coastguard Worker /// Serialize is required to convert message to a ByteBuffer, and 46*cc02d7e2SAndroid Build Coastguard Worker /// return that byte buffer through *buffer. *own_buffer should 47*cc02d7e2SAndroid Build Coastguard Worker /// be set to true if the caller owns said byte buffer, or false if 48*cc02d7e2SAndroid Build Coastguard Worker /// ownership is retained elsewhere. 49*cc02d7e2SAndroid Build Coastguard Worker /// 50*cc02d7e2SAndroid Build Coastguard Worker /// Deserialize is required to convert buffer into the message stored at 51*cc02d7e2SAndroid Build Coastguard Worker /// msg. max_receive_message_size is passed in as a bound on the maximum 52*cc02d7e2SAndroid Build Coastguard Worker /// number of message bytes Deserialize should accept. 53*cc02d7e2SAndroid Build Coastguard Worker /// 54*cc02d7e2SAndroid Build Coastguard Worker /// Both functions return a Status, allowing them to explain what went 55*cc02d7e2SAndroid Build Coastguard Worker /// wrong if required. 56*cc02d7e2SAndroid Build Coastguard Worker template <class Message, 57*cc02d7e2SAndroid Build Coastguard Worker class UnusedButHereForPartialTemplateSpecialization = void> 58*cc02d7e2SAndroid Build Coastguard Worker class SerializationTraits; 59*cc02d7e2SAndroid Build Coastguard Worker 60*cc02d7e2SAndroid Build Coastguard Worker } // namespace grpc 61*cc02d7e2SAndroid Build Coastguard Worker 62*cc02d7e2SAndroid Build Coastguard Worker #endif // GRPCPP_IMPL_SERIALIZATION_TRAITS_H 63