// 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. #import "GPBMessage_PackagePrivate.h" #import #import #import "GPBArray_PackagePrivate.h" #import "GPBCodedInputStream_PackagePrivate.h" #import "GPBCodedOutputStream.h" #import "GPBDescriptor_PackagePrivate.h" #import "GPBDictionary_PackagePrivate.h" #import "GPBExtensionField_PackagePrivate.h" #import "GPBExtensionRegistry.h" #import "GPBRootObject_PackagePrivate.h" #import "GPBUnknownFieldSet_PackagePrivate.h" #import "GPBUtilities_PackagePrivate.h" NSString *const GPBMessageErrorDomain = GPBNSStringifySymbol(GPBMessageErrorDomain); #ifdef DEBUG NSString *const GPBExceptionMessageKey = GPBNSStringifySymbol(GPBExceptionMessage); #endif // DEBUG static NSString *const kGPBDataCoderKey = @"GPBData"; // // PLEASE REMEMBER: // // This is the base class for *all* messages generated, so any selector defined, // *public* or *private* could end up colliding with a proto message field. So // avoid using selectors that could match a property, use C functions to hide // them, etc. // @interface GPBMessage () { @package GPBUnknownFieldSet *unknownFields_; NSMutableDictionary *extensionMap_; NSMutableDictionary *autocreatedExtensionMap_; // If the object was autocreated, we remember the creator so that if we get // mutated, we can inform the creator to make our field visible. GPBMessage *autocreator_; GPBFieldDescriptor *autocreatorField_; GPBExtensionField *autocreatorExtension_; } @end static id CreateArrayForField(GPBFieldDescriptor *field, GPBMessage *autocreator) __attribute__((ns_returns_retained)); static id GetOrCreateArrayIvarWithField(GPBMessage *self, GPBFieldDescriptor *field, GPBFileSyntax syntax); static id GetArrayIvarWithField(GPBMessage *self, GPBFieldDescriptor *field); static id CreateMapForField(GPBFieldDescriptor *field, GPBMessage *autocreator) __attribute__((ns_returns_retained)); static id GetOrCreateMapIvarWithField(GPBMessage *self, GPBFieldDescriptor *field, GPBFileSyntax syntax); static id GetMapIvarWithField(GPBMessage *self, GPBFieldDescriptor *field); static NSMutableDictionary *CloneExtensionMap(NSDictionary *extensionMap, NSZone *zone) __attribute__((ns_returns_retained)); static NSError *MessageError(NSInteger code, NSDictionary *userInfo) { return [NSError errorWithDomain:GPBMessageErrorDomain code:code userInfo:userInfo]; } static NSError *MessageErrorWithReason(NSInteger code, NSString *reason) { NSDictionary *userInfo = nil; if ([reason length]) { userInfo = @{ @"Reason" : reason }; } return MessageError(code, userInfo); } static void CheckExtension(GPBMessage *self, GPBExtensionField *extension) { if ([[self class] descriptor] != [extension containingType]) { [NSException raise:NSInvalidArgumentException format:@"Extension %@ used on wrong class (%@ instead of %@)", extension.descriptor.singletonName, [[self class] descriptor].name, [extension containingType].name]; } } static NSMutableDictionary *CloneExtensionMap(NSDictionary *extensionMap, NSZone *zone) { if (extensionMap.count == 0) { return nil; } NSMutableDictionary *result = [[NSMutableDictionary allocWithZone:zone] initWithCapacity:extensionMap.count]; for (GPBExtensionField *field in extensionMap) { id value = [extensionMap objectForKey:field]; GPBExtensionDescriptor *fieldDescriptor = field.descriptor; BOOL isMessageExtension = GPBExtensionIsMessage(fieldDescriptor); if ([field isRepeated]) { if (isMessageExtension) { NSMutableArray *list = [[NSMutableArray alloc] initWithCapacity:[value count]]; for (GPBMessage *listValue in value) { GPBMessage *copiedValue = [listValue copyWithZone:zone]; [list addObject:copiedValue]; [copiedValue release]; } [result setObject:list forKey:field]; [list release]; } else { NSMutableArray *copiedValue = [value mutableCopyWithZone:zone]; [result setObject:copiedValue forKey:field]; [copiedValue release]; } } else { if (isMessageExtension) { GPBMessage *copiedValue = [value copyWithZone:zone]; [result setObject:copiedValue forKey:field]; [copiedValue release]; } else { [result setObject:value forKey:field]; } } } return result; } static id CreateArrayForField(GPBFieldDescriptor *field, GPBMessage *autocreator) { id result; GPBType fieldDataType = GPBGetFieldType(field); switch (fieldDataType) { case GPBTypeBool: result = [[GPBBoolArray alloc] init]; break; case GPBTypeFixed32: case GPBTypeUInt32: result = [[GPBUInt32Array alloc] init]; break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: result = [[GPBInt32Array alloc] init]; break; case GPBTypeFixed64: case GPBTypeUInt64: result = [[GPBUInt64Array alloc] init]; break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: result = [[GPBInt64Array alloc] init]; break; case GPBTypeFloat: result = [[GPBFloatArray alloc] init]; break; case GPBTypeDouble: result = [[GPBDoubleArray alloc] init]; break; case GPBTypeEnum: result = [[GPBEnumArray alloc] initWithValidationFunction:field.enumDescriptor.enumVerifier]; break; case GPBTypeData: case GPBTypeGroup: case GPBTypeMessage: case GPBTypeString: if (autocreator) { result = [[GPBAutocreatedArray alloc] init]; } else { result = [[NSMutableArray alloc] init]; } break; } if (autocreator) { if (GPBTypeIsObject(fieldDataType)) { GPBAutocreatedArray *autoArray = result; autoArray->_autocreator = autocreator; } else { GPBInt32Array *gpbArray = result; gpbArray->_autocreator = autocreator; } } return result; } static id CreateMapForField(GPBFieldDescriptor *field, GPBMessage *autocreator) { id result; GPBType keyType = field.mapKeyType; GPBType valueType = GPBGetFieldType(field); switch (keyType) { case GPBTypeBool: switch (valueType) { case GPBTypeBool: result = [[GPBBoolBoolDictionary alloc] init]; break; case GPBTypeFixed32: case GPBTypeUInt32: result = [[GPBBoolUInt32Dictionary alloc] init]; break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: result = [[GPBBoolInt32Dictionary alloc] init]; break; case GPBTypeFixed64: case GPBTypeUInt64: result = [[GPBBoolUInt64Dictionary alloc] init]; break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: result = [[GPBBoolInt64Dictionary alloc] init]; break; case GPBTypeFloat: result = [[GPBBoolFloatDictionary alloc] init]; break; case GPBTypeDouble: result = [[GPBBoolDoubleDictionary alloc] init]; break; case GPBTypeEnum: result = [[GPBBoolEnumDictionary alloc] initWithValidationFunction:field.enumDescriptor.enumVerifier]; break; case GPBTypeData: case GPBTypeMessage: case GPBTypeString: result = [[GPBBoolObjectDictionary alloc] init]; break; case GPBTypeGroup: NSCAssert(NO, @"shouldn't happen"); return nil; } break; case GPBTypeFixed32: case GPBTypeUInt32: switch (valueType) { case GPBTypeBool: result = [[GPBUInt32BoolDictionary alloc] init]; break; case GPBTypeFixed32: case GPBTypeUInt32: result = [[GPBUInt32UInt32Dictionary alloc] init]; break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: result = [[GPBUInt32Int32Dictionary alloc] init]; break; case GPBTypeFixed64: case GPBTypeUInt64: result = [[GPBUInt32UInt64Dictionary alloc] init]; break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: result = [[GPBUInt32Int64Dictionary alloc] init]; break; case GPBTypeFloat: result = [[GPBUInt32FloatDictionary alloc] init]; break; case GPBTypeDouble: result = [[GPBUInt32DoubleDictionary alloc] init]; break; case GPBTypeEnum: result = [[GPBUInt32EnumDictionary alloc] initWithValidationFunction:field.enumDescriptor.enumVerifier]; break; case GPBTypeData: case GPBTypeMessage: case GPBTypeString: result = [[GPBUInt32ObjectDictionary alloc] init]; break; case GPBTypeGroup: NSCAssert(NO, @"shouldn't happen"); return nil; } break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: switch (valueType) { case GPBTypeBool: result = [[GPBInt32BoolDictionary alloc] init]; break; case GPBTypeFixed32: case GPBTypeUInt32: result = [[GPBInt32UInt32Dictionary alloc] init]; break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: result = [[GPBInt32Int32Dictionary alloc] init]; break; case GPBTypeFixed64: case GPBTypeUInt64: result = [[GPBInt32UInt64Dictionary alloc] init]; break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: result = [[GPBInt32Int64Dictionary alloc] init]; break; case GPBTypeFloat: result = [[GPBInt32FloatDictionary alloc] init]; break; case GPBTypeDouble: result = [[GPBInt32DoubleDictionary alloc] init]; break; case GPBTypeEnum: result = [[GPBInt32EnumDictionary alloc] initWithValidationFunction:field.enumDescriptor.enumVerifier]; break; case GPBTypeData: case GPBTypeMessage: case GPBTypeString: result = [[GPBInt32ObjectDictionary alloc] init]; break; case GPBTypeGroup: NSCAssert(NO, @"shouldn't happen"); return nil; } break; case GPBTypeFixed64: case GPBTypeUInt64: switch (valueType) { case GPBTypeBool: result = [[GPBUInt64BoolDictionary alloc] init]; break; case GPBTypeFixed32: case GPBTypeUInt32: result = [[GPBUInt64UInt32Dictionary alloc] init]; break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: result = [[GPBUInt64Int32Dictionary alloc] init]; break; case GPBTypeFixed64: case GPBTypeUInt64: result = [[GPBUInt64UInt64Dictionary alloc] init]; break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: result = [[GPBUInt64Int64Dictionary alloc] init]; break; case GPBTypeFloat: result = [[GPBUInt64FloatDictionary alloc] init]; break; case GPBTypeDouble: result = [[GPBUInt64DoubleDictionary alloc] init]; break; case GPBTypeEnum: result = [[GPBUInt64EnumDictionary alloc] initWithValidationFunction:field.enumDescriptor.enumVerifier]; break; case GPBTypeData: case GPBTypeMessage: case GPBTypeString: result = [[GPBUInt64ObjectDictionary alloc] init]; break; case GPBTypeGroup: NSCAssert(NO, @"shouldn't happen"); return nil; } break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: switch (valueType) { case GPBTypeBool: result = [[GPBInt64BoolDictionary alloc] init]; break; case GPBTypeFixed32: case GPBTypeUInt32: result = [[GPBInt64UInt32Dictionary alloc] init]; break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: result = [[GPBInt64Int32Dictionary alloc] init]; break; case GPBTypeFixed64: case GPBTypeUInt64: result = [[GPBInt64UInt64Dictionary alloc] init]; break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: result = [[GPBInt64Int64Dictionary alloc] init]; break; case GPBTypeFloat: result = [[GPBInt64FloatDictionary alloc] init]; break; case GPBTypeDouble: result = [[GPBInt64DoubleDictionary alloc] init]; break; case GPBTypeEnum: result = [[GPBInt64EnumDictionary alloc] initWithValidationFunction:field.enumDescriptor.enumVerifier]; break; case GPBTypeData: case GPBTypeMessage: case GPBTypeString: result = [[GPBInt64ObjectDictionary alloc] init]; break; case GPBTypeGroup: NSCAssert(NO, @"shouldn't happen"); return nil; } break; case GPBTypeString: switch (valueType) { case GPBTypeBool: result = [[GPBStringBoolDictionary alloc] init]; break; case GPBTypeFixed32: case GPBTypeUInt32: result = [[GPBStringUInt32Dictionary alloc] init]; break; case GPBTypeInt32: case GPBTypeSFixed32: case GPBTypeSInt32: result = [[GPBStringInt32Dictionary alloc] init]; break; case GPBTypeFixed64: case GPBTypeUInt64: result = [[GPBStringUInt64Dictionary alloc] init]; break; case GPBTypeInt64: case GPBTypeSFixed64: case GPBTypeSInt64: result = [[GPBStringInt64Dictionary alloc] init]; break; case GPBTypeFloat: result = [[GPBStringFloatDictionary alloc] init]; break; case GPBTypeDouble: result = [[GPBStringDoubleDictionary alloc] init]; break; case GPBTypeEnum: result = [[GPBStringEnumDictionary alloc] initWithValidationFunction:field.enumDescriptor.enumVerifier]; break; case GPBTypeData: case GPBTypeMessage: case GPBTypeString: if (autocreator) { result = [[GPBAutocreatedDictionary alloc] init]; } else { result = [[NSMutableDictionary alloc] init]; } break; case GPBTypeGroup: NSCAssert(NO, @"shouldn't happen"); return nil; } break; case GPBTypeFloat: case GPBTypeDouble: case GPBTypeEnum: case GPBTypeData: case GPBTypeGroup: case GPBTypeMessage: NSCAssert(NO, @"shouldn't happen"); return nil; } if (autocreator) { if ((keyType == GPBTypeString) && GPBTypeIsObject(valueType)) { GPBAutocreatedDictionary *autoDict = result; autoDict->_autocreator = autocreator; } else { GPBInt32Int32Dictionary *gpbDict = result; gpbDict->_autocreator = autocreator; } } return result; } #if !defined(__clang_analyzer__) // These functions are blocked from the analyzer because the analyzer sees the // GPBSetRetainedObjectIvarWithFieldInternal() call as consuming the array/map, // so use of the array/map after the call returns is flagged as a use after // free. // But GPBSetRetainedObjectIvarWithFieldInternal() is "consuming" the retain // count be holding onto the object (it is transfering it), the object is // still valid after returning from the call. The other way to avoid this // would be to add a -retain/-autorelease, but that would force every // repeated/map field parsed into the autorelease pool which is both a memory // and performance hit. static id GetOrCreateArrayIvarWithField(GPBMessage *self, GPBFieldDescriptor *field, GPBFileSyntax syntax) { id array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (!array) { // No lock needed, this is called from places expecting to mutate // so no threading protection is needed. array = CreateArrayForField(field, nil); GPBSetRetainedObjectIvarWithFieldInternal(self, field, array, syntax); } return array; } // This is like GPBGetObjectIvarWithField(), but for arrays, it should // only be used to wire the method into the class. static id GetArrayIvarWithField(GPBMessage *self, GPBFieldDescriptor *field) { id array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (!array) { // Check again after getting the lock. OSSpinLockLock(&self->readOnlyMutex_); array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (!array) { array = CreateArrayForField(field, self); GPBSetAutocreatedRetainedObjectIvarWithField(self, field, array); } OSSpinLockUnlock(&self->readOnlyMutex_); } return array; } static id GetOrCreateMapIvarWithField(GPBMessage *self, GPBFieldDescriptor *field, GPBFileSyntax syntax) { id dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (!dict) { // No lock needed, this is called from places expecting to mutate // so no threading protection is needed. dict = CreateMapForField(field, nil); GPBSetRetainedObjectIvarWithFieldInternal(self, field, dict, syntax); } return dict; } // This is like GPBGetObjectIvarWithField(), but for maps, it should // only be used to wire the method into the class. static id GetMapIvarWithField(GPBMessage *self, GPBFieldDescriptor *field) { id dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (!dict) { // Check again after getting the lock. OSSpinLockLock(&self->readOnlyMutex_); dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (!dict) { dict = CreateMapForField(field, self); GPBSetAutocreatedRetainedObjectIvarWithField(self, field, dict); } OSSpinLockUnlock(&self->readOnlyMutex_); } return dict; } #endif // !defined(__clang_analyzer__) GPBMessage *GPBCreateMessageWithAutocreator(Class msgClass, GPBMessage *autocreator, GPBFieldDescriptor *field) { GPBMessage *message = [[msgClass alloc] init]; message->autocreator_ = autocreator; message->autocreatorField_ = [field retain]; return message; } static GPBMessage *CreateMessageWithAutocreatorForExtension( Class msgClass, GPBMessage *autocreator, GPBExtensionField *extension) __attribute__((ns_returns_retained)); static GPBMessage *CreateMessageWithAutocreatorForExtension( Class msgClass, GPBMessage *autocreator, GPBExtensionField *extension) { GPBMessage *message = [[msgClass alloc] init]; message->autocreator_ = autocreator; message->autocreatorExtension_ = [extension retain]; return message; } BOOL GPBWasMessageAutocreatedBy(GPBMessage *message, GPBMessage *parent) { return (message->autocreator_ == parent); } void GPBBecomeVisibleToAutocreator(GPBMessage *self) { // Message objects that are implicitly created by accessing a message field // are initially not visible via the hasX selector. This method makes them // visible. if (self->autocreator_) { // This will recursively make all parent messages visible until it reaches a // super-creator that's visible. if (self->autocreatorField_) { GPBFileSyntax syntax = [self->autocreator_ descriptor].file.syntax; GPBSetObjectIvarWithFieldInternal(self->autocreator_, self->autocreatorField_, self, syntax); } else { [self->autocreator_ setExtension:self->autocreatorExtension_ value:self]; } } } void GPBAutocreatedArrayModified(GPBMessage *self, id array) { // When one of our autocreated arrays adds elements, make it visible. GPBDescriptor *descriptor = [[self class] descriptor]; for (GPBFieldDescriptor *field in descriptor->fields_) { if (field.fieldType == GPBFieldTypeRepeated) { id curArray = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (curArray == array) { if (GPBFieldTypeIsObject(field)) { GPBAutocreatedArray *autoArray = array; autoArray->_autocreator = nil; } else { GPBInt32Array *gpbArray = array; gpbArray->_autocreator = nil; } GPBBecomeVisibleToAutocreator(self); return; } } } NSCAssert(NO, @"Unknown autocreated %@ for %@.", [array class], self); } void GPBAutocreatedDictionaryModified(GPBMessage *self, id dictionary) { // When one of our autocreated dicts adds elements, make it visible. GPBDescriptor *descriptor = [[self class] descriptor]; for (GPBFieldDescriptor *field in descriptor->fields_) { if (field.fieldType == GPBFieldTypeMap) { id curDict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (curDict == dictionary) { if ((field.mapKeyType == GPBTypeString) && GPBFieldTypeIsObject(field)) { GPBAutocreatedDictionary *autoDict = dictionary; autoDict->_autocreator = nil; } else { GPBInt32Int32Dictionary *gpbDict = dictionary; gpbDict->_autocreator = nil; } GPBBecomeVisibleToAutocreator(self); return; } } } NSCAssert(NO, @"Unknown autocreated %@ for %@.", [dictionary class], self); } void GPBClearMessageAutocreator(GPBMessage *self) { if ((self == nil) || !self->autocreator_) { return; } #if DEBUG && !defined(NS_BLOCK_ASSERTIONS) // Either the autocreator must have its "has" flag set to YES, or it must be // NO and not equal to ourselves. BOOL autocreatorHas = (self->autocreatorField_ ? GPBGetHasIvarField(self->autocreator_, self->autocreatorField_) : [self->autocreator_ hasExtension:self->autocreatorExtension_]); GPBMessage *autocreatorFieldValue = (self->autocreatorField_ ? GPBGetObjectIvarWithFieldNoAutocreate(self->autocreator_, self->autocreatorField_) : [self->autocreator_->autocreatedExtensionMap_ objectForKey:self->autocreatorExtension_]); NSCAssert(autocreatorHas || autocreatorFieldValue != self, @"Cannot clear autocreator because it still refers to self, self: %@.", self); #endif // DEBUG && !defined(NS_BLOCK_ASSERTIONS) self->autocreator_ = nil; [self->autocreatorField_ release]; self->autocreatorField_ = nil; [self->autocreatorExtension_ release]; self->autocreatorExtension_ = nil; } static GPBUnknownFieldSet *GetOrMakeUnknownFields(GPBMessage *self) { if (!self->unknownFields_) { self->unknownFields_ = [[GPBUnknownFieldSet alloc] init]; GPBBecomeVisibleToAutocreator(self); } return self->unknownFields_; } @implementation GPBMessage + (void)initialize { Class pbMessageClass = [GPBMessage class]; if ([self class] == pbMessageClass) { // This is here to start up the "base" class descriptor. [self descriptor]; // Message shares extension method resolving with GPBRootObject so insure // it is started up at the same time. (void)[GPBRootObject class]; } else if ([self superclass] == pbMessageClass) { // This is here to start up all the "message" subclasses. Just needs to be // done for the messages, not any of the subclasses. // This must be done in initialize to enforce thread safety of start up of // the protocol buffer library. // Note: The generated code for -descriptor calls // +[GPBDescriptor allocDescriptorForClass:...], passing the GPBRootObject // subclass for the file. That call chain is what ensures that *Root class // is started up to support extension resolution off the message class // (+resolveClassMethod: below) in a thread safe manner. [self descriptor]; } } + (instancetype)allocWithZone:(NSZone *)zone { // Override alloc to allocate our classes with the additional storage // required for the instance variables. GPBDescriptor *descriptor = [self descriptor]; return NSAllocateObject(self, descriptor->storageSize_, zone); } + (instancetype)alloc { return [self allocWithZone:nil]; } + (GPBDescriptor *)descriptor { // This is thread safe because it is called from +initialize. static GPBDescriptor *descriptor = NULL; static GPBFileDescriptor *fileDescriptor = NULL; if (!descriptor) { // Use a dummy file that marks it as proto2 syntax so when used generically // it supports unknowns/etc. fileDescriptor = [[GPBFileDescriptor alloc] initWithPackage:@"internal" syntax:GPBFileSyntaxProto2]; descriptor = [GPBDescriptor allocDescriptorForClass:[GPBMessage class] rootClass:Nil file:fileDescriptor fields:NULL fieldCount:0 oneofs:NULL oneofCount:0 enums:NULL enumCount:0 ranges:NULL rangeCount:0 storageSize:0 wireFormat:NO]; } return descriptor; } + (instancetype)message { return [[[self alloc] init] autorelease]; } - (instancetype)init { if ((self = [super init])) { messageStorage_ = (GPBMessage_StoragePtr)( ((uint8_t *)self) + class_getInstanceSize([self class])); readOnlyMutex_ = OS_SPINLOCK_INIT; } return self; } - (instancetype)initWithData:(NSData *)data error:(NSError **)errorPtr { return [self initWithData:data extensionRegistry:nil error:errorPtr]; } - (instancetype)initWithData:(NSData *)data extensionRegistry:(GPBExtensionRegistry *)extensionRegistry error:(NSError **)errorPtr { if ((self = [self init])) { @try { [self mergeFromData:data extensionRegistry:extensionRegistry]; } @catch (NSException *exception) { [self release]; self = nil; if (errorPtr) { *errorPtr = MessageErrorWithReason(GPBMessageErrorCodeMalformedData, exception.reason); } } #ifdef DEBUG if (self && !self.initialized) { [self release]; self = nil; if (errorPtr) { *errorPtr = MessageError(GPBMessageErrorCodeMissingRequiredField, nil); } } #endif } return self; } - (instancetype)initWithCodedInputStream:(GPBCodedInputStream *)input extensionRegistry: (GPBExtensionRegistry *)extensionRegistry error:(NSError **)errorPtr { if ((self = [self init])) { @try { [self mergeFromCodedInputStream:input extensionRegistry:extensionRegistry]; } @catch (NSException *exception) { [self release]; self = nil; if (errorPtr) { *errorPtr = MessageErrorWithReason(GPBMessageErrorCodeMalformedData, exception.reason); } } #ifdef DEBUG if (self && !self.initialized) { [self release]; self = nil; if (errorPtr) { *errorPtr = MessageError(GPBMessageErrorCodeMissingRequiredField, nil); } } #endif } return self; } - (void)dealloc { [self internalClear:NO]; NSCAssert(!autocreator_, @"Autocreator was not cleared before dealloc."); [super dealloc]; } - (void)copyFieldsInto:(GPBMessage *)message zone:(NSZone *)zone descriptor:(GPBDescriptor *)descriptor { // Copy all the storage... memcpy(message->messageStorage_, messageStorage_, descriptor->storageSize_); GPBFileSyntax syntax = descriptor.file.syntax; // Loop over the fields doing fixup... for (GPBFieldDescriptor *field in descriptor->fields_) { if (GPBFieldIsMapOrArray(field)) { id value = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (value) { // We need to copy the array/map, but the catch is for message fields, // we also need to ensure all the messages as those need copying also. id newValue; if (GPBFieldTypeIsMessage(field)) { if (field.fieldType == GPBFieldTypeRepeated) { NSArray *existingArray = (NSArray *)value; NSMutableArray *newArray = [[NSMutableArray alloc] initWithCapacity:existingArray.count]; newValue = newArray; for (GPBMessage *msg in existingArray) { GPBMessage *copiedMsg = [msg copyWithZone:zone]; [newArray addObject:copiedMsg]; [copiedMsg release]; } } else { if (field.mapKeyType == GPBTypeString) { // Map is an NSDictionary. NSDictionary *existingDict = value; NSMutableDictionary *newDict = [[NSMutableDictionary alloc] initWithCapacity:existingDict.count]; newValue = newDict; [existingDict enumerateKeysAndObjectsUsingBlock:^(NSString *key, GPBMessage *msg, BOOL *stop) { #pragma unused(stop) GPBMessage *copiedMsg = [msg copyWithZone:zone]; [newDict setObject:copiedMsg forKey:key]; [copiedMsg release]; }]; } else { // Is one of the GPB*ObjectDictionary classes. Type doesn't // matter, just need one to invoke the selector. GPBInt32ObjectDictionary *existingDict = value; newValue = [existingDict deepCopyWithZone:zone]; } } } else { // Not messages (but is a map/array)... if (field.fieldType == GPBFieldTypeRepeated) { if (GPBFieldTypeIsObject(field)) { // NSArray newValue = [value mutableCopyWithZone:zone]; } else { // GPB*Array newValue = [value copyWithZone:zone]; } } else { if (field.mapKeyType == GPBTypeString) { // NSDictionary newValue = [value mutableCopyWithZone:zone]; } else { // Is one of the GPB*Dictionary classes. Type doesn't matter, // just need one to invoke the selector. GPBInt32Int32Dictionary *existingDict = value; newValue = [existingDict copyWithZone:zone]; } } } // We retain here because the memcpy picked up the pointer value and // the next call to SetRetainedObject... will release the current value. [value retain]; GPBSetRetainedObjectIvarWithFieldInternal(message, field, newValue, syntax); } } else if (GPBFieldTypeIsMessage(field)) { // For object types, if we have a value, copy it. If we don't, // zero it to remove the pointer to something that was autocreated // (and the ptr just got memcpyed). if (GPBGetHasIvarField(self, field)) { GPBMessage *value = GPBGetObjectIvarWithFieldNoAutocreate(self, field); GPBMessage *newValue = [value copyWithZone:zone]; // We retain here because the memcpy picked up the pointer value and // the next call to SetRetainedObject... will release the current value. [value retain]; GPBSetRetainedObjectIvarWithFieldInternal(message, field, newValue, syntax); } else { uint8_t *storage = (uint8_t *)message->messageStorage_; id *typePtr = (id *)&storage[field->description_->offset]; *typePtr = NULL; } } else if (GPBFieldTypeIsObject(field) && GPBGetHasIvarField(self, field)) { // A set string/data value (message picked off above), copy it. id value = GPBGetObjectIvarWithFieldNoAutocreate(self, field); id newValue = [value copyWithZone:zone]; // We retain here because the memcpy picked up the pointer value and // the next call to SetRetainedObject... will release the current value. [value retain]; GPBSetRetainedObjectIvarWithFieldInternal(message, field, newValue, syntax); } else { // memcpy took care of the rest of the primative fields if they were set. } } // for (field in descriptor->fields_) } - (id)copyWithZone:(NSZone *)zone { GPBDescriptor *descriptor = [self descriptor]; GPBMessage *result = [[descriptor.messageClass allocWithZone:zone] init]; [self copyFieldsInto:result zone:zone descriptor:descriptor]; // Make immutable copies of the extra bits. result->unknownFields_ = [unknownFields_ copyWithZone:zone]; result->extensionMap_ = CloneExtensionMap(extensionMap_, zone); return result; } - (void)clear { [self internalClear:YES]; } - (void)internalClear:(BOOL)zeroStorage { GPBDescriptor *descriptor = [self descriptor]; for (GPBFieldDescriptor *field in descriptor->fields_) { if (GPBFieldIsMapOrArray(field)) { id arrayOrMap = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (arrayOrMap) { if (field.fieldType == GPBFieldTypeRepeated) { if (GPBFieldTypeIsObject(field)) { GPBAutocreatedArray *autoArray = arrayOrMap; if (autoArray->_autocreator == self) { autoArray->_autocreator = nil; } } else { // Type doesn't matter, it is a GPB*Array. GPBInt32Array *gpbArray = arrayOrMap; if (gpbArray->_autocreator == self) { gpbArray->_autocreator = nil; } } } else { if ((field.mapKeyType == GPBTypeString) && GPBFieldTypeIsObject(field)) { GPBAutocreatedDictionary *autoDict = arrayOrMap; if (autoDict->_autocreator == self) { autoDict->_autocreator = nil; } } else { // Type doesn't matter, it is a GPB*Dictionary. GPBInt32Int32Dictionary *gpbDict = arrayOrMap; if (gpbDict->_autocreator == self) { gpbDict->_autocreator = nil; } } } [arrayOrMap release]; } } else if (GPBFieldTypeIsMessage(field)) { GPBClearAutocreatedMessageIvarWithField(self, field); GPBMessage *value = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [value release]; } else if (GPBFieldTypeIsObject(field) && GPBGetHasIvarField(self, field)) { id value = GPBGetObjectIvarWithField(self, field); [value release]; } } // GPBClearMessageAutocreator() expects that its caller has already been // removed from autocreatedExtensionMap_ so we set to nil first. NSArray *autocreatedValues = [autocreatedExtensionMap_ allValues]; [autocreatedExtensionMap_ release]; autocreatedExtensionMap_ = nil; // Since we're clearing all of our extensions, make sure that we clear the // autocreator on any that we've created so they no longer refer to us. for (GPBMessage *value in autocreatedValues) { NSCAssert(GPBWasMessageAutocreatedBy(value, self), @"Autocreated extension does not refer back to self."); GPBClearMessageAutocreator(value); } [extensionMap_ release]; extensionMap_ = nil; [unknownFields_ release]; unknownFields_ = nil; // Note that clearing does not affect autocreator_. If we are being cleared // because of a dealloc, then autocreator_ should be nil anyway. If we are // being cleared because someone explicitly clears us, we don't want to // sever our relationship with our autocreator. if (zeroStorage) { memset(messageStorage_, 0, descriptor->storageSize_); } } - (BOOL)isInitialized { GPBDescriptor *descriptor = [self descriptor]; for (GPBFieldDescriptor *field in descriptor->fields_) { if (field.isRequired) { if (!GPBGetHasIvarField(self, field)) { return NO; } } if (GPBFieldTypeIsMessage(field)) { GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeSingle) { if (field.isRequired) { GPBMessage *message = GPBGetMessageIvarWithField(self, field); if (!message.initialized) { return NO; } } else { NSAssert(field.isOptional, @"%@: Single message field %@ not required or optional?", [self class], field.name); if (GPBGetHasIvarField(self, field)) { GPBMessage *message = GPBGetMessageIvarWithField(self, field); if (!message.initialized) { return NO; } } } } else if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); for (GPBMessage *message in array) { if (!message.initialized) { return NO; } } } else { // fieldType == GPBFieldTypeMap if (field.mapKeyType == GPBTypeString) { NSDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (map && !GPBDictionaryIsInitializedInternalHelper(map, field)) { return NO; } } else { // Real type is GPB*ObjectDictionary, exact type doesn't matter. GPBInt32ObjectDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (map && ![map isInitialized]) { return NO; } } } } } __block BOOL result = YES; [extensionMap_ enumerateKeysAndObjectsUsingBlock:^(GPBExtensionField *extension, id obj, BOOL *stop) { GPBExtensionDescriptor *extDesc = extension.descriptor; if (GPBExtensionIsMessage(extDesc)) { if (extDesc.isRepeated) { for (GPBMessage *msg in obj) { if (!msg.initialized) { result = NO; *stop = YES; break; } } } else { GPBMessage *asMsg = obj; if (!asMsg.initialized) { result = NO; *stop = YES; } } } }]; return result; } - (GPBDescriptor *)descriptor { return [[self class] descriptor]; } - (NSData *)data { #ifdef DEBUG if (!self.initialized) { return nil; } #endif NSMutableData *data = [NSMutableData dataWithLength:[self serializedSize]]; GPBCodedOutputStream *stream = [[GPBCodedOutputStream alloc] initWithData:data]; @try { [self writeToCodedOutputStream:stream]; } @catch (NSException *exception) { // This really shouldn't happen. The only way writeToCodedOutputStream: // could throw is if something in the library has a bug and the // serializedSize was wrong. #ifdef DEBUG NSLog(@"%@: Internal exception while building message data: %@", [self class], exception); #endif data = nil; } [stream release]; return data; } - (NSData *)delimitedData { size_t serializedSize = [self serializedSize]; size_t varintSize = GPBComputeRawVarint32SizeForInteger(serializedSize); NSMutableData *data = [NSMutableData dataWithLength:(serializedSize + varintSize)]; GPBCodedOutputStream *stream = [[GPBCodedOutputStream alloc] initWithData:data]; @try { [self writeDelimitedToCodedOutputStream:stream]; } @catch (NSException *exception) { // This really shouldn't happen. The only way writeToCodedOutputStream: // could throw is if something in the library has a bug and the // serializedSize was wrong. #ifdef DEBUG NSLog(@"%@: Internal exception while building message delimitedData: %@", [self class], exception); #endif data = nil; } [stream release]; return data; } - (void)writeToOutputStream:(NSOutputStream *)output { GPBCodedOutputStream *stream = [[GPBCodedOutputStream alloc] initWithOutputStream:output]; [self writeToCodedOutputStream:stream]; [stream release]; } - (void)writeToCodedOutputStream:(GPBCodedOutputStream *)output { GPBDescriptor *descriptor = [self descriptor]; NSArray *fieldsArray = descriptor->fields_; NSUInteger fieldCount = fieldsArray.count; const GPBExtensionRange *extensionRanges = descriptor.extensionRanges; NSUInteger extensionRangesCount = descriptor.extensionRangesCount; for (NSUInteger i = 0, j = 0; i < fieldCount || j < extensionRangesCount;) { if (i == fieldCount) { [self writeExtensionsToCodedOutputStream:output range:extensionRanges[j++]]; } else if (j == extensionRangesCount || GPBFieldNumber(fieldsArray[i]) < extensionRanges[j].start) { [self writeField:fieldsArray[i++] toCodedOutputStream:output]; } else { [self writeExtensionsToCodedOutputStream:output range:extensionRanges[j++]]; } } if (descriptor.isWireFormat) { [unknownFields_ writeAsMessageSetTo:output]; } else { [unknownFields_ writeToCodedOutputStream:output]; } } - (void)writeDelimitedToOutputStream:(NSOutputStream *)output { GPBCodedOutputStream *codedOutput = [[GPBCodedOutputStream alloc] initWithOutputStream:output]; [self writeDelimitedToCodedOutputStream:codedOutput]; [codedOutput release]; } - (void)writeDelimitedToCodedOutputStream:(GPBCodedOutputStream *)output { [output writeRawVarintSizeTAs32:[self serializedSize]]; [self writeToCodedOutputStream:output]; } - (void)writeField:(GPBFieldDescriptor *)field toCodedOutputStream:(GPBCodedOutputStream *)output { GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeSingle) { BOOL has = GPBGetHasIvarField(self, field); if (!has) { return; } } uint32_t fieldNumber = GPBFieldNumber(field); //%PDDM-DEFINE FIELD_CASE(TYPE, REAL_TYPE) //%FIELD_CASE_FULL(TYPE, REAL_TYPE, REAL_TYPE) //%PDDM-DEFINE FIELD_CASE_FULL(TYPE, REAL_TYPE, ARRAY_TYPE) //% case GPBType##TYPE: //% if (fieldType == GPBFieldTypeRepeated) { //% uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; //% GPB##ARRAY_TYPE##Array *array = //% GPBGetObjectIvarWithFieldNoAutocreate(self, field); //% [output write##TYPE##s:fieldNumber values:array tag:tag]; //% } else if (fieldType == GPBFieldTypeSingle) { //% [output write##TYPE:fieldNumber //% TYPE$S value:GPBGet##REAL_TYPE##IvarWithField(self, field)]; //% } else { // fieldType == GPBFieldTypeMap //% // Exact type here doesn't matter. //% GPBInt32##ARRAY_TYPE##Dictionary *dict = //% GPBGetObjectIvarWithFieldNoAutocreate(self, field); //% [dict writeToCodedOutputStream:output asField:field]; //% } //% break; //% //%PDDM-DEFINE FIELD_CASE2(TYPE) //% case GPBType##TYPE: //% if (fieldType == GPBFieldTypeRepeated) { //% NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); //% [output write##TYPE##s:fieldNumber values:array]; //% } else if (fieldType == GPBFieldTypeSingle) { //% // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check //% // again. //% [output write##TYPE:fieldNumber //% TYPE$S value:GPBGetObjectIvarWithFieldNoAutocreate(self, field)]; //% } else { // fieldType == GPBFieldTypeMap //% // Exact type here doesn't matter. //% id dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); //% GPBType mapKeyType = field.mapKeyType; //% if (mapKeyType == GPBTypeString) { //% GPBDictionaryWriteToStreamInternalHelper(output, dict, field); //% } else { //% [dict writeToCodedOutputStream:output asField:field]; //% } //% } //% break; //% switch (GPBGetFieldType(field)) { //%PDDM-EXPAND FIELD_CASE(Bool, Bool) // This block of code is generated, do not edit it directly. case GPBTypeBool: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBBoolArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeBools:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeBool:fieldNumber value:GPBGetBoolIvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32BoolDictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(Fixed32, UInt32) // This block of code is generated, do not edit it directly. case GPBTypeFixed32: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBUInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeFixed32s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeFixed32:fieldNumber value:GPBGetUInt32IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32UInt32Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(SFixed32, Int32) // This block of code is generated, do not edit it directly. case GPBTypeSFixed32: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeSFixed32s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeSFixed32:fieldNumber value:GPBGetInt32IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32Int32Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(Float, Float) // This block of code is generated, do not edit it directly. case GPBTypeFloat: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBFloatArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeFloats:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeFloat:fieldNumber value:GPBGetFloatIvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32FloatDictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(Fixed64, UInt64) // This block of code is generated, do not edit it directly. case GPBTypeFixed64: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBUInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeFixed64s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeFixed64:fieldNumber value:GPBGetUInt64IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32UInt64Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(SFixed64, Int64) // This block of code is generated, do not edit it directly. case GPBTypeSFixed64: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeSFixed64s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeSFixed64:fieldNumber value:GPBGetInt64IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32Int64Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(Double, Double) // This block of code is generated, do not edit it directly. case GPBTypeDouble: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBDoubleArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeDoubles:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeDouble:fieldNumber value:GPBGetDoubleIvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32DoubleDictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(Int32, Int32) // This block of code is generated, do not edit it directly. case GPBTypeInt32: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeInt32s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeInt32:fieldNumber value:GPBGetInt32IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32Int32Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(Int64, Int64) // This block of code is generated, do not edit it directly. case GPBTypeInt64: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeInt64s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeInt64:fieldNumber value:GPBGetInt64IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32Int64Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(SInt32, Int32) // This block of code is generated, do not edit it directly. case GPBTypeSInt32: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeSInt32s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeSInt32:fieldNumber value:GPBGetInt32IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32Int32Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(SInt64, Int64) // This block of code is generated, do not edit it directly. case GPBTypeSInt64: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeSInt64s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeSInt64:fieldNumber value:GPBGetInt64IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32Int64Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(UInt32, UInt32) // This block of code is generated, do not edit it directly. case GPBTypeUInt32: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBUInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeUInt32s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeUInt32:fieldNumber value:GPBGetUInt32IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32UInt32Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE(UInt64, UInt64) // This block of code is generated, do not edit it directly. case GPBTypeUInt64: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBUInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeUInt64s:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeUInt64:fieldNumber value:GPBGetUInt64IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32UInt64Dictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE_FULL(Enum, Int32, Enum) // This block of code is generated, do not edit it directly. case GPBTypeEnum: if (fieldType == GPBFieldTypeRepeated) { uint32_t tag = field.isPackable ? GPBFieldTag(field) : 0; GPBEnumArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeEnums:fieldNumber values:array tag:tag]; } else if (fieldType == GPBFieldTypeSingle) { [output writeEnum:fieldNumber value:GPBGetInt32IvarWithField(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. GPBInt32EnumDictionary *dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [dict writeToCodedOutputStream:output asField:field]; } break; //%PDDM-EXPAND FIELD_CASE2(Data) // This block of code is generated, do not edit it directly. case GPBTypeData: if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeDatas:fieldNumber values:array]; } else if (fieldType == GPBFieldTypeSingle) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. [output writeData:fieldNumber value:GPBGetObjectIvarWithFieldNoAutocreate(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. id dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { GPBDictionaryWriteToStreamInternalHelper(output, dict, field); } else { [dict writeToCodedOutputStream:output asField:field]; } } break; //%PDDM-EXPAND FIELD_CASE2(String) // This block of code is generated, do not edit it directly. case GPBTypeString: if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeStrings:fieldNumber values:array]; } else if (fieldType == GPBFieldTypeSingle) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. [output writeString:fieldNumber value:GPBGetObjectIvarWithFieldNoAutocreate(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. id dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { GPBDictionaryWriteToStreamInternalHelper(output, dict, field); } else { [dict writeToCodedOutputStream:output asField:field]; } } break; //%PDDM-EXPAND FIELD_CASE2(Message) // This block of code is generated, do not edit it directly. case GPBTypeMessage: if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeMessages:fieldNumber values:array]; } else if (fieldType == GPBFieldTypeSingle) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. [output writeMessage:fieldNumber value:GPBGetObjectIvarWithFieldNoAutocreate(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. id dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { GPBDictionaryWriteToStreamInternalHelper(output, dict, field); } else { [dict writeToCodedOutputStream:output asField:field]; } } break; //%PDDM-EXPAND FIELD_CASE2(Group) // This block of code is generated, do not edit it directly. case GPBTypeGroup: if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(self, field); [output writeGroups:fieldNumber values:array]; } else if (fieldType == GPBFieldTypeSingle) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. [output writeGroup:fieldNumber value:GPBGetObjectIvarWithFieldNoAutocreate(self, field)]; } else { // fieldType == GPBFieldTypeMap // Exact type here doesn't matter. id dict = GPBGetObjectIvarWithFieldNoAutocreate(self, field); GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { GPBDictionaryWriteToStreamInternalHelper(output, dict, field); } else { [dict writeToCodedOutputStream:output asField:field]; } } break; //%PDDM-EXPAND-END (18 expansions) } } #pragma mark - Extensions - (id)getExtension:(GPBExtensionField *)extension { CheckExtension(self, extension); id value = [extensionMap_ objectForKey:extension]; if (value != nil) { return value; } GPBExtensionDescriptor *extDesc = extension.descriptor; // No default for repeated. if (extDesc.isRepeated) { return nil; } // Non messages get their default. if (!GPBExtensionIsMessage(extDesc)) { return [extension defaultValue]; } // Check for an autocreated value. OSSpinLockLock(&readOnlyMutex_); value = [autocreatedExtensionMap_ objectForKey:extension]; if (!value) { // Auto create the message extensions to match normal fields. value = CreateMessageWithAutocreatorForExtension(extDesc.msgClass, self, extension); if (autocreatedExtensionMap_ == nil) { autocreatedExtensionMap_ = [[NSMutableDictionary alloc] init]; } // We can't simply call setExtension here because that would clear the new // value's autocreator. [autocreatedExtensionMap_ setObject:value forKey:extension]; [value release]; } OSSpinLockUnlock(&readOnlyMutex_); return value; } - (id)getExistingExtension:(GPBExtensionField *)extension { // This is an internal method so we don't need to call CheckExtension(). return [extensionMap_ objectForKey:extension]; } - (BOOL)hasExtension:(GPBExtensionField *)extension { #if DEBUG CheckExtension(self, extension); #endif // DEBUG return nil != [extensionMap_ objectForKey:extension]; } - (NSArray *)extensionsCurrentlySet { return [extensionMap_ allKeys]; } - (void)writeExtensionsToCodedOutputStream:(GPBCodedOutputStream *)output range:(GPBExtensionRange)range { NSArray *sortedExtensions = [[extensionMap_ allKeys] sortedArrayUsingSelector:@selector(compareByFieldNumber:)]; uint32_t start = range.start; uint32_t end = range.end; for (GPBExtensionField *extension in sortedExtensions) { uint32_t fieldNumber = [extension fieldNumber]; if (fieldNumber >= start && fieldNumber < end) { id value = [extensionMap_ objectForKey:extension]; [extension writeValue:value includingTagToCodedOutputStream:output]; } } } - (NSArray *)sortedExtensionsInUse { return [[extensionMap_ allKeys] sortedArrayUsingSelector:@selector(compareByFieldNumber:)]; } - (void)setExtension:(GPBExtensionField *)extension value:(id)value { if (!value) { [self clearExtension:extension]; return; } CheckExtension(self, extension); if ([extension isRepeated]) { [NSException raise:NSInvalidArgumentException format:@"Must call addExtension() for repeated types."]; } if (extensionMap_ == nil) { extensionMap_ = [[NSMutableDictionary alloc] init]; } [extensionMap_ setObject:value forKey:extension]; GPBExtensionDescriptor *descriptor = extension.descriptor; if (GPBExtensionIsMessage(descriptor) && !descriptor.isRepeated) { GPBMessage *autocreatedValue = [[autocreatedExtensionMap_ objectForKey:extension] retain]; // Must remove from the map before calling GPBClearMessageAutocreator() so // that GPBClearMessageAutocreator() knows its safe to clear. [autocreatedExtensionMap_ removeObjectForKey:extension]; GPBClearMessageAutocreator(autocreatedValue); [autocreatedValue release]; } GPBBecomeVisibleToAutocreator(self); } - (void)addExtension:(GPBExtensionField *)extension value:(id)value { CheckExtension(self, extension); if (![extension isRepeated]) { [NSException raise:NSInvalidArgumentException format:@"Must call setExtension() for singular types."]; } if (extensionMap_ == nil) { extensionMap_ = [[NSMutableDictionary alloc] init]; } NSMutableArray *list = [extensionMap_ objectForKey:extension]; if (list == nil) { list = [NSMutableArray array]; [extensionMap_ setObject:list forKey:extension]; } [list addObject:value]; GPBBecomeVisibleToAutocreator(self); } - (void)setExtension:(GPBExtensionField *)extension index:(NSUInteger)idx value:(id)value { CheckExtension(self, extension); if (![extension isRepeated]) { [NSException raise:NSInvalidArgumentException format:@"Must call setExtension() for singular types."]; } if (extensionMap_ == nil) { extensionMap_ = [[NSMutableDictionary alloc] init]; } NSMutableArray *list = [extensionMap_ objectForKey:extension]; [list replaceObjectAtIndex:idx withObject:value]; GPBBecomeVisibleToAutocreator(self); } - (void)clearExtension:(GPBExtensionField *)extension { CheckExtension(self, extension); // Only become visible if there was actually a value to clear. if ([extensionMap_ objectForKey:extension]) { [extensionMap_ removeObjectForKey:extension]; GPBBecomeVisibleToAutocreator(self); } } #pragma mark - mergeFrom - (void)mergeFromData:(NSData *)data extensionRegistry:(GPBExtensionRegistry *)extensionRegistry { GPBCodedInputStream *input = [[GPBCodedInputStream alloc] initWithData:data]; [self mergeFromCodedInputStream:input extensionRegistry:extensionRegistry]; [input checkLastTagWas:0]; [input release]; } #pragma mark - mergeDelimitedFrom - (void)mergeDelimitedFromCodedInputStream:(GPBCodedInputStream *)input extensionRegistry:(GPBExtensionRegistry *)extensionRegistry { GPBCodedInputStreamState *state = &input->state_; if (GPBCodedInputStreamIsAtEnd(state)) { return; } NSData *data = GPBCodedInputStreamReadRetainedDataNoCopy(state); if (data == nil) { return; } [self mergeFromData:data extensionRegistry:extensionRegistry]; [data release]; } #pragma mark - Parse From Data Support + (instancetype)parseFromData:(NSData *)data error:(NSError **)errorPtr { return [self parseFromData:data extensionRegistry:nil error:errorPtr]; } + (instancetype)parseFromData:(NSData *)data extensionRegistry:(GPBExtensionRegistry *)extensionRegistry error:(NSError **)errorPtr { return [[[self alloc] initWithData:data extensionRegistry:extensionRegistry error:errorPtr] autorelease]; } + (instancetype)parseFromCodedInputStream:(GPBCodedInputStream *)input extensionRegistry:(GPBExtensionRegistry *)extensionRegistry error:(NSError **)errorPtr { return [[[self alloc] initWithCodedInputStream:input extensionRegistry:extensionRegistry error:errorPtr] autorelease]; } #pragma mark - Parse Delimited From Data Support + (instancetype)parseDelimitedFromCodedInputStream:(GPBCodedInputStream *)input extensionRegistry: (GPBExtensionRegistry *)extensionRegistry error:(NSError **)errorPtr { GPBMessage *message = [[[self alloc] init] autorelease]; @try { [message mergeDelimitedFromCodedInputStream:input extensionRegistry:extensionRegistry]; } @catch (NSException *exception) { [message release]; message = nil; if (errorPtr) { *errorPtr = MessageErrorWithReason(GPBMessageErrorCodeMalformedData, exception.reason); } } #ifdef DEBUG if (message && !message.initialized) { [message release]; message = nil; if (errorPtr) { *errorPtr = MessageError(GPBMessageErrorCodeMissingRequiredField, nil); } } #endif return message; } #pragma mark - Unknown Field Support - (GPBUnknownFieldSet *)unknownFields { return unknownFields_; } - (void)setUnknownFields:(GPBUnknownFieldSet *)unknownFields { if (unknownFields != unknownFields_) { [unknownFields_ release]; unknownFields_ = [unknownFields copy]; GPBBecomeVisibleToAutocreator(self); } } - (void)parseMessageSet:(GPBCodedInputStream *)input extensionRegistry:(GPBExtensionRegistry *)extensionRegistry { uint32_t typeId = 0; NSData *rawBytes = nil; GPBExtensionField *extension = nil; GPBCodedInputStreamState *state = &input->state_; while (true) { uint32_t tag = GPBCodedInputStreamReadTag(state); if (tag == 0) { break; } if (tag == GPBWireFormatMessageSetTypeIdTag) { typeId = GPBCodedInputStreamReadUInt32(state); if (typeId != 0) { extension = [extensionRegistry getExtension:[self descriptor] fieldNumber:typeId]; } } else if (tag == GPBWireFormatMessageSetMessageTag) { rawBytes = [GPBCodedInputStreamReadRetainedDataNoCopy(state) autorelease]; } else { if (![input skipField:tag]) { break; } } } [input checkLastTagWas:GPBWireFormatMessageSetItemEndTag]; if (rawBytes != nil && typeId != 0) { if (extension != nil) { GPBCodedInputStream *newInput = [[GPBCodedInputStream alloc] initWithData:rawBytes]; [extension mergeFromCodedInputStream:newInput extensionRegistry:extensionRegistry message:self]; [newInput release]; } else { GPBUnknownFieldSet *unknownFields = GetOrMakeUnknownFields(self); [unknownFields mergeMessageSetMessage:typeId data:rawBytes]; } } } - (BOOL)parseUnknownField:(GPBCodedInputStream *)input extensionRegistry:(GPBExtensionRegistry *)extensionRegistry tag:(uint32_t)tag { GPBWireFormat wireType = GPBWireFormatGetTagWireType(tag); int32_t fieldNumber = GPBWireFormatGetTagFieldNumber(tag); GPBDescriptor *descriptor = [self descriptor]; GPBExtensionField *extension = [extensionRegistry getExtension:descriptor fieldNumber:fieldNumber]; if (extension == nil) { if (descriptor.wireFormat && GPBWireFormatMessageSetItemTag == tag) { [self parseMessageSet:input extensionRegistry:extensionRegistry]; return YES; } } else { if ([extension wireType] == wireType) { [extension mergeFromCodedInputStream:input extensionRegistry:extensionRegistry message:self]; return YES; } } if ([GPBUnknownFieldSet isFieldTag:tag]) { GPBUnknownFieldSet *unknownFields = GetOrMakeUnknownFields(self); return [unknownFields mergeFieldFrom:tag input:input]; } else { return NO; } } - (void)addUnknownMapEntry:(int32_t)fieldNum value:(NSData *)data { GPBUnknownFieldSet *unknownFields = GetOrMakeUnknownFields(self); [unknownFields addUnknownMapEntry:fieldNum value:data]; } #pragma mark - MergeFromCodedInputStream Support typedef struct MergeFromCodedInputStreamContext { GPBMessage *self; GPBCodedInputStream *stream; GPBMessage *result; GPBExtensionRegistry *registry; uint32_t tag; GPBFileSyntax syntax; } MergeFromCodedInputStreamContext; //%PDDM-DEFINE MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(NAME, TYPE, ARRAY_TYPE) //%static BOOL DynamicMergeFromCodedInputStream##NAME(GPBFieldDescriptor *field, //% NAME$S void *voidContext) { //% MergeFromCodedInputStreamContext *context = //% (MergeFromCodedInputStreamContext *)voidContext; //% GPBCodedInputStreamState *state = &context->stream->state_; //% GPBFieldType fieldType = field.fieldType; //% if (fieldType == GPBFieldTypeRepeated) { //% GPB##ARRAY_TYPE##Array *array = //% GetOrCreateArrayIvarWithField(context->result, field, context->syntax); //% if (field.isPackable) { //% int32_t length = GPBCodedInputStreamReadInt32(state); //% size_t limit = GPBCodedInputStreamPushLimit(state, length); //% while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { //% TYPE val = GPBCodedInputStreamRead##NAME(state); //% [array addValue:val]; //% } //% GPBCodedInputStreamPopLimit(state, limit); //% } else { //% TYPE val = GPBCodedInputStreamRead##NAME(state); //% [array addValue:val]; //% } //% } else if (fieldType == GPBFieldTypeSingle) { //% TYPE val = GPBCodedInputStreamRead##NAME(state); //% GPBSet##ARRAY_TYPE##IvarWithFieldInternal(context->result, field, val, //% ARRAY_TYPE$S context->syntax); //% } else { // fieldType == GPBFieldTypeMap //% // The exact type doesn't matter, just need to know it is a GPB*Dictionary. //% GPBInt32Int32Dictionary *map = //% GetOrCreateMapIvarWithField(context->result, field, context->syntax); //% [context->stream readMapEntry:map //% extensionRegistry:nil //% field:field //% parentMessage:context->result]; //% } //% return NO; //%} //% //%PDDM-DEFINE MERGE_FROM_CODED_INPUT_STREAM_OBJ_FUNC(NAME) //%static BOOL DynamicMergeFromCodedInputStream##NAME(GPBFieldDescriptor *field, //% NAME$S void *voidContext) { //% MergeFromCodedInputStreamContext *context = voidContext; //% GPBCodedInputStreamState *state = &context->stream->state_; //% GPBFieldType fieldType = field.fieldType; //% if (fieldType == GPBFieldTypeMap) { //% // GPB*Dictionary or NSDictionary, exact type doesn't matter at this point. //% id map = //% GetOrCreateMapIvarWithField(context->result, field, context->syntax); //% [context->stream readMapEntry:map //% extensionRegistry:nil //% field:field //% parentMessage:context->result]; //% } else { //% id val = GPBCodedInputStreamReadRetained##NAME(state); //% if (fieldType == GPBFieldTypeRepeated) { //% NSMutableArray *array = //% GetOrCreateArrayIvarWithField(context->result, field, context->syntax); //% [array addObject:val]; //% [val release]; //% } else { // fieldType == GPBFieldTypeSingle //% GPBSetRetainedObjectIvarWithFieldInternal(context->result, field, val, //% context->syntax); //% } //% } //% return NO; //%} //% static BOOL DynamicMergeFromCodedInputStreamGroup(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; int number = GPBFieldNumber(field); GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBMessage *message = [[field.msgClass alloc] init]; NSMutableArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); [context->stream readGroup:number message:message extensionRegistry:context->registry]; [array addObject:message]; [message release]; } else if (fieldType == GPBFieldTypeSingle) { BOOL has = GPBGetHasIvarField(context->result, field); if (has) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. GPBMessage *message = GPBGetObjectIvarWithFieldNoAutocreate(context->result, field); [context->stream readGroup:number message:message extensionRegistry:context->registry]; } else { GPBMessage *message = [[field.msgClass alloc] init]; [context->stream readGroup:number message:message extensionRegistry:context->registry]; GPBSetRetainedObjectIvarWithFieldInternal(context->result, field, message, context->syntax); } } else { // fieldType == GPBFieldTypeMap NSCAssert(NO, @"Shouldn't happen"); return YES; } return NO; } static BOOL DynamicMergeFromCodedInputStreamMessage(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBMessage *message = [[field.msgClass alloc] init]; NSMutableArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); [context->stream readMessage:message extensionRegistry:context->registry]; [array addObject:message]; [message release]; } else if (fieldType == GPBFieldTypeSingle) { BOOL has = GPBGetHasIvarField(context->result, field); if (has) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. GPBMessage *message = GPBGetObjectIvarWithFieldNoAutocreate(context->result, field); [context->stream readMessage:message extensionRegistry:context->registry]; } else { GPBMessage *message = [[field.msgClass alloc] init]; [context->stream readMessage:message extensionRegistry:context->registry]; GPBSetRetainedObjectIvarWithFieldInternal(context->result, field, message, context->syntax); } } else { // fieldType == GPBFieldTypeMap // GPB*Dictionary or NSDictionary, exact type doesn't matter. id map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:context->registry field:field parentMessage:context->result]; } return NO; } static BOOL DynamicMergeFromCodedInputStreamEnum(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; int number = GPBFieldNumber(field); BOOL hasPreservingUnknownEnumSemantics = GPBHasPreservingUnknownEnumSemantics(context->syntax); GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBEnumArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { int32_t val = GPBCodedInputStreamReadEnum(state); if (hasPreservingUnknownEnumSemantics || [field isValidEnumValue:val]) { [array addRawValue:val]; } else { GPBUnknownFieldSet *unknownFields = GetOrMakeUnknownFields(context->self); [unknownFields mergeVarintField:number value:val]; } } GPBCodedInputStreamPopLimit(state, limit); } else { int32_t val = GPBCodedInputStreamReadEnum(state); if (hasPreservingUnknownEnumSemantics || [field isValidEnumValue:val]) { [array addRawValue:val]; } else { GPBUnknownFieldSet *unknownFields = GetOrMakeUnknownFields(context->self); [unknownFields mergeVarintField:number value:val]; } } } else if (fieldType == GPBFieldTypeSingle) { int32_t val = GPBCodedInputStreamReadEnum(state); if (hasPreservingUnknownEnumSemantics || [field isValidEnumValue:val]) { GPBSetInt32IvarWithFieldInternal(context->result, field, val, context->syntax); } else { GPBUnknownFieldSet *unknownFields = GetOrMakeUnknownFields(context->self); [unknownFields mergeVarintField:number value:val]; } } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a // GPB*EnumDictionary. GPBInt32EnumDictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:context->registry field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(Bool, BOOL, Bool) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamBool(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBBoolArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { BOOL val = GPBCodedInputStreamReadBool(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { BOOL val = GPBCodedInputStreamReadBool(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { BOOL val = GPBCodedInputStreamReadBool(state); GPBSetBoolIvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(Int32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamInt32(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt32Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { int32_t val = GPBCodedInputStreamReadInt32(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { int32_t val = GPBCodedInputStreamReadInt32(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { int32_t val = GPBCodedInputStreamReadInt32(state); GPBSetInt32IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(SInt32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamSInt32(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt32Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { int32_t val = GPBCodedInputStreamReadSInt32(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { int32_t val = GPBCodedInputStreamReadSInt32(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { int32_t val = GPBCodedInputStreamReadSInt32(state); GPBSetInt32IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(SFixed32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamSFixed32(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt32Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { int32_t val = GPBCodedInputStreamReadSFixed32(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { int32_t val = GPBCodedInputStreamReadSFixed32(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { int32_t val = GPBCodedInputStreamReadSFixed32(state); GPBSetInt32IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(UInt32, uint32_t, UInt32) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamUInt32(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt32Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { uint32_t val = GPBCodedInputStreamReadUInt32(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { uint32_t val = GPBCodedInputStreamReadUInt32(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { uint32_t val = GPBCodedInputStreamReadUInt32(state); GPBSetUInt32IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(Fixed32, uint32_t, UInt32) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamFixed32(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt32Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { uint32_t val = GPBCodedInputStreamReadFixed32(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { uint32_t val = GPBCodedInputStreamReadFixed32(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { uint32_t val = GPBCodedInputStreamReadFixed32(state); GPBSetUInt32IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(Int64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamInt64(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt64Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { int64_t val = GPBCodedInputStreamReadInt64(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { int64_t val = GPBCodedInputStreamReadInt64(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { int64_t val = GPBCodedInputStreamReadInt64(state); GPBSetInt64IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(SFixed64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamSFixed64(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt64Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { int64_t val = GPBCodedInputStreamReadSFixed64(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { int64_t val = GPBCodedInputStreamReadSFixed64(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { int64_t val = GPBCodedInputStreamReadSFixed64(state); GPBSetInt64IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(SInt64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamSInt64(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt64Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { int64_t val = GPBCodedInputStreamReadSInt64(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { int64_t val = GPBCodedInputStreamReadSInt64(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { int64_t val = GPBCodedInputStreamReadSInt64(state); GPBSetInt64IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(UInt64, uint64_t, UInt64) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamUInt64(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt64Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { uint64_t val = GPBCodedInputStreamReadUInt64(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { uint64_t val = GPBCodedInputStreamReadUInt64(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { uint64_t val = GPBCodedInputStreamReadUInt64(state); GPBSetUInt64IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(Fixed64, uint64_t, UInt64) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamFixed64(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt64Array *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { uint64_t val = GPBCodedInputStreamReadFixed64(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { uint64_t val = GPBCodedInputStreamReadFixed64(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { uint64_t val = GPBCodedInputStreamReadFixed64(state); GPBSetUInt64IvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(Float, float, Float) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamFloat(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBFloatArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { float val = GPBCodedInputStreamReadFloat(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { float val = GPBCodedInputStreamReadFloat(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { float val = GPBCodedInputStreamReadFloat(state); GPBSetFloatIvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_POD_FUNC(Double, double, Double) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamDouble(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = (MergeFromCodedInputStreamContext *)voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBDoubleArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); if (field.isPackable) { int32_t length = GPBCodedInputStreamReadInt32(state); size_t limit = GPBCodedInputStreamPushLimit(state, length); while (GPBCodedInputStreamBytesUntilLimit(state) > 0) { double val = GPBCodedInputStreamReadDouble(state); [array addValue:val]; } GPBCodedInputStreamPopLimit(state, limit); } else { double val = GPBCodedInputStreamReadDouble(state); [array addValue:val]; } } else if (fieldType == GPBFieldTypeSingle) { double val = GPBCodedInputStreamReadDouble(state); GPBSetDoubleIvarWithFieldInternal(context->result, field, val, context->syntax); } else { // fieldType == GPBFieldTypeMap // The exact type doesn't matter, just need to know it is a GPB*Dictionary. GPBInt32Int32Dictionary *map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_OBJ_FUNC(String) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamString(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeMap) { // GPB*Dictionary or NSDictionary, exact type doesn't matter at this point. id map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } else { id val = GPBCodedInputStreamReadRetainedString(state); if (fieldType == GPBFieldTypeRepeated) { NSMutableArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); [array addObject:val]; [val release]; } else { // fieldType == GPBFieldTypeSingle GPBSetRetainedObjectIvarWithFieldInternal(context->result, field, val, context->syntax); } } return NO; } //%PDDM-EXPAND MERGE_FROM_CODED_INPUT_STREAM_OBJ_FUNC(Data) // This block of code is generated, do not edit it directly. static BOOL DynamicMergeFromCodedInputStreamData(GPBFieldDescriptor *field, void *voidContext) { MergeFromCodedInputStreamContext *context = voidContext; GPBCodedInputStreamState *state = &context->stream->state_; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeMap) { // GPB*Dictionary or NSDictionary, exact type doesn't matter at this point. id map = GetOrCreateMapIvarWithField(context->result, field, context->syntax); [context->stream readMapEntry:map extensionRegistry:nil field:field parentMessage:context->result]; } else { id val = GPBCodedInputStreamReadRetainedData(state); if (fieldType == GPBFieldTypeRepeated) { NSMutableArray *array = GetOrCreateArrayIvarWithField(context->result, field, context->syntax); [array addObject:val]; [val release]; } else { // fieldType == GPBFieldTypeSingle GPBSetRetainedObjectIvarWithFieldInternal(context->result, field, val, context->syntax); } } return NO; } //%PDDM-EXPAND-END (15 expansions) - (void)mergeFromCodedInputStream:(GPBCodedInputStream *)input extensionRegistry:(GPBExtensionRegistry *)extensionRegistry { GPBDescriptor *descriptor = [self descriptor]; GPBFileSyntax syntax = descriptor.file.syntax; MergeFromCodedInputStreamContext context = { self, input, self, extensionRegistry, 0, syntax }; GPBApplyStrictFunctions funcs = GPBAPPLY_STRICT_FUNCTIONS_INIT(DynamicMergeFromCodedInputStream); NSUInteger startingIndex = 0; NSArray *fields = descriptor->fields_; NSUInteger count = fields.count; while (YES) { BOOL merged = NO; context.tag = GPBCodedInputStreamReadTag(&input->state_); for (NSUInteger i = 0; i < count; ++i) { if (startingIndex >= count) startingIndex = 0; GPBFieldDescriptor *fieldDescriptor = fields[startingIndex]; if (GPBFieldTag(fieldDescriptor) == context.tag) { GPBApplyFunction function = funcs[GPBGetFieldType(fieldDescriptor)]; function(fieldDescriptor, &context); merged = YES; break; } else { startingIndex += 1; } } if (!merged) { if (context.tag == 0) { // zero signals EOF / limit reached return; } else { if (GPBPreserveUnknownFields(syntax)) { if (![self parseUnknownField:input extensionRegistry:extensionRegistry tag:context.tag]) { // it's an endgroup tag return; } } else { if (![input skipField:context.tag]) { return; } } } } } } #pragma mark - MergeFrom Support typedef struct MergeFromContext { GPBMessage *other; GPBMessage *result; GPBFileSyntax syntax; } MergeFromContext; //%PDDM-DEFINE GPB_MERGE_FROM_FUNC(NAME) //%static BOOL MergeFrom##NAME(GPBFieldDescriptor *field, void *voidContext) { //% MergeFromContext *context = (MergeFromContext *)voidContext; //% BOOL otherHas = GPBGetHasIvarField(context->other, field); //% if (otherHas) { //% GPBSet##NAME##IvarWithFieldInternal( //% context->result, field, GPBGet##NAME##IvarWithField(context->other, field), //% context->syntax); //% } //% return YES; //%} //% //%PDDM-EXPAND GPB_MERGE_FROM_FUNC(Bool) // This block of code is generated, do not edit it directly. static BOOL MergeFromBool(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; BOOL otherHas = GPBGetHasIvarField(context->other, field); if (otherHas) { GPBSetBoolIvarWithFieldInternal( context->result, field, GPBGetBoolIvarWithField(context->other, field), context->syntax); } return YES; } //%PDDM-EXPAND GPB_MERGE_FROM_FUNC(Int32) // This block of code is generated, do not edit it directly. static BOOL MergeFromInt32(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; BOOL otherHas = GPBGetHasIvarField(context->other, field); if (otherHas) { GPBSetInt32IvarWithFieldInternal( context->result, field, GPBGetInt32IvarWithField(context->other, field), context->syntax); } return YES; } //%PDDM-EXPAND GPB_MERGE_FROM_FUNC(UInt32) // This block of code is generated, do not edit it directly. static BOOL MergeFromUInt32(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; BOOL otherHas = GPBGetHasIvarField(context->other, field); if (otherHas) { GPBSetUInt32IvarWithFieldInternal( context->result, field, GPBGetUInt32IvarWithField(context->other, field), context->syntax); } return YES; } //%PDDM-EXPAND GPB_MERGE_FROM_FUNC(Int64) // This block of code is generated, do not edit it directly. static BOOL MergeFromInt64(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; BOOL otherHas = GPBGetHasIvarField(context->other, field); if (otherHas) { GPBSetInt64IvarWithFieldInternal( context->result, field, GPBGetInt64IvarWithField(context->other, field), context->syntax); } return YES; } //%PDDM-EXPAND GPB_MERGE_FROM_FUNC(UInt64) // This block of code is generated, do not edit it directly. static BOOL MergeFromUInt64(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; BOOL otherHas = GPBGetHasIvarField(context->other, field); if (otherHas) { GPBSetUInt64IvarWithFieldInternal( context->result, field, GPBGetUInt64IvarWithField(context->other, field), context->syntax); } return YES; } //%PDDM-EXPAND GPB_MERGE_FROM_FUNC(Float) // This block of code is generated, do not edit it directly. static BOOL MergeFromFloat(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; BOOL otherHas = GPBGetHasIvarField(context->other, field); if (otherHas) { GPBSetFloatIvarWithFieldInternal( context->result, field, GPBGetFloatIvarWithField(context->other, field), context->syntax); } return YES; } //%PDDM-EXPAND GPB_MERGE_FROM_FUNC(Double) // This block of code is generated, do not edit it directly. static BOOL MergeFromDouble(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; BOOL otherHas = GPBGetHasIvarField(context->other, field); if (otherHas) { GPBSetDoubleIvarWithFieldInternal( context->result, field, GPBGetDoubleIvarWithField(context->other, field), context->syntax); } return YES; } //%PDDM-EXPAND-END (7 expansions) static BOOL MergeFromObject(GPBFieldDescriptor *field, void *voidContext) { MergeFromContext *context = (MergeFromContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { // In the case of a list, they need to be appended, and there is no // _hasIvar to worry about setting. id otherArray = GPBGetObjectIvarWithFieldNoAutocreate(context->other, field); if (otherArray) { GPBType fieldDataType = field->description_->type; if (GPBTypeIsObject(fieldDataType)) { NSMutableArray *resultArray = GetOrCreateArrayIvarWithField( context->result, field, context->syntax); [resultArray addObjectsFromArray:otherArray]; } else if (fieldDataType == GPBTypeEnum) { GPBEnumArray *resultArray = GetOrCreateArrayIvarWithField( context->result, field, context->syntax); [resultArray addRawValuesFromArray:otherArray]; } else { // The array type doesn't matter, that all implment // -addValuesFromArray:. GPBInt32Array *resultArray = GetOrCreateArrayIvarWithField( context->result, field, context->syntax); [resultArray addValuesFromArray:otherArray]; } } return YES; } if (fieldType == GPBFieldTypeMap) { // In the case of a map, they need to be merged, and there is no // _hasIvar to worry about setting. id otherDict = GPBGetObjectIvarWithFieldNoAutocreate(context->other, field); if (otherDict) { GPBType keyType = field.mapKeyType; GPBType valueType = field->description_->type; if (GPBTypeIsObject(keyType) && GPBTypeIsObject(valueType)) { NSMutableDictionary *resultDict = GetOrCreateMapIvarWithField( context->result, field, context->syntax); [resultDict addEntriesFromDictionary:otherDict]; } else if (valueType == GPBTypeEnum) { // The exact type doesn't matter, just need to know it is a // GPB*EnumDictionary. GPBInt32EnumDictionary *resultDict = GetOrCreateMapIvarWithField( context->result, field, context->syntax); [resultDict addRawEntriesFromDictionary:otherDict]; } else { // The exact type doesn't matter, they all implement // -addEntriesFromDictionary:. GPBInt32Int32Dictionary *resultDict = GetOrCreateMapIvarWithField( context->result, field, context->syntax); [resultDict addEntriesFromDictionary:otherDict]; } } return YES; } int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNumber = GPBFieldNumber(field); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNumber); if (!otherHas) { return YES; } // GPBGetObjectIvarWithFieldNoAutocreate skips the has check, faster. id otherVal = GPBGetObjectIvarWithFieldNoAutocreate(context->other, field); if (GPBFieldTypeIsMessage(field)) { if (GPBGetHasIvar(context->result, hasIndex, fieldNumber)) { GPBMessage *message = GPBGetObjectIvarWithFieldNoAutocreate(context->result, field); [message mergeFrom:otherVal]; } else { GPBMessage *message = [otherVal copy]; GPBSetRetainedObjectIvarWithFieldInternal(context->result, field, message, context->syntax); } } else { GPBSetObjectIvarWithFieldInternal(context->result, field, otherVal, context->syntax); } return YES; } - (void)mergeFrom:(GPBMessage *)other { Class selfClass = [self class]; Class otherClass = [other class]; if (!([selfClass isSubclassOfClass:otherClass] || [otherClass isSubclassOfClass:selfClass])) { [NSException raise:NSInvalidArgumentException format:@"Classes must match %@ != %@", selfClass, otherClass]; } GPBApplyFunctions funcs = GPBAPPLY_FUNCTIONS_INIT(MergeFrom); GPBFileSyntax syntax = [self descriptor].file.syntax; MergeFromContext context = {other, self, syntax}; GPBApplyFunctionsToMessageFields(&funcs, self, &context); // We assume someting got done, and become visible. GPBBecomeVisibleToAutocreator(self); // Unknown fields. if (!unknownFields_) { [self setUnknownFields:context.other.unknownFields]; } else { [unknownFields_ mergeUnknownFields:context.other.unknownFields]; } if (other->extensionMap_.count == 0) { return; } if (extensionMap_ == nil) { extensionMap_ = CloneExtensionMap(other->extensionMap_, NSZoneFromPointer(self)); } else { for (GPBExtensionField *thisField in other->extensionMap_) { id otherValue = [other->extensionMap_ objectForKey:thisField]; id value = [extensionMap_ objectForKey:thisField]; GPBExtensionDescriptor *thisFieldDescriptor = thisField.descriptor; BOOL isMessageExtension = GPBExtensionIsMessage(thisFieldDescriptor); if ([thisField isRepeated]) { NSMutableArray *list = value; if (list == nil) { list = [[NSMutableArray alloc] init]; [extensionMap_ setObject:list forKey:thisField]; [list release]; } if (isMessageExtension) { for (GPBMessage *otherListValue in otherValue) { GPBMessage *copiedValue = [otherListValue copy]; [list addObject:copiedValue]; [copiedValue release]; } } else { [list addObjectsFromArray:otherValue]; } } else { if (isMessageExtension) { if (value) { [(GPBMessage *)value mergeFrom:(GPBMessage *)otherValue]; } else { GPBMessage *copiedValue = [otherValue copy]; [extensionMap_ setObject:copiedValue forKey:thisField]; [copiedValue release]; } } else { [extensionMap_ setObject:otherValue forKey:thisField]; } } if (isMessageExtension && !thisFieldDescriptor.isRepeated) { GPBMessage *autocreatedValue = [[autocreatedExtensionMap_ objectForKey:thisField] retain]; // Must remove from the map before calling GPBClearMessageAutocreator() // so that GPBClearMessageAutocreator() knows its safe to clear. [autocreatedExtensionMap_ removeObjectForKey:thisField]; GPBClearMessageAutocreator(autocreatedValue); [autocreatedValue release]; } } } } #pragma mark - IsEqual Support typedef struct IsEqualContext { GPBMessage *other; GPBMessage *self; BOOL outIsEqual; } IsEqualContext; // If both self and other "has" a value then compare. //%PDDM-DEFINE IS_EQUAL_FUNC(NAME, TYPE) //%static BOOL IsEqual##NAME(GPBFieldDescriptor *field, void *voidContext) { //% IsEqualContext *context = (IsEqualContext *)voidContext; //% int32_t hasIndex = GPBFieldHasIndex(field); //% uint32_t fieldNum = GPBFieldNumber(field); //% BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); //% BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); //% if (selfHas != otherHas) { //% context->outIsEqual = NO; //% return NO; //% } //% if (!selfHas) { //% return YES; //% } //% TYPE selfVal = GPBGet##NAME##IvarWithField(context->self, field); //% TYPE otherVal = GPBGet##NAME##IvarWithField(context->other, field); //% if (selfVal != otherVal) { //% context->outIsEqual = NO; //% return NO; //% } //% return YES; //%} //% //%PDDM-EXPAND IS_EQUAL_FUNC(Bool, BOOL) // This block of code is generated, do not edit it directly. static BOOL IsEqualBool(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } BOOL selfVal = GPBGetBoolIvarWithField(context->self, field); BOOL otherVal = GPBGetBoolIvarWithField(context->other, field); if (selfVal != otherVal) { context->outIsEqual = NO; return NO; } return YES; } //%PDDM-EXPAND IS_EQUAL_FUNC(Int32, int32_t) // This block of code is generated, do not edit it directly. static BOOL IsEqualInt32(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } int32_t selfVal = GPBGetInt32IvarWithField(context->self, field); int32_t otherVal = GPBGetInt32IvarWithField(context->other, field); if (selfVal != otherVal) { context->outIsEqual = NO; return NO; } return YES; } //%PDDM-EXPAND IS_EQUAL_FUNC(UInt32, uint32_t) // This block of code is generated, do not edit it directly. static BOOL IsEqualUInt32(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } uint32_t selfVal = GPBGetUInt32IvarWithField(context->self, field); uint32_t otherVal = GPBGetUInt32IvarWithField(context->other, field); if (selfVal != otherVal) { context->outIsEqual = NO; return NO; } return YES; } //%PDDM-EXPAND IS_EQUAL_FUNC(Int64, int64_t) // This block of code is generated, do not edit it directly. static BOOL IsEqualInt64(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } int64_t selfVal = GPBGetInt64IvarWithField(context->self, field); int64_t otherVal = GPBGetInt64IvarWithField(context->other, field); if (selfVal != otherVal) { context->outIsEqual = NO; return NO; } return YES; } //%PDDM-EXPAND IS_EQUAL_FUNC(UInt64, uint64_t) // This block of code is generated, do not edit it directly. static BOOL IsEqualUInt64(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } uint64_t selfVal = GPBGetUInt64IvarWithField(context->self, field); uint64_t otherVal = GPBGetUInt64IvarWithField(context->other, field); if (selfVal != otherVal) { context->outIsEqual = NO; return NO; } return YES; } //%PDDM-EXPAND IS_EQUAL_FUNC(Float, float) // This block of code is generated, do not edit it directly. static BOOL IsEqualFloat(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } float selfVal = GPBGetFloatIvarWithField(context->self, field); float otherVal = GPBGetFloatIvarWithField(context->other, field); if (selfVal != otherVal) { context->outIsEqual = NO; return NO; } return YES; } //%PDDM-EXPAND IS_EQUAL_FUNC(Double, double) // This block of code is generated, do not edit it directly. static BOOL IsEqualDouble(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } double selfVal = GPBGetDoubleIvarWithField(context->self, field); double otherVal = GPBGetDoubleIvarWithField(context->other, field); if (selfVal != otherVal) { context->outIsEqual = NO; return NO; } return YES; } //%PDDM-EXPAND-END (7 expansions) static BOOL IsEqualObject(GPBFieldDescriptor *field, void *voidContext) { IsEqualContext *context = (IsEqualContext *)voidContext; if (GPBFieldIsMapOrArray(field)) { // In the case of a list/map, there is no _hasIvar to worry about checking. // NOTE: These are NSArray/GPB*Array/NSDictionary/GPB*Dictionary, but the // type doesn't really matter as the object just has to support // -count/-isEqual:. NSArray *resultMapOrArray = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSArray *otherMapOrArray = GPBGetObjectIvarWithFieldNoAutocreate(context->other, field); context->outIsEqual = (resultMapOrArray.count == 0 && otherMapOrArray.count == 0) || [resultMapOrArray isEqual:otherMapOrArray]; return context->outIsEqual; } int32_t hasIndex = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); BOOL selfHas = GPBGetHasIvar(context->self, hasIndex, fieldNum); BOOL otherHas = GPBGetHasIvar(context->other, hasIndex, fieldNum); if (selfHas != otherHas) { context->outIsEqual = NO; return NO; } if (!selfHas) { return YES; } // GPBGetObjectIvarWithFieldNoAutocreate skips the has check, faster. NSObject *selfVal = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSObject *otherVal = GPBGetObjectIvarWithFieldNoAutocreate(context->other, field); // This covers case where selfVal is set to nil, as well as shortcuts the call // to isEqual: in common cases. if (selfVal == otherVal) { return YES; } if (![selfVal isEqual:otherVal]) { context->outIsEqual = NO; return NO; } return YES; } - (BOOL)isEqual:(GPBMessage *)other { if (other == self) { return YES; } if (![other isKindOfClass:[self class]] && ![self isKindOfClass:[other class]]) { return NO; } GPBApplyFunctions funcs = GPBAPPLY_FUNCTIONS_INIT(IsEqual); IsEqualContext context = {other, self, YES}; GPBApplyFunctionsToMessageFields(&funcs, self, &context); if (!context.outIsEqual) { return NO; } // nil and empty are equal if (extensionMap_.count != 0 || other->extensionMap_.count != 0) { if (![extensionMap_ isEqual:other->extensionMap_]) { return NO; } } // nil and empty are equal GPBUnknownFieldSet *otherUnknowns = other.unknownFields; if ([unknownFields_ countOfFields] != 0 || [otherUnknowns countOfFields] != 0) { if (![unknownFields_ isEqual:otherUnknowns]) { return NO; } } return YES; } // It is very difficult to implement a generic hash for ProtoBuf messages that // will perform well. If you need hashing on your ProtoBufs (eg you are using // them as dictionary keys) you will probably want to implement a ProtoBuf // message specific hash as a category on your protobuf class. Do not make it a // category on GPBMessage as you will conflict with this hash, and will possibly // override hash for all generated protobufs. A good implementation of hash will // be really fast, so we would recommend only hashing protobufs that have an // identifier field of some kind that you can easily hash. If you implement // hash, we would strongly recommend overriding isEqual: in your category as // well, as the default implementation of isEqual: is extremely slow, and may // drastically affect performance in large sets. - (NSUInteger)hash { GPBDescriptor *descriptor = [[self class] descriptor]; const NSUInteger prime = 19; // Start with the descriptor and then mix it with the field numbers that // are set. Hopefully that will give a spread based on classes and what // fields are set. NSUInteger result = (NSUInteger)descriptor; for (GPBFieldDescriptor *field in descriptor->fields_) { if (GPBFieldIsMapOrArray(field)) { // Exact type doesn't matter, just check if there are any elements. NSArray *mapOrArray = GPBGetObjectIvarWithFieldNoAutocreate(self, field); if (mapOrArray.count) { result = prime * result + GPBFieldNumber(field); } } else if (GPBGetHasIvarField(self, field)) { result = prime * result + GPBFieldNumber(field); } } return result; } #pragma mark - Description Support - (NSString *)description { NSString *textFormat = GPBTextFormatForMessage(self, @" "); NSString *description = [NSString stringWithFormat:@"<%@ %p>: {\n%@}", [self class], self, textFormat]; return description; } #if DEBUG // Xcode 5.1 added support for custom quick look info. // https://developer.apple.com/library/ios/documentation/IDEs/Conceptual/CustomClassDisplay_in_QuickLook/CH01-quick_look_for_custom_objects/CH01-quick_look_for_custom_objects.html#//apple_ref/doc/uid/TP40014001-CH2-SW1 - (id)debugQuickLookObject { return GPBTextFormatForMessage(self, nil); } #endif // DEBUG #pragma mark - SerializedSize Support // Serialized size is only calculated once, and then is stored into // memoizedSerializedSize. typedef struct SerializedSizeContext { GPBMessage *self; size_t outSize; } SerializedSizeContext; //%PDDM-DEFINE SERIALIZED_SIZE_POD_FUNC(NAME, TYPE, REAL_TYPE) //%SERIALIZED_SIZE_POD_FUNC_FULL(NAME, TYPE, REAL_TYPE, REAL_TYPE, ) //%PDDM-DEFINE SERIALIZED_SIZE_POD_FUNC_FULL(NAME, TYPE, REAL_TYPE, ARRAY_TYPE, ARRAY_ACCESSOR_NAME) //%static BOOL DynamicSerializedSize##NAME(GPBFieldDescriptor *field, //% NAME$S void *voidContext) { //% SerializedSizeContext *context = (SerializedSizeContext *)voidContext; //% GPBFieldType fieldType = field.fieldType; //% if (fieldType == GPBFieldTypeRepeated) { //% GPB##ARRAY_TYPE##Array *array = //% GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); //% NSUInteger count = array.count; //% if (count == 0) return YES; //% __block size_t dataSize = 0; //% [array enumerate##ARRAY_ACCESSOR_NAME##ValuesWithBlock:^(TYPE value, NSUInteger idx, BOOL *stop) { //% #pragma unused(idx, stop) //% dataSize += GPBCompute##NAME##SizeNoTag(value); //% }]; //% context->outSize += dataSize; //% size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); //% if (field.isPackable) { //% context->outSize += tagSize; //% context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); //% } else { //% context->outSize += count * tagSize; //% } //% } else if (fieldType == GPBFieldTypeSingle) { //% BOOL selfHas = GPBGetHasIvarField(context->self, field); //% if (selfHas) { //% TYPE selfVal = GPBGet##REAL_TYPE##IvarWithField(context->self, field); //% context->outSize += GPBCompute##NAME##Size(GPBFieldNumber(field), selfVal); //% } //% } else { // fieldType == GPBFieldTypeMap //% // Type will be GPB*##REAL_TYPE##Dictionary, exact type doesn't matter. //% GPBInt32##REAL_TYPE##Dictionary *map = //% GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); //% context->outSize += [map computeSerializedSizeAsField:field]; //% } //% return YES; //%} //% //%PDDM-DEFINE SERIALIZED_SIZE_OBJECT_FUNC(NAME) //%static BOOL DynamicSerializedSize##NAME(GPBFieldDescriptor *field, //% NAME$S void *voidContext) { //% SerializedSizeContext *context = (SerializedSizeContext *)voidContext; //% GPBFieldType fieldType = field.fieldType; //% if (fieldType == GPBFieldTypeRepeated) { //% NSArray *array = //% GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); //% for (id value in array) { //% context->outSize += GPBCompute##NAME##SizeNoTag(value); //% } //% size_t tagSize = GPBComputeWireFormatTagSize(GPBFieldNumber(field), //% GPBGetFieldType(field)); //% context->outSize += array.count * tagSize; //% } else if (fieldType == GPBFieldTypeSingle) { //% BOOL selfHas = GPBGetHasIvarField(context->self, field); //% if (selfHas) { //% // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check //% // again. //% id selfVal = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); //% context->outSize += GPBCompute##NAME##Size(GPBFieldNumber(field), selfVal); //% } //% } else { // fieldType == GPBFieldTypeMap //% GPBType mapKeyType = field.mapKeyType; //% if (mapKeyType == GPBTypeString) { //% // If key type was string, then the map is an NSDictionary. //% NSDictionary *map = //% GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); //% context->outSize += GPBDictionaryComputeSizeInternalHelper(map, field); //% } else { //% // Type will be GPB*##NAME##Dictionary, exact type doesn't matter. //% GPBInt32ObjectDictionary *map = //% GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); //% context->outSize += [map computeSerializedSizeAsField:field]; //% } //% } //% return YES; //%} //% //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(Bool, BOOL, Bool) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeBool(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBBoolArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(BOOL value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeBoolSizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { BOOL selfVal = GPBGetBoolIvarWithField(context->self, field); context->outSize += GPBComputeBoolSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*BoolDictionary, exact type doesn't matter. GPBInt32BoolDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(Int32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeInt32(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(int32_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeInt32SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { int32_t selfVal = GPBGetInt32IvarWithField(context->self, field); context->outSize += GPBComputeInt32Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*Int32Dictionary, exact type doesn't matter. GPBInt32Int32Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(SInt32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeSInt32(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(int32_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeSInt32SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { int32_t selfVal = GPBGetInt32IvarWithField(context->self, field); context->outSize += GPBComputeSInt32Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*Int32Dictionary, exact type doesn't matter. GPBInt32Int32Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(SFixed32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeSFixed32(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(int32_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeSFixed32SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { int32_t selfVal = GPBGetInt32IvarWithField(context->self, field); context->outSize += GPBComputeSFixed32Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*Int32Dictionary, exact type doesn't matter. GPBInt32Int32Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC_FULL(Enum, int32_t, Int32, Enum, Raw) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeEnum(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBEnumArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateRawValuesWithBlock:^(int32_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeEnumSizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { int32_t selfVal = GPBGetInt32IvarWithField(context->self, field); context->outSize += GPBComputeEnumSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*Int32Dictionary, exact type doesn't matter. GPBInt32Int32Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(UInt32, uint32_t, UInt32) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeUInt32(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(uint32_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeUInt32SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { uint32_t selfVal = GPBGetUInt32IvarWithField(context->self, field); context->outSize += GPBComputeUInt32Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*UInt32Dictionary, exact type doesn't matter. GPBInt32UInt32Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(Fixed32, uint32_t, UInt32) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeFixed32(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt32Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(uint32_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeFixed32SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { uint32_t selfVal = GPBGetUInt32IvarWithField(context->self, field); context->outSize += GPBComputeFixed32Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*UInt32Dictionary, exact type doesn't matter. GPBInt32UInt32Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(Int64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeInt64(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(int64_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeInt64SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { int64_t selfVal = GPBGetInt64IvarWithField(context->self, field); context->outSize += GPBComputeInt64Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*Int64Dictionary, exact type doesn't matter. GPBInt32Int64Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(SFixed64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeSFixed64(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(int64_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeSFixed64SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { int64_t selfVal = GPBGetInt64IvarWithField(context->self, field); context->outSize += GPBComputeSFixed64Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*Int64Dictionary, exact type doesn't matter. GPBInt32Int64Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(SInt64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeSInt64(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(int64_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeSInt64SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { int64_t selfVal = GPBGetInt64IvarWithField(context->self, field); context->outSize += GPBComputeSInt64Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*Int64Dictionary, exact type doesn't matter. GPBInt32Int64Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(UInt64, uint64_t, UInt64) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeUInt64(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(uint64_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeUInt64SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { uint64_t selfVal = GPBGetUInt64IvarWithField(context->self, field); context->outSize += GPBComputeUInt64Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*UInt64Dictionary, exact type doesn't matter. GPBInt32UInt64Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(Fixed64, uint64_t, UInt64) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeFixed64(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBUInt64Array *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(uint64_t value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeFixed64SizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { uint64_t selfVal = GPBGetUInt64IvarWithField(context->self, field); context->outSize += GPBComputeFixed64Size(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*UInt64Dictionary, exact type doesn't matter. GPBInt32UInt64Dictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(Float, float, Float) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeFloat(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBFloatArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(float value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeFloatSizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { float selfVal = GPBGetFloatIvarWithField(context->self, field); context->outSize += GPBComputeFloatSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*FloatDictionary, exact type doesn't matter. GPBInt32FloatDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_POD_FUNC(Double, double, Double) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeDouble(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { GPBDoubleArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); NSUInteger count = array.count; if (count == 0) return YES; __block size_t dataSize = 0; [array enumerateValuesWithBlock:^(double value, NSUInteger idx, BOOL *stop) { #pragma unused(idx, stop) dataSize += GPBComputeDoubleSizeNoTag(value); }]; context->outSize += dataSize; size_t tagSize = GPBComputeTagSize(GPBFieldNumber(field)); if (field.isPackable) { context->outSize += tagSize; context->outSize += GPBComputeSizeTSizeAsInt32NoTag(dataSize); } else { context->outSize += count * tagSize; } } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { double selfVal = GPBGetDoubleIvarWithField(context->self, field); context->outSize += GPBComputeDoubleSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap // Type will be GPB*DoubleDictionary, exact type doesn't matter. GPBInt32DoubleDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_OBJECT_FUNC(String) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeString(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); for (id value in array) { context->outSize += GPBComputeStringSizeNoTag(value); } size_t tagSize = GPBComputeWireFormatTagSize(GPBFieldNumber(field), GPBGetFieldType(field)); context->outSize += array.count * tagSize; } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. id selfVal = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBComputeStringSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { // If key type was string, then the map is an NSDictionary. NSDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBDictionaryComputeSizeInternalHelper(map, field); } else { // Type will be GPB*StringDictionary, exact type doesn't matter. GPBInt32ObjectDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_OBJECT_FUNC(Data) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeData(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); for (id value in array) { context->outSize += GPBComputeDataSizeNoTag(value); } size_t tagSize = GPBComputeWireFormatTagSize(GPBFieldNumber(field), GPBGetFieldType(field)); context->outSize += array.count * tagSize; } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. id selfVal = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBComputeDataSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { // If key type was string, then the map is an NSDictionary. NSDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBDictionaryComputeSizeInternalHelper(map, field); } else { // Type will be GPB*DataDictionary, exact type doesn't matter. GPBInt32ObjectDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_OBJECT_FUNC(Message) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeMessage(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); for (id value in array) { context->outSize += GPBComputeMessageSizeNoTag(value); } size_t tagSize = GPBComputeWireFormatTagSize(GPBFieldNumber(field), GPBGetFieldType(field)); context->outSize += array.count * tagSize; } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. id selfVal = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBComputeMessageSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { // If key type was string, then the map is an NSDictionary. NSDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBDictionaryComputeSizeInternalHelper(map, field); } else { // Type will be GPB*MessageDictionary, exact type doesn't matter. GPBInt32ObjectDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } } return YES; } //%PDDM-EXPAND SERIALIZED_SIZE_OBJECT_FUNC(Group) // This block of code is generated, do not edit it directly. static BOOL DynamicSerializedSizeGroup(GPBFieldDescriptor *field, void *voidContext) { SerializedSizeContext *context = (SerializedSizeContext *)voidContext; GPBFieldType fieldType = field.fieldType; if (fieldType == GPBFieldTypeRepeated) { NSArray *array = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); for (id value in array) { context->outSize += GPBComputeGroupSizeNoTag(value); } size_t tagSize = GPBComputeWireFormatTagSize(GPBFieldNumber(field), GPBGetFieldType(field)); context->outSize += array.count * tagSize; } else if (fieldType == GPBFieldTypeSingle) { BOOL selfHas = GPBGetHasIvarField(context->self, field); if (selfHas) { // GPBGetObjectIvarWithFieldNoAutocreate() avoids doing the has check // again. id selfVal = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBComputeGroupSize(GPBFieldNumber(field), selfVal); } } else { // fieldType == GPBFieldTypeMap GPBType mapKeyType = field.mapKeyType; if (mapKeyType == GPBTypeString) { // If key type was string, then the map is an NSDictionary. NSDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += GPBDictionaryComputeSizeInternalHelper(map, field); } else { // Type will be GPB*GroupDictionary, exact type doesn't matter. GPBInt32ObjectDictionary *map = GPBGetObjectIvarWithFieldNoAutocreate(context->self, field); context->outSize += [map computeSerializedSizeAsField:field]; } } return YES; } //%PDDM-EXPAND-END (18 expansions) - (size_t)serializedSize { // Fields. SerializedSizeContext context = {self, 0}; GPBApplyStrictFunctions funcs = GPBAPPLY_STRICT_FUNCTIONS_INIT(DynamicSerializedSize); GPBApplyStrictFunctionsToMessageFields(&funcs, self, &context); // Add any unknown fields. const GPBDescriptor *descriptor = [self descriptor]; if (descriptor.wireFormat) { context.outSize += [unknownFields_ serializedSizeAsMessageSet]; } else { context.outSize += [unknownFields_ serializedSize]; } // Add any extensions. for (GPBExtensionField *extension in extensionMap_) { id value = [extensionMap_ objectForKey:extension]; context.outSize += [extension computeSerializedSizeIncludingTag:value]; } return context.outSize; } #pragma mark - Resolve Methods Support typedef struct IvarAccessorMethodContext { GPBFileSyntax syntax; IMP impToAdd; SEL encodingSelector; } IvarAccessorMethodContext; //%PDDM-DEFINE IVAR_ACCESSOR_FUNC_COMMON(NAME, TYPE, TRUE_NAME) //%static BOOL IvarGet##NAME(GPBFieldDescriptor *field, void *voidContext) { //% IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; //% context->impToAdd = imp_implementationWithBlock(^(id obj) { //% return GPBGet##TRUE_NAME##IvarWithField(obj, field); //% }); //% context->encodingSelector = @selector(get##NAME); //% return NO; //%} //% //%PDDM-DEFINE IVAR_ACCESSOR_FUNC_OBJECT(NAME, TYPE) //%IVAR_ACCESSOR_FUNC_COMMON(NAME, TYPE, Object) //%static BOOL IvarSet##NAME(GPBFieldDescriptor *field, void *voidContext) { //% IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; //% // Local for syntax so the block doesn't capture context and use random //% // memory in the future. //% const GPBFileSyntax syntax = context->syntax; //% context->impToAdd = imp_implementationWithBlock(^(id obj, TYPE value) { //% return GPBSetObjectIvarWithFieldInternal(obj, field, value, syntax); //% }); //% context->encodingSelector = @selector(set##NAME:); //% return NO; //%} //% //%PDDM-DEFINE IVAR_ACCESSOR_FUNC_PER_VERSION(NAME, TYPE) //%IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(NAME, TYPE, NAME) //%PDDM-DEFINE IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(NAME, TYPE, TRUE_NAME) //%IVAR_ACCESSOR_FUNC_COMMON(NAME, TYPE, TRUE_NAME) //%static BOOL IvarSet##NAME(GPBFieldDescriptor *field, void *voidContext) { //% IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; //% // Local for syntax so the block doesn't capture context and use random //% // memory in the future. //% const GPBFileSyntax syntax = context->syntax; //% context->impToAdd = imp_implementationWithBlock(^(id obj, TYPE value) { //% return GPBSet##TRUE_NAME##IvarWithFieldInternal(obj, field, value, syntax); //% }); //% context->encodingSelector = @selector(set##NAME:); //% return NO; //%} //% //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION(Bool, BOOL) // This block of code is generated, do not edit it directly. static BOOL IvarGetBool(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetBoolIvarWithField(obj, field); }); context->encodingSelector = @selector(getBool); return NO; } static BOOL IvarSetBool(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, BOOL value) { return GPBSetBoolIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setBool:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION(Int32, int32_t) // This block of code is generated, do not edit it directly. static BOOL IvarGetInt32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetInt32IvarWithField(obj, field); }); context->encodingSelector = @selector(getInt32); return NO; } static BOOL IvarSetInt32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, int32_t value) { return GPBSetInt32IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setInt32:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(SInt32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL IvarGetSInt32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetInt32IvarWithField(obj, field); }); context->encodingSelector = @selector(getSInt32); return NO; } static BOOL IvarSetSInt32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, int32_t value) { return GPBSetInt32IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setSInt32:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(SFixed32, int32_t, Int32) // This block of code is generated, do not edit it directly. static BOOL IvarGetSFixed32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetInt32IvarWithField(obj, field); }); context->encodingSelector = @selector(getSFixed32); return NO; } static BOOL IvarSetSFixed32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, int32_t value) { return GPBSetInt32IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setSFixed32:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION(UInt32, uint32_t) // This block of code is generated, do not edit it directly. static BOOL IvarGetUInt32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetUInt32IvarWithField(obj, field); }); context->encodingSelector = @selector(getUInt32); return NO; } static BOOL IvarSetUInt32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, uint32_t value) { return GPBSetUInt32IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setUInt32:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(Fixed32, uint32_t, UInt32) // This block of code is generated, do not edit it directly. static BOOL IvarGetFixed32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetUInt32IvarWithField(obj, field); }); context->encodingSelector = @selector(getFixed32); return NO; } static BOOL IvarSetFixed32(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, uint32_t value) { return GPBSetUInt32IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setFixed32:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION(Int64, int64_t) // This block of code is generated, do not edit it directly. static BOOL IvarGetInt64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetInt64IvarWithField(obj, field); }); context->encodingSelector = @selector(getInt64); return NO; } static BOOL IvarSetInt64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, int64_t value) { return GPBSetInt64IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setInt64:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(SFixed64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL IvarGetSFixed64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetInt64IvarWithField(obj, field); }); context->encodingSelector = @selector(getSFixed64); return NO; } static BOOL IvarSetSFixed64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, int64_t value) { return GPBSetInt64IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setSFixed64:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(SInt64, int64_t, Int64) // This block of code is generated, do not edit it directly. static BOOL IvarGetSInt64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetInt64IvarWithField(obj, field); }); context->encodingSelector = @selector(getSInt64); return NO; } static BOOL IvarSetSInt64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, int64_t value) { return GPBSetInt64IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setSInt64:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION(UInt64, uint64_t) // This block of code is generated, do not edit it directly. static BOOL IvarGetUInt64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetUInt64IvarWithField(obj, field); }); context->encodingSelector = @selector(getUInt64); return NO; } static BOOL IvarSetUInt64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, uint64_t value) { return GPBSetUInt64IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setUInt64:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION_ALIASED(Fixed64, uint64_t, UInt64) // This block of code is generated, do not edit it directly. static BOOL IvarGetFixed64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetUInt64IvarWithField(obj, field); }); context->encodingSelector = @selector(getFixed64); return NO; } static BOOL IvarSetFixed64(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, uint64_t value) { return GPBSetUInt64IvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setFixed64:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION(Float, float) // This block of code is generated, do not edit it directly. static BOOL IvarGetFloat(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetFloatIvarWithField(obj, field); }); context->encodingSelector = @selector(getFloat); return NO; } static BOOL IvarSetFloat(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, float value) { return GPBSetFloatIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setFloat:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_PER_VERSION(Double, double) // This block of code is generated, do not edit it directly. static BOOL IvarGetDouble(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetDoubleIvarWithField(obj, field); }); context->encodingSelector = @selector(getDouble); return NO; } static BOOL IvarSetDouble(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, double value) { return GPBSetDoubleIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setDouble:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_OBJECT(String, id) // This block of code is generated, do not edit it directly. static BOOL IvarGetString(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetObjectIvarWithField(obj, field); }); context->encodingSelector = @selector(getString); return NO; } static BOOL IvarSetString(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, id value) { return GPBSetObjectIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setString:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_OBJECT(Data, id) // This block of code is generated, do not edit it directly. static BOOL IvarGetData(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetObjectIvarWithField(obj, field); }); context->encodingSelector = @selector(getData); return NO; } static BOOL IvarSetData(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, id value) { return GPBSetObjectIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setData:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_OBJECT(Message, id) // This block of code is generated, do not edit it directly. static BOOL IvarGetMessage(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetObjectIvarWithField(obj, field); }); context->encodingSelector = @selector(getMessage); return NO; } static BOOL IvarSetMessage(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, id value) { return GPBSetObjectIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setMessage:); return NO; } //%PDDM-EXPAND IVAR_ACCESSOR_FUNC_OBJECT(Group, id) // This block of code is generated, do not edit it directly. static BOOL IvarGetGroup(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetObjectIvarWithField(obj, field); }); context->encodingSelector = @selector(getGroup); return NO; } static BOOL IvarSetGroup(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, id value) { return GPBSetObjectIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setGroup:); return NO; } //%PDDM-EXPAND-END (17 expansions) // Enum gets custom hooks because get needs the syntax to Get. static BOOL IvarGetEnum(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetEnumIvarWithFieldInternal(obj, field, syntax); }); context->encodingSelector = @selector(getEnum); return NO; } static BOOL IvarSetEnum(GPBFieldDescriptor *field, void *voidContext) { IvarAccessorMethodContext *context = (IvarAccessorMethodContext *)voidContext; // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context->syntax; context->impToAdd = imp_implementationWithBlock(^(id obj, int32_t value) { return GPBSetEnumIvarWithFieldInternal(obj, field, value, syntax); }); context->encodingSelector = @selector(setEnum:); return NO; } + (BOOL)resolveInstanceMethod:(SEL)sel { const GPBDescriptor *descriptor = [self descriptor]; if (!descriptor) { return NO; } // NOTE: hasSel_/setHasSel_ will be NULL if the field for the given message // should not have has support (done in GPBDescriptor.m), so there is no need // for checks here to see if has*/setHas* are allowed. IvarAccessorMethodContext context = {descriptor.file.syntax, NULL, NULL}; for (GPBFieldDescriptor *field in descriptor->fields_) { BOOL isMapOrArray = GPBFieldIsMapOrArray(field); if (!isMapOrArray) { if (sel == field->getSel_) { static const GPBApplyStrictFunctions funcs = GPBAPPLY_STRICT_FUNCTIONS_INIT(IvarGet); funcs[GPBGetFieldType(field)](field, &context); break; } else if (sel == field->hasSel_) { int32_t index = GPBFieldHasIndex(field); uint32_t fieldNum = GPBFieldNumber(field); context.impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetHasIvar(obj, index, fieldNum); }); context.encodingSelector = @selector(getBool); break; } else if (sel == field->setHasSel_) { context.impToAdd = imp_implementationWithBlock(^(id obj, BOOL value) { if (value) { [NSException raise:NSInvalidArgumentException format:@"%@: %@ can only be set to NO (to clear field).", [obj class], NSStringFromSelector(field->setHasSel_)]; } GPBClearMessageField(obj, field); }); context.encodingSelector = @selector(setBool:); break; } else if (sel == field->setSel_) { GPBApplyStrictFunctions funcs = GPBAPPLY_STRICT_FUNCTIONS_INIT(IvarSet); funcs[GPBGetFieldType(field)](field, &context); break; } else { GPBOneofDescriptor *oneof = field->containingOneof_; if (oneof && (sel == oneof->caseSel_)) { int32_t index = oneof->oneofDescription_->index; context.impToAdd = imp_implementationWithBlock(^(id obj) { return GPBGetHasOneof(obj, index); }); context.encodingSelector = @selector(getEnum); break; } } } else { if (sel == field->getSel_) { if (field.fieldType == GPBFieldTypeRepeated) { context.impToAdd = imp_implementationWithBlock(^(id obj) { return GetArrayIvarWithField(obj, field); }); } else { context.impToAdd = imp_implementationWithBlock(^(id obj) { return GetMapIvarWithField(obj, field); }); } context.encodingSelector = @selector(getArray); break; } else if (sel == field->setSel_) { // Local for syntax so the block doesn't capture context and use random // memory in the future. const GPBFileSyntax syntax = context.syntax; context.impToAdd = imp_implementationWithBlock(^(id obj, id value) { return GPBSetObjectIvarWithFieldInternal(obj, field, value, syntax); }); context.encodingSelector = @selector(setArray:); break; } } } if (context.impToAdd) { const char *encoding = GPBMessageEncodingForSelector(context.encodingSelector, YES); BOOL methodAdded = class_addMethod(descriptor.messageClass, sel, context.impToAdd, encoding); return methodAdded; } return [super resolveInstanceMethod:sel]; } + (BOOL)resolveClassMethod:(SEL)sel { // Extensions scoped to a Message and looked up via class methods. if (GPBResolveExtensionClassMethod(self, sel)) { return YES; } return [super resolveClassMethod:sel]; } #pragma mark - NSCoding Support + (BOOL)supportsSecureCoding { return YES; } - (instancetype)initWithCoder:(NSCoder *)aDecoder { self = [self init]; if (self) { NSData *data = [aDecoder decodeObjectOfClass:[NSData class] forKey:kGPBDataCoderKey]; if (data.length) { [self mergeFromData:data extensionRegistry:nil]; } } return self; } - (void)encodeWithCoder:(NSCoder *)aCoder { NSData *data = [self data]; if (data.length) { [aCoder encodeObject:data forKey:kGPBDataCoderKey]; } } #pragma mark - KVC Support + (BOOL)accessInstanceVariablesDirectly { // Make sure KVC doesn't use instance variables. return NO; } @end