Type.pbobjc.m 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701
  1. // Generated by the protocol buffer compiler. DO NOT EDIT!
  2. // source: google/protobuf/type.proto
  3. // This CPP symbol can be defined to use imports that match up to the framework
  4. // imports needed when using CocoaPods.
  5. #if !defined(GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS)
  6. #define GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS 0
  7. #endif
  8. #if GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS
  9. #import <Protobuf/GPBProtocolBuffers_RuntimeSupport.h>
  10. #else
  11. #import "GPBProtocolBuffers_RuntimeSupport.h"
  12. #endif
  13. #if GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS
  14. #import <Protobuf/Type.pbobjc.h>
  15. #import <Protobuf/Any.pbobjc.h>
  16. #import <Protobuf/SourceContext.pbobjc.h>
  17. #else
  18. #import "google/protobuf/Type.pbobjc.h"
  19. #import "google/protobuf/Any.pbobjc.h"
  20. #import "google/protobuf/SourceContext.pbobjc.h"
  21. #endif
  22. // @@protoc_insertion_point(imports)
  23. #pragma clang diagnostic push
  24. #pragma clang diagnostic ignored "-Wdeprecated-declarations"
  25. #pragma mark - GPBTypeRoot
  26. @implementation GPBTypeRoot
  27. // No extensions in the file and none of the imports (direct or indirect)
  28. // defined extensions, so no need to generate +extensionRegistry.
  29. @end
  30. #pragma mark - GPBTypeRoot_FileDescriptor
  31. static GPBFileDescriptor *GPBTypeRoot_FileDescriptor(void) {
  32. // This is called by +initialize so there is no need to worry
  33. // about thread safety of the singleton.
  34. static GPBFileDescriptor *descriptor = NULL;
  35. if (!descriptor) {
  36. GPBDebugCheckRuntimeVersion();
  37. descriptor = [[GPBFileDescriptor alloc] initWithPackage:@"google.protobuf"
  38. objcPrefix:@"GPB"
  39. syntax:GPBFileSyntaxProto3];
  40. }
  41. return descriptor;
  42. }
  43. #pragma mark - Enum GPBSyntax
  44. GPBEnumDescriptor *GPBSyntax_EnumDescriptor(void) {
  45. static GPBEnumDescriptor *descriptor = NULL;
  46. if (!descriptor) {
  47. static const char *valueNames =
  48. "SyntaxProto2\000SyntaxProto3\000";
  49. static const int32_t values[] = {
  50. GPBSyntax_SyntaxProto2,
  51. GPBSyntax_SyntaxProto3,
  52. };
  53. GPBEnumDescriptor *worker =
  54. [GPBEnumDescriptor allocDescriptorForName:GPBNSStringifySymbol(GPBSyntax)
  55. valueNames:valueNames
  56. values:values
  57. count:(uint32_t)(sizeof(values) / sizeof(int32_t))
  58. enumVerifier:GPBSyntax_IsValidValue];
  59. if (!OSAtomicCompareAndSwapPtrBarrier(nil, worker, (void * volatile *)&descriptor)) {
  60. [worker release];
  61. }
  62. }
  63. return descriptor;
  64. }
  65. BOOL GPBSyntax_IsValidValue(int32_t value__) {
  66. switch (value__) {
  67. case GPBSyntax_SyntaxProto2:
  68. case GPBSyntax_SyntaxProto3:
  69. return YES;
  70. default:
  71. return NO;
  72. }
  73. }
  74. #pragma mark - GPBType
  75. @implementation GPBType
  76. @dynamic name;
  77. @dynamic fieldsArray, fieldsArray_Count;
  78. @dynamic oneofsArray, oneofsArray_Count;
  79. @dynamic optionsArray, optionsArray_Count;
  80. @dynamic hasSourceContext, sourceContext;
  81. @dynamic syntax;
  82. typedef struct GPBType__storage_ {
  83. uint32_t _has_storage_[1];
  84. GPBSyntax syntax;
  85. NSString *name;
  86. NSMutableArray *fieldsArray;
  87. NSMutableArray *oneofsArray;
  88. NSMutableArray *optionsArray;
  89. GPBSourceContext *sourceContext;
  90. } GPBType__storage_;
  91. // This method is threadsafe because it is initially called
  92. // in +initialize for each subclass.
  93. + (GPBDescriptor *)descriptor {
  94. static GPBDescriptor *descriptor = nil;
  95. if (!descriptor) {
  96. static GPBMessageFieldDescription fields[] = {
  97. {
  98. .name = "name",
  99. .dataTypeSpecific.className = NULL,
  100. .number = GPBType_FieldNumber_Name,
  101. .hasIndex = 0,
  102. .offset = (uint32_t)offsetof(GPBType__storage_, name),
  103. .flags = GPBFieldOptional,
  104. .dataType = GPBDataTypeString,
  105. },
  106. {
  107. .name = "fieldsArray",
  108. .dataTypeSpecific.className = GPBStringifySymbol(GPBField),
  109. .number = GPBType_FieldNumber_FieldsArray,
  110. .hasIndex = GPBNoHasBit,
  111. .offset = (uint32_t)offsetof(GPBType__storage_, fieldsArray),
  112. .flags = GPBFieldRepeated,
  113. .dataType = GPBDataTypeMessage,
  114. },
  115. {
  116. .name = "oneofsArray",
  117. .dataTypeSpecific.className = NULL,
  118. .number = GPBType_FieldNumber_OneofsArray,
  119. .hasIndex = GPBNoHasBit,
  120. .offset = (uint32_t)offsetof(GPBType__storage_, oneofsArray),
  121. .flags = GPBFieldRepeated,
  122. .dataType = GPBDataTypeString,
  123. },
  124. {
  125. .name = "optionsArray",
  126. .dataTypeSpecific.className = GPBStringifySymbol(GPBOption),
  127. .number = GPBType_FieldNumber_OptionsArray,
  128. .hasIndex = GPBNoHasBit,
  129. .offset = (uint32_t)offsetof(GPBType__storage_, optionsArray),
  130. .flags = GPBFieldRepeated,
  131. .dataType = GPBDataTypeMessage,
  132. },
  133. {
  134. .name = "sourceContext",
  135. .dataTypeSpecific.className = GPBStringifySymbol(GPBSourceContext),
  136. .number = GPBType_FieldNumber_SourceContext,
  137. .hasIndex = 1,
  138. .offset = (uint32_t)offsetof(GPBType__storage_, sourceContext),
  139. .flags = GPBFieldOptional,
  140. .dataType = GPBDataTypeMessage,
  141. },
  142. {
  143. .name = "syntax",
  144. .dataTypeSpecific.enumDescFunc = GPBSyntax_EnumDescriptor,
  145. .number = GPBType_FieldNumber_Syntax,
  146. .hasIndex = 2,
  147. .offset = (uint32_t)offsetof(GPBType__storage_, syntax),
  148. .flags = GPBFieldOptional | GPBFieldHasEnumDescriptor,
  149. .dataType = GPBDataTypeEnum,
  150. },
  151. };
  152. GPBDescriptor *localDescriptor =
  153. [GPBDescriptor allocDescriptorForClass:[GPBType class]
  154. rootClass:[GPBTypeRoot class]
  155. file:GPBTypeRoot_FileDescriptor()
  156. fields:fields
  157. fieldCount:(uint32_t)(sizeof(fields) / sizeof(GPBMessageFieldDescription))
  158. storageSize:sizeof(GPBType__storage_)
  159. flags:0];
  160. NSAssert(descriptor == nil, @"Startup recursed!");
  161. descriptor = localDescriptor;
  162. }
  163. return descriptor;
  164. }
  165. @end
  166. int32_t GPBType_Syntax_RawValue(GPBType *message) {
  167. GPBDescriptor *descriptor = [GPBType descriptor];
  168. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBType_FieldNumber_Syntax];
  169. return GPBGetMessageInt32Field(message, field);
  170. }
  171. void SetGPBType_Syntax_RawValue(GPBType *message, int32_t value) {
  172. GPBDescriptor *descriptor = [GPBType descriptor];
  173. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBType_FieldNumber_Syntax];
  174. GPBSetInt32IvarWithFieldInternal(message, field, value, descriptor.file.syntax);
  175. }
  176. #pragma mark - GPBField
  177. @implementation GPBField
  178. @dynamic kind;
  179. @dynamic cardinality;
  180. @dynamic number;
  181. @dynamic name;
  182. @dynamic typeURL;
  183. @dynamic oneofIndex;
  184. @dynamic packed;
  185. @dynamic optionsArray, optionsArray_Count;
  186. @dynamic jsonName;
  187. @dynamic defaultValue;
  188. typedef struct GPBField__storage_ {
  189. uint32_t _has_storage_[1];
  190. GPBField_Kind kind;
  191. GPBField_Cardinality cardinality;
  192. int32_t number;
  193. int32_t oneofIndex;
  194. NSString *name;
  195. NSString *typeURL;
  196. NSMutableArray *optionsArray;
  197. NSString *jsonName;
  198. NSString *defaultValue;
  199. } GPBField__storage_;
  200. // This method is threadsafe because it is initially called
  201. // in +initialize for each subclass.
  202. + (GPBDescriptor *)descriptor {
  203. static GPBDescriptor *descriptor = nil;
  204. if (!descriptor) {
  205. static GPBMessageFieldDescription fields[] = {
  206. {
  207. .name = "kind",
  208. .dataTypeSpecific.enumDescFunc = GPBField_Kind_EnumDescriptor,
  209. .number = GPBField_FieldNumber_Kind,
  210. .hasIndex = 0,
  211. .offset = (uint32_t)offsetof(GPBField__storage_, kind),
  212. .flags = GPBFieldOptional | GPBFieldHasEnumDescriptor,
  213. .dataType = GPBDataTypeEnum,
  214. },
  215. {
  216. .name = "cardinality",
  217. .dataTypeSpecific.enumDescFunc = GPBField_Cardinality_EnumDescriptor,
  218. .number = GPBField_FieldNumber_Cardinality,
  219. .hasIndex = 1,
  220. .offset = (uint32_t)offsetof(GPBField__storage_, cardinality),
  221. .flags = GPBFieldOptional | GPBFieldHasEnumDescriptor,
  222. .dataType = GPBDataTypeEnum,
  223. },
  224. {
  225. .name = "number",
  226. .dataTypeSpecific.className = NULL,
  227. .number = GPBField_FieldNumber_Number,
  228. .hasIndex = 2,
  229. .offset = (uint32_t)offsetof(GPBField__storage_, number),
  230. .flags = GPBFieldOptional,
  231. .dataType = GPBDataTypeInt32,
  232. },
  233. {
  234. .name = "name",
  235. .dataTypeSpecific.className = NULL,
  236. .number = GPBField_FieldNumber_Name,
  237. .hasIndex = 3,
  238. .offset = (uint32_t)offsetof(GPBField__storage_, name),
  239. .flags = GPBFieldOptional,
  240. .dataType = GPBDataTypeString,
  241. },
  242. {
  243. .name = "typeURL",
  244. .dataTypeSpecific.className = NULL,
  245. .number = GPBField_FieldNumber_TypeURL,
  246. .hasIndex = 4,
  247. .offset = (uint32_t)offsetof(GPBField__storage_, typeURL),
  248. .flags = GPBFieldOptional | GPBFieldTextFormatNameCustom,
  249. .dataType = GPBDataTypeString,
  250. },
  251. {
  252. .name = "oneofIndex",
  253. .dataTypeSpecific.className = NULL,
  254. .number = GPBField_FieldNumber_OneofIndex,
  255. .hasIndex = 5,
  256. .offset = (uint32_t)offsetof(GPBField__storage_, oneofIndex),
  257. .flags = GPBFieldOptional,
  258. .dataType = GPBDataTypeInt32,
  259. },
  260. {
  261. .name = "packed",
  262. .dataTypeSpecific.className = NULL,
  263. .number = GPBField_FieldNumber_Packed,
  264. .hasIndex = 6,
  265. .offset = 7, // Stored in _has_storage_ to save space.
  266. .flags = GPBFieldOptional,
  267. .dataType = GPBDataTypeBool,
  268. },
  269. {
  270. .name = "optionsArray",
  271. .dataTypeSpecific.className = GPBStringifySymbol(GPBOption),
  272. .number = GPBField_FieldNumber_OptionsArray,
  273. .hasIndex = GPBNoHasBit,
  274. .offset = (uint32_t)offsetof(GPBField__storage_, optionsArray),
  275. .flags = GPBFieldRepeated,
  276. .dataType = GPBDataTypeMessage,
  277. },
  278. {
  279. .name = "jsonName",
  280. .dataTypeSpecific.className = NULL,
  281. .number = GPBField_FieldNumber_JsonName,
  282. .hasIndex = 8,
  283. .offset = (uint32_t)offsetof(GPBField__storage_, jsonName),
  284. .flags = GPBFieldOptional,
  285. .dataType = GPBDataTypeString,
  286. },
  287. {
  288. .name = "defaultValue",
  289. .dataTypeSpecific.className = NULL,
  290. .number = GPBField_FieldNumber_DefaultValue,
  291. .hasIndex = 9,
  292. .offset = (uint32_t)offsetof(GPBField__storage_, defaultValue),
  293. .flags = GPBFieldOptional,
  294. .dataType = GPBDataTypeString,
  295. },
  296. };
  297. GPBDescriptor *localDescriptor =
  298. [GPBDescriptor allocDescriptorForClass:[GPBField class]
  299. rootClass:[GPBTypeRoot class]
  300. file:GPBTypeRoot_FileDescriptor()
  301. fields:fields
  302. fieldCount:(uint32_t)(sizeof(fields) / sizeof(GPBMessageFieldDescription))
  303. storageSize:sizeof(GPBField__storage_)
  304. flags:0];
  305. #if !GPBOBJC_SKIP_MESSAGE_TEXTFORMAT_EXTRAS
  306. static const char *extraTextFormatInfo =
  307. "\001\006\004\241!!\000";
  308. [localDescriptor setupExtraTextInfo:extraTextFormatInfo];
  309. #endif // !GPBOBJC_SKIP_MESSAGE_TEXTFORMAT_EXTRAS
  310. NSAssert(descriptor == nil, @"Startup recursed!");
  311. descriptor = localDescriptor;
  312. }
  313. return descriptor;
  314. }
  315. @end
  316. int32_t GPBField_Kind_RawValue(GPBField *message) {
  317. GPBDescriptor *descriptor = [GPBField descriptor];
  318. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBField_FieldNumber_Kind];
  319. return GPBGetMessageInt32Field(message, field);
  320. }
  321. void SetGPBField_Kind_RawValue(GPBField *message, int32_t value) {
  322. GPBDescriptor *descriptor = [GPBField descriptor];
  323. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBField_FieldNumber_Kind];
  324. GPBSetInt32IvarWithFieldInternal(message, field, value, descriptor.file.syntax);
  325. }
  326. int32_t GPBField_Cardinality_RawValue(GPBField *message) {
  327. GPBDescriptor *descriptor = [GPBField descriptor];
  328. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBField_FieldNumber_Cardinality];
  329. return GPBGetMessageInt32Field(message, field);
  330. }
  331. void SetGPBField_Cardinality_RawValue(GPBField *message, int32_t value) {
  332. GPBDescriptor *descriptor = [GPBField descriptor];
  333. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBField_FieldNumber_Cardinality];
  334. GPBSetInt32IvarWithFieldInternal(message, field, value, descriptor.file.syntax);
  335. }
  336. #pragma mark - Enum GPBField_Kind
  337. GPBEnumDescriptor *GPBField_Kind_EnumDescriptor(void) {
  338. static GPBEnumDescriptor *descriptor = NULL;
  339. if (!descriptor) {
  340. static const char *valueNames =
  341. "TypeUnknown\000TypeDouble\000TypeFloat\000TypeInt"
  342. "64\000TypeUint64\000TypeInt32\000TypeFixed64\000Type"
  343. "Fixed32\000TypeBool\000TypeString\000TypeGroup\000Ty"
  344. "peMessage\000TypeBytes\000TypeUint32\000TypeEnum\000"
  345. "TypeSfixed32\000TypeSfixed64\000TypeSint32\000Typ"
  346. "eSint64\000";
  347. static const int32_t values[] = {
  348. GPBField_Kind_TypeUnknown,
  349. GPBField_Kind_TypeDouble,
  350. GPBField_Kind_TypeFloat,
  351. GPBField_Kind_TypeInt64,
  352. GPBField_Kind_TypeUint64,
  353. GPBField_Kind_TypeInt32,
  354. GPBField_Kind_TypeFixed64,
  355. GPBField_Kind_TypeFixed32,
  356. GPBField_Kind_TypeBool,
  357. GPBField_Kind_TypeString,
  358. GPBField_Kind_TypeGroup,
  359. GPBField_Kind_TypeMessage,
  360. GPBField_Kind_TypeBytes,
  361. GPBField_Kind_TypeUint32,
  362. GPBField_Kind_TypeEnum,
  363. GPBField_Kind_TypeSfixed32,
  364. GPBField_Kind_TypeSfixed64,
  365. GPBField_Kind_TypeSint32,
  366. GPBField_Kind_TypeSint64,
  367. };
  368. GPBEnumDescriptor *worker =
  369. [GPBEnumDescriptor allocDescriptorForName:GPBNSStringifySymbol(GPBField_Kind)
  370. valueNames:valueNames
  371. values:values
  372. count:(uint32_t)(sizeof(values) / sizeof(int32_t))
  373. enumVerifier:GPBField_Kind_IsValidValue];
  374. if (!OSAtomicCompareAndSwapPtrBarrier(nil, worker, (void * volatile *)&descriptor)) {
  375. [worker release];
  376. }
  377. }
  378. return descriptor;
  379. }
  380. BOOL GPBField_Kind_IsValidValue(int32_t value__) {
  381. switch (value__) {
  382. case GPBField_Kind_TypeUnknown:
  383. case GPBField_Kind_TypeDouble:
  384. case GPBField_Kind_TypeFloat:
  385. case GPBField_Kind_TypeInt64:
  386. case GPBField_Kind_TypeUint64:
  387. case GPBField_Kind_TypeInt32:
  388. case GPBField_Kind_TypeFixed64:
  389. case GPBField_Kind_TypeFixed32:
  390. case GPBField_Kind_TypeBool:
  391. case GPBField_Kind_TypeString:
  392. case GPBField_Kind_TypeGroup:
  393. case GPBField_Kind_TypeMessage:
  394. case GPBField_Kind_TypeBytes:
  395. case GPBField_Kind_TypeUint32:
  396. case GPBField_Kind_TypeEnum:
  397. case GPBField_Kind_TypeSfixed32:
  398. case GPBField_Kind_TypeSfixed64:
  399. case GPBField_Kind_TypeSint32:
  400. case GPBField_Kind_TypeSint64:
  401. return YES;
  402. default:
  403. return NO;
  404. }
  405. }
  406. #pragma mark - Enum GPBField_Cardinality
  407. GPBEnumDescriptor *GPBField_Cardinality_EnumDescriptor(void) {
  408. static GPBEnumDescriptor *descriptor = NULL;
  409. if (!descriptor) {
  410. static const char *valueNames =
  411. "CardinalityUnknown\000CardinalityOptional\000C"
  412. "ardinalityRequired\000CardinalityRepeated\000";
  413. static const int32_t values[] = {
  414. GPBField_Cardinality_CardinalityUnknown,
  415. GPBField_Cardinality_CardinalityOptional,
  416. GPBField_Cardinality_CardinalityRequired,
  417. GPBField_Cardinality_CardinalityRepeated,
  418. };
  419. GPBEnumDescriptor *worker =
  420. [GPBEnumDescriptor allocDescriptorForName:GPBNSStringifySymbol(GPBField_Cardinality)
  421. valueNames:valueNames
  422. values:values
  423. count:(uint32_t)(sizeof(values) / sizeof(int32_t))
  424. enumVerifier:GPBField_Cardinality_IsValidValue];
  425. if (!OSAtomicCompareAndSwapPtrBarrier(nil, worker, (void * volatile *)&descriptor)) {
  426. [worker release];
  427. }
  428. }
  429. return descriptor;
  430. }
  431. BOOL GPBField_Cardinality_IsValidValue(int32_t value__) {
  432. switch (value__) {
  433. case GPBField_Cardinality_CardinalityUnknown:
  434. case GPBField_Cardinality_CardinalityOptional:
  435. case GPBField_Cardinality_CardinalityRequired:
  436. case GPBField_Cardinality_CardinalityRepeated:
  437. return YES;
  438. default:
  439. return NO;
  440. }
  441. }
  442. #pragma mark - GPBEnum
  443. @implementation GPBEnum
  444. @dynamic name;
  445. @dynamic enumvalueArray, enumvalueArray_Count;
  446. @dynamic optionsArray, optionsArray_Count;
  447. @dynamic hasSourceContext, sourceContext;
  448. @dynamic syntax;
  449. typedef struct GPBEnum__storage_ {
  450. uint32_t _has_storage_[1];
  451. GPBSyntax syntax;
  452. NSString *name;
  453. NSMutableArray *enumvalueArray;
  454. NSMutableArray *optionsArray;
  455. GPBSourceContext *sourceContext;
  456. } GPBEnum__storage_;
  457. // This method is threadsafe because it is initially called
  458. // in +initialize for each subclass.
  459. + (GPBDescriptor *)descriptor {
  460. static GPBDescriptor *descriptor = nil;
  461. if (!descriptor) {
  462. static GPBMessageFieldDescription fields[] = {
  463. {
  464. .name = "name",
  465. .dataTypeSpecific.className = NULL,
  466. .number = GPBEnum_FieldNumber_Name,
  467. .hasIndex = 0,
  468. .offset = (uint32_t)offsetof(GPBEnum__storage_, name),
  469. .flags = GPBFieldOptional,
  470. .dataType = GPBDataTypeString,
  471. },
  472. {
  473. .name = "enumvalueArray",
  474. .dataTypeSpecific.className = GPBStringifySymbol(GPBEnumValue),
  475. .number = GPBEnum_FieldNumber_EnumvalueArray,
  476. .hasIndex = GPBNoHasBit,
  477. .offset = (uint32_t)offsetof(GPBEnum__storage_, enumvalueArray),
  478. .flags = GPBFieldRepeated,
  479. .dataType = GPBDataTypeMessage,
  480. },
  481. {
  482. .name = "optionsArray",
  483. .dataTypeSpecific.className = GPBStringifySymbol(GPBOption),
  484. .number = GPBEnum_FieldNumber_OptionsArray,
  485. .hasIndex = GPBNoHasBit,
  486. .offset = (uint32_t)offsetof(GPBEnum__storage_, optionsArray),
  487. .flags = GPBFieldRepeated,
  488. .dataType = GPBDataTypeMessage,
  489. },
  490. {
  491. .name = "sourceContext",
  492. .dataTypeSpecific.className = GPBStringifySymbol(GPBSourceContext),
  493. .number = GPBEnum_FieldNumber_SourceContext,
  494. .hasIndex = 1,
  495. .offset = (uint32_t)offsetof(GPBEnum__storage_, sourceContext),
  496. .flags = GPBFieldOptional,
  497. .dataType = GPBDataTypeMessage,
  498. },
  499. {
  500. .name = "syntax",
  501. .dataTypeSpecific.enumDescFunc = GPBSyntax_EnumDescriptor,
  502. .number = GPBEnum_FieldNumber_Syntax,
  503. .hasIndex = 2,
  504. .offset = (uint32_t)offsetof(GPBEnum__storage_, syntax),
  505. .flags = GPBFieldOptional | GPBFieldHasEnumDescriptor,
  506. .dataType = GPBDataTypeEnum,
  507. },
  508. };
  509. GPBDescriptor *localDescriptor =
  510. [GPBDescriptor allocDescriptorForClass:[GPBEnum class]
  511. rootClass:[GPBTypeRoot class]
  512. file:GPBTypeRoot_FileDescriptor()
  513. fields:fields
  514. fieldCount:(uint32_t)(sizeof(fields) / sizeof(GPBMessageFieldDescription))
  515. storageSize:sizeof(GPBEnum__storage_)
  516. flags:0];
  517. NSAssert(descriptor == nil, @"Startup recursed!");
  518. descriptor = localDescriptor;
  519. }
  520. return descriptor;
  521. }
  522. @end
  523. int32_t GPBEnum_Syntax_RawValue(GPBEnum *message) {
  524. GPBDescriptor *descriptor = [GPBEnum descriptor];
  525. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBEnum_FieldNumber_Syntax];
  526. return GPBGetMessageInt32Field(message, field);
  527. }
  528. void SetGPBEnum_Syntax_RawValue(GPBEnum *message, int32_t value) {
  529. GPBDescriptor *descriptor = [GPBEnum descriptor];
  530. GPBFieldDescriptor *field = [descriptor fieldWithNumber:GPBEnum_FieldNumber_Syntax];
  531. GPBSetInt32IvarWithFieldInternal(message, field, value, descriptor.file.syntax);
  532. }
  533. #pragma mark - GPBEnumValue
  534. @implementation GPBEnumValue
  535. @dynamic name;
  536. @dynamic number;
  537. @dynamic optionsArray, optionsArray_Count;
  538. typedef struct GPBEnumValue__storage_ {
  539. uint32_t _has_storage_[1];
  540. int32_t number;
  541. NSString *name;
  542. NSMutableArray *optionsArray;
  543. } GPBEnumValue__storage_;
  544. // This method is threadsafe because it is initially called
  545. // in +initialize for each subclass.
  546. + (GPBDescriptor *)descriptor {
  547. static GPBDescriptor *descriptor = nil;
  548. if (!descriptor) {
  549. static GPBMessageFieldDescription fields[] = {
  550. {
  551. .name = "name",
  552. .dataTypeSpecific.className = NULL,
  553. .number = GPBEnumValue_FieldNumber_Name,
  554. .hasIndex = 0,
  555. .offset = (uint32_t)offsetof(GPBEnumValue__storage_, name),
  556. .flags = GPBFieldOptional,
  557. .dataType = GPBDataTypeString,
  558. },
  559. {
  560. .name = "number",
  561. .dataTypeSpecific.className = NULL,
  562. .number = GPBEnumValue_FieldNumber_Number,
  563. .hasIndex = 1,
  564. .offset = (uint32_t)offsetof(GPBEnumValue__storage_, number),
  565. .flags = GPBFieldOptional,
  566. .dataType = GPBDataTypeInt32,
  567. },
  568. {
  569. .name = "optionsArray",
  570. .dataTypeSpecific.className = GPBStringifySymbol(GPBOption),
  571. .number = GPBEnumValue_FieldNumber_OptionsArray,
  572. .hasIndex = GPBNoHasBit,
  573. .offset = (uint32_t)offsetof(GPBEnumValue__storage_, optionsArray),
  574. .flags = GPBFieldRepeated,
  575. .dataType = GPBDataTypeMessage,
  576. },
  577. };
  578. GPBDescriptor *localDescriptor =
  579. [GPBDescriptor allocDescriptorForClass:[GPBEnumValue class]
  580. rootClass:[GPBTypeRoot class]
  581. file:GPBTypeRoot_FileDescriptor()
  582. fields:fields
  583. fieldCount:(uint32_t)(sizeof(fields) / sizeof(GPBMessageFieldDescription))
  584. storageSize:sizeof(GPBEnumValue__storage_)
  585. flags:0];
  586. NSAssert(descriptor == nil, @"Startup recursed!");
  587. descriptor = localDescriptor;
  588. }
  589. return descriptor;
  590. }
  591. @end
  592. #pragma mark - GPBOption
  593. @implementation GPBOption
  594. @dynamic name;
  595. @dynamic hasValue, value;
  596. typedef struct GPBOption__storage_ {
  597. uint32_t _has_storage_[1];
  598. NSString *name;
  599. GPBAny *value;
  600. } GPBOption__storage_;
  601. // This method is threadsafe because it is initially called
  602. // in +initialize for each subclass.
  603. + (GPBDescriptor *)descriptor {
  604. static GPBDescriptor *descriptor = nil;
  605. if (!descriptor) {
  606. static GPBMessageFieldDescription fields[] = {
  607. {
  608. .name = "name",
  609. .dataTypeSpecific.className = NULL,
  610. .number = GPBOption_FieldNumber_Name,
  611. .hasIndex = 0,
  612. .offset = (uint32_t)offsetof(GPBOption__storage_, name),
  613. .flags = GPBFieldOptional,
  614. .dataType = GPBDataTypeString,
  615. },
  616. {
  617. .name = "value",
  618. .dataTypeSpecific.className = GPBStringifySymbol(GPBAny),
  619. .number = GPBOption_FieldNumber_Value,
  620. .hasIndex = 1,
  621. .offset = (uint32_t)offsetof(GPBOption__storage_, value),
  622. .flags = GPBFieldOptional,
  623. .dataType = GPBDataTypeMessage,
  624. },
  625. };
  626. GPBDescriptor *localDescriptor =
  627. [GPBDescriptor allocDescriptorForClass:[GPBOption class]
  628. rootClass:[GPBTypeRoot class]
  629. file:GPBTypeRoot_FileDescriptor()
  630. fields:fields
  631. fieldCount:(uint32_t)(sizeof(fields) / sizeof(GPBMessageFieldDescription))
  632. storageSize:sizeof(GPBOption__storage_)
  633. flags:0];
  634. NSAssert(descriptor == nil, @"Startup recursed!");
  635. descriptor = localDescriptor;
  636. }
  637. return descriptor;
  638. }
  639. @end
  640. #pragma clang diagnostic pop
  641. // @@protoc_insertion_point(global_scope)