Protocol Buffers - Google's data interchange format (grpc依赖)
https://developers.google.com/protocol-buffers/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
104 lines
3.5 KiB
104 lines
3.5 KiB
// Generated by the protocol buffer compiler. DO NOT EDIT! |
|
// clang-format off |
|
// source: google/protobuf/timestamp.proto |
|
|
|
#import "GPBProtocolBuffers_RuntimeSupport.h" |
|
#import "GPBTimestamp.pbobjc.h" |
|
|
|
#if GOOGLE_PROTOBUF_OBJC_VERSION < 30007 |
|
#error This file was generated by a newer version of protoc which is incompatible with your Protocol Buffer library sources. |
|
#endif |
|
#if 30007 < GOOGLE_PROTOBUF_OBJC_MIN_SUPPORTED_VERSION |
|
#error This file was generated by an older version of protoc which is incompatible with your Protocol Buffer library sources. |
|
#endif |
|
|
|
// @@protoc_insertion_point(imports) |
|
|
|
#pragma clang diagnostic push |
|
#pragma clang diagnostic ignored "-Wdeprecated-declarations" |
|
#pragma clang diagnostic ignored "-Wdollar-in-identifier-extension" |
|
|
|
#pragma mark - Objective C Class declarations |
|
// Forward declarations of Objective C classes that we can use as |
|
// static values in struct initializers. |
|
// We don't use [Foo class] because it is not a static value. |
|
GPBObjCClassDeclaration(GPBTimestamp); |
|
|
|
#pragma mark - GPBTimestampRoot |
|
|
|
@implementation GPBTimestampRoot |
|
|
|
// No extensions in the file and no imports, so no need to generate |
|
// +extensionRegistry. |
|
|
|
@end |
|
|
|
static GPBFileDescription GPBTimestampRoot_FileDescription = { |
|
.package = "google.protobuf", |
|
.prefix = "GPB", |
|
.syntax = GPBFileSyntaxProto3 |
|
}; |
|
|
|
#pragma mark - GPBTimestamp |
|
|
|
@implementation GPBTimestamp |
|
|
|
@dynamic seconds; |
|
@dynamic nanos; |
|
|
|
typedef struct GPBTimestamp__storage_ { |
|
uint32_t _has_storage_[1]; |
|
int32_t nanos; |
|
int64_t seconds; |
|
} GPBTimestamp__storage_; |
|
|
|
// This method is threadsafe because it is initially called |
|
// in +initialize for each subclass. |
|
+ (GPBDescriptor *)descriptor { |
|
static GPBDescriptor *descriptor = nil; |
|
if (!descriptor) { |
|
GPB_DEBUG_CHECK_RUNTIME_VERSIONS(); |
|
static GPBMessageFieldDescription fields[] = { |
|
{ |
|
.name = "seconds", |
|
.dataTypeSpecific.clazz = Nil, |
|
.number = GPBTimestamp_FieldNumber_Seconds, |
|
.hasIndex = 0, |
|
.offset = (uint32_t)offsetof(GPBTimestamp__storage_, seconds), |
|
.flags = (GPBFieldFlags)(GPBFieldOptional | GPBFieldClearHasIvarOnZero), |
|
.dataType = GPBDataTypeInt64, |
|
}, |
|
{ |
|
.name = "nanos", |
|
.dataTypeSpecific.clazz = Nil, |
|
.number = GPBTimestamp_FieldNumber_Nanos, |
|
.hasIndex = 1, |
|
.offset = (uint32_t)offsetof(GPBTimestamp__storage_, nanos), |
|
.flags = (GPBFieldFlags)(GPBFieldOptional | GPBFieldClearHasIvarOnZero), |
|
.dataType = GPBDataTypeInt32, |
|
}, |
|
}; |
|
GPBDescriptor *localDescriptor = |
|
[GPBDescriptor allocDescriptorForClass:GPBObjCClass(GPBTimestamp) |
|
messageName:@"Timestamp" |
|
fileDescription:&GPBTimestampRoot_FileDescription |
|
fields:fields |
|
fieldCount:(uint32_t)(sizeof(fields) / sizeof(GPBMessageFieldDescription)) |
|
storageSize:sizeof(GPBTimestamp__storage_) |
|
flags:(GPBDescriptorInitializationFlags)(GPBDescriptorInitializationFlag_UsesClassRefs | GPBDescriptorInitializationFlag_Proto3OptionalKnown | GPBDescriptorInitializationFlag_ClosedEnumSupportKnown)]; |
|
#if defined(DEBUG) && DEBUG |
|
NSAssert(descriptor == nil, @"Startup recursed!"); |
|
#endif // DEBUG |
|
descriptor = localDescriptor; |
|
} |
|
return descriptor; |
|
} |
|
|
|
@end |
|
|
|
|
|
#pragma clang diagnostic pop |
|
|
|
// @@protoc_insertion_point(global_scope) |
|
|
|
// clang-format on
|
|
|