| Index: third_party/protobuf/src/google/protobuf/map_type_handler.h
|
| diff --git a/third_party/protobuf/src/google/protobuf/map_type_handler.h b/third_party/protobuf/src/google/protobuf/map_type_handler.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..ffdb6dfbaccf3add22470b5511d9e81f9156c5a6
|
| --- /dev/null
|
| +++ b/third_party/protobuf/src/google/protobuf/map_type_handler.h
|
| @@ -0,0 +1,516 @@
|
| +// Protocol Buffers - Google's data interchange format
|
| +// Copyright 2008 Google Inc. All rights reserved.
|
| +// https://developers.google.com/protocol-buffers/
|
| +//
|
| +// Redistribution and use in source and binary forms, with or without
|
| +// modification, are permitted provided that the following conditions are
|
| +// met:
|
| +//
|
| +// * Redistributions of source code must retain the above copyright
|
| +// notice, this list of conditions and the following disclaimer.
|
| +// * Redistributions in binary form must reproduce the above
|
| +// copyright notice, this list of conditions and the following disclaimer
|
| +// in the documentation and/or other materials provided with the
|
| +// distribution.
|
| +// * Neither the name of Google Inc. nor the names of its
|
| +// contributors may be used to endorse or promote products derived from
|
| +// this software without specific prior written permission.
|
| +//
|
| +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
| +// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
| +// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
| +// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
| +// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
| +// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
| +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
| +// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
| +// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
| +// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
| +// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
| +
|
| +#ifndef GOOGLE_PROTOBUF_TYPE_HANDLER_H__
|
| +#define GOOGLE_PROTOBUF_TYPE_HANDLER_H__
|
| +
|
| +#include <google/protobuf/arena.h>
|
| +#include <google/protobuf/generated_message_util.h>
|
| +#include <google/protobuf/wire_format_lite_inl.h>
|
| +
|
| +namespace google {
|
| +namespace protobuf {
|
| +namespace internal {
|
| +
|
| +// Used for compile time type selection. MapIf::type will be TrueType if Flag is
|
| +// true and FalseType otherwise.
|
| +template<bool Flag, typename TrueType, typename FalseType>
|
| +struct MapIf;
|
| +
|
| +template<typename TrueType, typename FalseType>
|
| +struct MapIf<true, TrueType, FalseType> {
|
| + typedef TrueType type;
|
| +};
|
| +
|
| +template<typename TrueType, typename FalseType>
|
| +struct MapIf<false, TrueType, FalseType> {
|
| + typedef FalseType type;
|
| +};
|
| +
|
| +// In MapField, string and message are stored as pointer while others are stored
|
| +// as object. However, google::protobuf::Map has unified api. Functions in this class
|
| +// convert key/value to type wanted in api regardless how it's stored
|
| +// internally.
|
| +template <typename Type>
|
| +class MapCommonTypeHandler {
|
| + public:
|
| + static inline Type& Reference(Type* x) { return *x; }
|
| + static inline Type& Reference(Type& x) { return x; }
|
| + static inline const Type& Reference(const Type& x) { return x; }
|
| + static inline Type* Pointer(Type* x) { return x; }
|
| + static inline Type* Pointer(Type& x) { return &x; }
|
| + static inline const Type* Pointer(const Type* x) { return x; }
|
| + static inline const Type* Pointer(const Type& x) { return &x; }
|
| +};
|
| +
|
| +// In proto2 Map, enum needs to be initialized to given default value, while
|
| +// other types' default value can be inferred from the type.
|
| +template <bool IsEnum, typename Type>
|
| +class MapValueInitializer {
|
| + public:
|
| + static inline void Initialize(Type& type, int default_enum_value);
|
| +};
|
| +
|
| +template <typename Type>
|
| +class MapValueInitializer<true, Type> {
|
| + public:
|
| + static inline void Initialize(Type& value, int default_enum_value) {
|
| + value = static_cast<Type>(default_enum_value);
|
| + }
|
| +};
|
| +
|
| +template <typename Type>
|
| +class MapValueInitializer<false, Type> {
|
| + public:
|
| + static inline void Initialize(Type& value, int default_enum_value) {}
|
| +};
|
| +
|
| +template <typename Type, bool is_arena_constructable>
|
| +class MapArenaMessageCreator {
|
| + public:
|
| + // Use arena to create message if Type is arena constructable. Otherwise,
|
| + // create the message on heap.
|
| + static inline Type* CreateMessage(Arena* arena);
|
| +};
|
| +template <typename Type>
|
| +class MapArenaMessageCreator<Type, true> {
|
| + public:
|
| + static inline Type* CreateMessage(Arena* arena) {
|
| + return Arena::CreateMessage<Type>(arena);
|
| + }
|
| +};
|
| +template <typename Type>
|
| +class MapArenaMessageCreator<Type, false> {
|
| + public:
|
| + static inline Type* CreateMessage(Arena* arena) {
|
| + return new Type;
|
| + }
|
| +};
|
| +
|
| +// Handlers for key/value stored type in MapField. ==================
|
| +
|
| +// Handler for message
|
| +template <typename Type>
|
| +class MapCppTypeHandler : public MapCommonTypeHandler<Type> {
|
| + public:
|
| + static const bool kIsStringOrMessage = true;
|
| + // SpaceUsedInMapEntry: Return bytes used by value in MapEntry, excluding
|
| + // those already calculate in sizeof(MapField).
|
| + static int SpaceUsedInMapEntry(const Type* value) {
|
| + return value->SpaceUsed();
|
| + }
|
| + // Return bytes used by value in Map.
|
| + static int SpaceUsedInMap(const Type& value) { return value.SpaceUsed(); }
|
| + static inline void Clear(Type** value) {
|
| + if (*value != NULL) (*value)->Clear();
|
| + }
|
| + static inline void ClearMaybeByDefaultEnum(Type** value,
|
| + int default_enum_value) {
|
| + if (*value != NULL) (*value)->Clear();
|
| + }
|
| + static inline void Merge(const Type& from, Type** to) {
|
| + (*to)->MergeFrom(from);
|
| + }
|
| +
|
| + static void Delete(const Type* ptr) { delete ptr; }
|
| +
|
| + // Assign default value to given instance.
|
| + static inline void AssignDefaultValue(Type** value) {
|
| + *value = const_cast<Type*>(&Type::default_instance());
|
| + }
|
| + // Initialize value when constructing MapEntry
|
| + static inline void Initialize(Type** x, Arena* arena) { *x = NULL; }
|
| + // Same as above, but use default_enum_value to initialize enum type value.
|
| + static inline void InitializeMaybeByDefaultEnum(
|
| + Type** x, int default_enum_value, Arena* arena) {
|
| + *x = NULL;
|
| + }
|
| + // Initialize value for the first time mutable accessor is called.
|
| + static inline void EnsureMutable(Type** value, Arena* arena) {
|
| + if (*value == NULL) {
|
| + *value =
|
| + MapArenaMessageCreator<Type, Arena::is_arena_constructable<Type>::
|
| + type::value>::CreateMessage(arena);
|
| + }
|
| + }
|
| + // Return default instance if value is not initialized when calling const
|
| + // reference accessor.
|
| + static inline const Type& DefaultIfNotInitialized(const Type* value,
|
| + const Type* default_value) {
|
| + return value != NULL ? *value : *default_value;
|
| + }
|
| + // Check if all required fields have values set.
|
| + static inline bool IsInitialized(Type* value) {
|
| + return value->IsInitialized();
|
| + }
|
| +};
|
| +
|
| +// Handler for string.
|
| +template <>
|
| +class MapCppTypeHandler<string> : public MapCommonTypeHandler<string> {
|
| + public:
|
| + static const bool kIsStringOrMessage = true;
|
| + static inline void Merge(const string& from, string** to) { **to = from; }
|
| + static inline void Clear(string** value) { (*value)->clear(); }
|
| + static inline void ClearMaybeByDefaultEnum(string** value, int default_enum) {
|
| + (*value)->clear();
|
| + }
|
| + static inline int SpaceUsedInMapEntry(const string* value) {
|
| + return sizeof(*value) + StringSpaceUsedExcludingSelf(*value);
|
| + }
|
| + static inline int SpaceUsedInMap(const string& value) {
|
| + return sizeof(value) + StringSpaceUsedExcludingSelf(value);
|
| + }
|
| + static void Delete(const string* ptr) {
|
| + if (ptr != &::google::protobuf::internal::GetEmptyString()) delete ptr;
|
| + }
|
| + static inline void AssignDefaultValue(string** value) {}
|
| + static inline void Initialize(string** value, Arena* arena) {
|
| + *value = const_cast< ::std::string*>(&::google::protobuf::internal::GetEmptyString());
|
| + if (arena != NULL) arena->Own(*value);
|
| + }
|
| + static inline void InitializeMaybeByDefaultEnum(
|
| + string** value, int default_enum_value, Arena* arena) {
|
| + *value = const_cast< ::std::string*>(&::google::protobuf::internal::GetEmptyString());
|
| + if (arena != NULL) arena->Own(*value);
|
| + }
|
| + static inline void EnsureMutable(string** value, Arena* arena) {
|
| + if (*value == &::google::protobuf::internal::GetEmptyString()) {
|
| + *value = Arena::Create<string>(arena);
|
| + }
|
| + }
|
| + static inline const string& DefaultIfNotInitialized(
|
| + const string* value,
|
| + const string* default_value) {
|
| + return value != default_value ? *value : *default_value;
|
| + }
|
| + static inline bool IsInitialized(string* value) { return true; }
|
| +};
|
| +
|
| +// Base class for primitive type handlers.
|
| +template <typename Type>
|
| +class MapPrimitiveTypeHandler : public MapCommonTypeHandler<Type> {
|
| + public:
|
| + static const bool kIsStringOrMessage = false;
|
| + static inline void Delete(const Type& x) {}
|
| + static inline void Merge(const Type& from, Type* to) { *to = from; }
|
| + static inline int SpaceUsedInMapEntry(const Type& value) { return 0; }
|
| + static inline int SpaceUsedInMap(const Type& value) { return sizeof(Type); }
|
| + static inline void AssignDefaultValue(Type* value) {}
|
| + static inline const Type& DefaultIfNotInitialized(
|
| + const Type& value, const Type& default_value) {
|
| + return value;
|
| + }
|
| + static inline bool IsInitialized(const Type& value) { return true; }
|
| +};
|
| +
|
| +// Handlers for primitive types.
|
| +#define PRIMITIVE_HANDLER(CType) \
|
| + template <> \
|
| + class MapCppTypeHandler<CType> : public MapPrimitiveTypeHandler<CType> { \
|
| + public: \
|
| + static inline void Clear(CType* value) { *value = 0; } \
|
| + static inline void ClearMaybeByDefaultEnum(CType* value, \
|
| + int default_enum_value) { \
|
| + *value = static_cast<CType>(default_enum_value); \
|
| + } \
|
| + static inline void Initialize(CType* value, Arena* arena) { *value = 0; } \
|
| + static inline void InitializeMaybeByDefaultEnum(CType* value, \
|
| + int default_enum_value, \
|
| + Arena* arena) { \
|
| + *value = static_cast<CType>(default_enum_value); \
|
| + } \
|
| + static inline void EnsureMutable(CType* value, Arena* arena) {} \
|
| + };
|
| +
|
| +PRIMITIVE_HANDLER(int32 )
|
| +PRIMITIVE_HANDLER(int64 )
|
| +PRIMITIVE_HANDLER(uint32)
|
| +PRIMITIVE_HANDLER(uint64)
|
| +PRIMITIVE_HANDLER(double)
|
| +PRIMITIVE_HANDLER(float )
|
| +PRIMITIVE_HANDLER(bool )
|
| +
|
| +#undef PRIMITIVE_HANDLER
|
| +
|
| +// Define constants for given wire field type
|
| +template <WireFormatLite::FieldType field_type>
|
| +class MapWireFieldTypeTraits {};
|
| +
|
| +#define TYPE_TRAITS(FieldType, CType, WireFormatType, IsMessage, IsEnum) \
|
| + template <> \
|
| + class MapWireFieldTypeTraits<WireFormatLite::TYPE_##FieldType> { \
|
| + public: \
|
| + typedef CType CppType; \
|
| + static const bool kIsMessage = IsMessage; \
|
| + static const bool kIsEnum = IsEnum; \
|
| + static const WireFormatLite::WireType kWireType = \
|
| + WireFormatLite::WIRETYPE_##WireFormatType; \
|
| + };
|
| +
|
| +TYPE_TRAITS(MESSAGE , MessageLite, LENGTH_DELIMITED, true, false)
|
| +TYPE_TRAITS(STRING , string , LENGTH_DELIMITED, false, false)
|
| +TYPE_TRAITS(BYTES , string , LENGTH_DELIMITED, false, false)
|
| +TYPE_TRAITS(INT64 , int64 , VARINT , false, false)
|
| +TYPE_TRAITS(UINT64 , uint64 , VARINT , false, false)
|
| +TYPE_TRAITS(INT32 , int32 , VARINT , false, false)
|
| +TYPE_TRAITS(UINT32 , uint32 , VARINT , false, false)
|
| +TYPE_TRAITS(SINT64 , int64 , VARINT , false, false)
|
| +TYPE_TRAITS(SINT32 , int32 , VARINT , false, false)
|
| +TYPE_TRAITS(ENUM , int , VARINT , false, true )
|
| +TYPE_TRAITS(DOUBLE , double , FIXED64, false, false)
|
| +TYPE_TRAITS(FLOAT , float , FIXED32, false, false)
|
| +TYPE_TRAITS(FIXED64 , uint64 , FIXED64, false, false)
|
| +TYPE_TRAITS(FIXED32 , uint32 , FIXED32, false, false)
|
| +TYPE_TRAITS(SFIXED64, int64 , FIXED64, false, false)
|
| +TYPE_TRAITS(SFIXED32, int32 , FIXED32, false, false)
|
| +TYPE_TRAITS(BOOL , bool , VARINT , false, false)
|
| +
|
| +#undef TYPE_TRAITS
|
| +
|
| +template <WireFormatLite::FieldType field_type>
|
| +class MapWireFieldTypeHandler {
|
| + public:
|
| + // Internal stored type in MapEntryLite for given wire field type.
|
| + typedef typename MapWireFieldTypeTraits<field_type>::CppType CppType;
|
| + // Corresponding wire type for field type.
|
| + static const WireFormatLite::WireType kWireType =
|
| + MapWireFieldTypeTraits<field_type>::kWireType;
|
| + // Whether wire type is for message.
|
| + static const bool kIsMessage = MapWireFieldTypeTraits<field_type>::kIsMessage;
|
| + // Whether wire type is for enum.
|
| + static const bool kIsEnum = MapWireFieldTypeTraits<field_type>::kIsEnum;
|
| +
|
| + // Functions used in parsing and serialization. ===================
|
| + template <typename ValueType>
|
| + static inline int ByteSize(const ValueType& value);
|
| + template <typename ValueType>
|
| + static inline int GetCachedSize(const ValueType& value);
|
| + template <typename ValueType>
|
| + static inline bool Read(io::CodedInputStream* input, ValueType* value);
|
| + static inline void Write(int field, const CppType& value,
|
| + io::CodedOutputStream* output);
|
| + static inline uint8* WriteToArray(int field, const CppType& value,
|
| + uint8* output);
|
| +};
|
| +
|
| +template <>
|
| +template <typename ValueType>
|
| +inline int MapWireFieldTypeHandler<WireFormatLite::TYPE_MESSAGE>::ByteSize(
|
| + const ValueType& value) {
|
| + return WireFormatLite::MessageSizeNoVirtual(value);
|
| +}
|
| +
|
| +#define BYTE_SIZE(FieldType, DeclaredType) \
|
| + template <> \
|
| + template <typename ValueType> \
|
| + inline int \
|
| + MapWireFieldTypeHandler<WireFormatLite::TYPE_##FieldType>::ByteSize( \
|
| + const ValueType& value) { \
|
| + return WireFormatLite::DeclaredType##Size(value); \
|
| + }
|
| +
|
| +BYTE_SIZE(STRING, String)
|
| +BYTE_SIZE(BYTES , Bytes)
|
| +BYTE_SIZE(INT64 , Int64)
|
| +BYTE_SIZE(UINT64, UInt64)
|
| +BYTE_SIZE(INT32 , Int32)
|
| +BYTE_SIZE(UINT32, UInt32)
|
| +BYTE_SIZE(SINT64, SInt64)
|
| +BYTE_SIZE(SINT32, SInt32)
|
| +BYTE_SIZE(ENUM , Enum)
|
| +
|
| +#undef BYTE_SIZE
|
| +
|
| +#define FIXED_BYTE_SIZE(FieldType, DeclaredType) \
|
| + template <> \
|
| + template <typename ValueType> \
|
| + inline int \
|
| + MapWireFieldTypeHandler<WireFormatLite::TYPE_##FieldType>::ByteSize( \
|
| + const ValueType& value) { \
|
| + return WireFormatLite::k##DeclaredType##Size; \
|
| + }
|
| +
|
| +FIXED_BYTE_SIZE(DOUBLE , Double)
|
| +FIXED_BYTE_SIZE(FLOAT , Float)
|
| +FIXED_BYTE_SIZE(FIXED64 , Fixed64)
|
| +FIXED_BYTE_SIZE(FIXED32 , Fixed32)
|
| +FIXED_BYTE_SIZE(SFIXED64, SFixed64)
|
| +FIXED_BYTE_SIZE(SFIXED32, SFixed32)
|
| +FIXED_BYTE_SIZE(BOOL , Bool)
|
| +
|
| +#undef FIXED_BYTE_SIZE
|
| +
|
| +template <>
|
| +template <typename ValueType>
|
| +inline int MapWireFieldTypeHandler<
|
| + WireFormatLite::TYPE_MESSAGE>::GetCachedSize(const ValueType& value) {
|
| + return WireFormatLite::LengthDelimitedSize(value.GetCachedSize());
|
| +}
|
| +
|
| +#define GET_CACHED_SIZE(FieldType, DeclaredType) \
|
| + template <> \
|
| + template <typename ValueType> \
|
| + inline int \
|
| + MapWireFieldTypeHandler<WireFormatLite::TYPE_##FieldType>::GetCachedSize( \
|
| + const ValueType& value) { \
|
| + return WireFormatLite::DeclaredType##Size(value); \
|
| + }
|
| +
|
| +GET_CACHED_SIZE(STRING, String)
|
| +GET_CACHED_SIZE(BYTES , Bytes)
|
| +GET_CACHED_SIZE(INT64 , Int64)
|
| +GET_CACHED_SIZE(UINT64, UInt64)
|
| +GET_CACHED_SIZE(INT32 , Int32)
|
| +GET_CACHED_SIZE(UINT32, UInt32)
|
| +GET_CACHED_SIZE(SINT64, SInt64)
|
| +GET_CACHED_SIZE(SINT32, SInt32)
|
| +GET_CACHED_SIZE(ENUM , Enum)
|
| +
|
| +#undef GET_CACHED_SIZE
|
| +
|
| +#define GET_FIXED_CACHED_SIZE(FieldType, DeclaredType) \
|
| + template <> \
|
| + template <typename ValueType> \
|
| + inline int \
|
| + MapWireFieldTypeHandler<WireFormatLite::TYPE_##FieldType>::GetCachedSize( \
|
| + const ValueType& value) { \
|
| + return WireFormatLite::k##DeclaredType##Size; \
|
| + }
|
| +
|
| +GET_FIXED_CACHED_SIZE(DOUBLE , Double)
|
| +GET_FIXED_CACHED_SIZE(FLOAT , Float)
|
| +GET_FIXED_CACHED_SIZE(FIXED64 , Fixed64)
|
| +GET_FIXED_CACHED_SIZE(FIXED32 , Fixed32)
|
| +GET_FIXED_CACHED_SIZE(SFIXED64, SFixed64)
|
| +GET_FIXED_CACHED_SIZE(SFIXED32, SFixed32)
|
| +GET_FIXED_CACHED_SIZE(BOOL , Bool)
|
| +
|
| +#undef GET_FIXED_CACHED_SIZE
|
| +
|
| +template <>
|
| +inline void MapWireFieldTypeHandler<WireFormatLite::TYPE_MESSAGE>::Write(
|
| + int field, const MessageLite& value, io::CodedOutputStream* output) {
|
| + WireFormatLite::WriteMessageMaybeToArray(field, value, output);
|
| +}
|
| +
|
| +template <>
|
| +inline uint8*
|
| +MapWireFieldTypeHandler<WireFormatLite::TYPE_MESSAGE>::WriteToArray(
|
| + int field, const MessageLite& value, uint8* output) {
|
| + return WireFormatLite::WriteMessageToArray(field, value, output);
|
| +}
|
| +
|
| +#define WRITE_METHOD(FieldType, DeclaredType) \
|
| + template <> \
|
| + inline void \
|
| + MapWireFieldTypeHandler<WireFormatLite::TYPE_##FieldType>::Write( \
|
| + int field, const CppType& value, io::CodedOutputStream* output) { \
|
| + return WireFormatLite::Write##DeclaredType(field, value, output); \
|
| + } \
|
| + template <> \
|
| + inline uint8* \
|
| + MapWireFieldTypeHandler<WireFormatLite::TYPE_##FieldType>::WriteToArray( \
|
| + int field, const CppType& value, uint8* output) { \
|
| + return WireFormatLite::Write##DeclaredType##ToArray(field, value, output); \
|
| + }
|
| +
|
| +WRITE_METHOD(STRING , String)
|
| +WRITE_METHOD(BYTES , Bytes)
|
| +WRITE_METHOD(INT64 , Int64)
|
| +WRITE_METHOD(UINT64 , UInt64)
|
| +WRITE_METHOD(INT32 , Int32)
|
| +WRITE_METHOD(UINT32 , UInt32)
|
| +WRITE_METHOD(SINT64 , SInt64)
|
| +WRITE_METHOD(SINT32 , SInt32)
|
| +WRITE_METHOD(ENUM , Enum)
|
| +WRITE_METHOD(DOUBLE , Double)
|
| +WRITE_METHOD(FLOAT , Float)
|
| +WRITE_METHOD(FIXED64 , Fixed64)
|
| +WRITE_METHOD(FIXED32 , Fixed32)
|
| +WRITE_METHOD(SFIXED64, SFixed64)
|
| +WRITE_METHOD(SFIXED32, SFixed32)
|
| +WRITE_METHOD(BOOL , Bool)
|
| +
|
| +#undef WRITE_METHOD
|
| +
|
| +template <>
|
| +template <typename ValueType>
|
| +inline bool MapWireFieldTypeHandler<WireFormatLite::TYPE_MESSAGE>::Read(
|
| + io::CodedInputStream* input, ValueType* value) {
|
| + return WireFormatLite::ReadMessageNoVirtual(input, value);
|
| +}
|
| +
|
| +template <>
|
| +template <typename ValueType>
|
| +inline bool MapWireFieldTypeHandler<WireFormatLite::TYPE_STRING>::Read(
|
| + io::CodedInputStream* input, ValueType* value) {
|
| + return WireFormatLite::ReadString(input, value);
|
| +}
|
| +
|
| +template <>
|
| +template <typename ValueType>
|
| +inline bool MapWireFieldTypeHandler<WireFormatLite::TYPE_BYTES>::Read(
|
| + io::CodedInputStream* input, ValueType* value) {
|
| + return WireFormatLite::ReadBytes(input, value);
|
| +}
|
| +
|
| +#define READ_METHOD(FieldType) \
|
| + template <> \
|
| + template <typename ValueType> \
|
| + inline bool MapWireFieldTypeHandler<WireFormatLite::TYPE_##FieldType>::Read( \
|
| + io::CodedInputStream* input, ValueType* value) { \
|
| + return WireFormatLite::ReadPrimitive<CppType, \
|
| + WireFormatLite::TYPE_##FieldType>( \
|
| + input, value); \
|
| + }
|
| +
|
| +READ_METHOD(INT64)
|
| +READ_METHOD(UINT64)
|
| +READ_METHOD(INT32)
|
| +READ_METHOD(UINT32)
|
| +READ_METHOD(SINT64)
|
| +READ_METHOD(SINT32)
|
| +READ_METHOD(ENUM)
|
| +READ_METHOD(DOUBLE)
|
| +READ_METHOD(FLOAT)
|
| +READ_METHOD(FIXED64)
|
| +READ_METHOD(FIXED32)
|
| +READ_METHOD(SFIXED64)
|
| +READ_METHOD(SFIXED32)
|
| +READ_METHOD(BOOL)
|
| +
|
| +#undef READ_METHOD
|
| +
|
| +} // namespace internal
|
| +} // namespace protobuf
|
| +
|
| +} // namespace google
|
| +#endif // GOOGLE_PROTOBUF_TYPE_HANDLER_H__
|
|
|