@ -108,6 +108,7 @@ static id GetOrCreateMapIvarWithField(GPBMessage *self, GPBFieldDescriptor *fiel
static id GetMapIvarWithField ( GPBMessage * self , GPBFieldDescriptor * field ) ;
static id GetMapIvarWithField ( GPBMessage * self , GPBFieldDescriptor * field ) ;
static NSMutableDictionary * CloneExtensionMap ( NSDictionary * extensionMap , NSZone * zone )
static NSMutableDictionary * CloneExtensionMap ( NSDictionary * extensionMap , NSZone * zone )
__attribute__ ( ( ns_returns_retained ) ) ;
__attribute__ ( ( ns_returns_retained ) ) ;
static GPBUnknownFieldSet * GetOrMakeUnknownFields ( GPBMessage * self ) ;
#ifdef DEBUG
#ifdef DEBUG
static NSError * MessageError ( NSInteger code , NSDictionary * userInfo ) {
static NSError * MessageError ( NSInteger code , NSDictionary * userInfo ) {
@ -638,6 +639,7 @@ static id GetMapIvarWithField(GPBMessage *self, GPBFieldDescriptor *field) {
#endif / / !defined ( __clang_analyzer__ )
#endif / / !defined ( __clang_analyzer__ )
static id NewSingleValueFromInputStream ( GPBExtensionDescriptor * extension ,
static id NewSingleValueFromInputStream ( GPBExtensionDescriptor * extension ,
GPBMessage * messageToGetExtension ,
GPBCodedInputStream * input ,
GPBCodedInputStream * input ,
id < GPBExtensionRegistry > extensionRegistry ,
id < GPBExtensionRegistry > extensionRegistry ,
GPBMessage * existingValue )
GPBMessage * existingValue )
@ -645,6 +647,7 @@ static id NewSingleValueFromInputStream(GPBExtensionDescriptor *extension,
/ / Note that this returns a retained value intentionally .
/ / Note that this returns a retained value intentionally .
static id NewSingleValueFromInputStream ( GPBExtensionDescriptor * extension ,
static id NewSingleValueFromInputStream ( GPBExtensionDescriptor * extension ,
GPBMessage * messageToGetExtension ,
GPBCodedInputStream * input ,
GPBCodedInputStream * input ,
id < GPBExtensionRegistry > extensionRegistry ,
id < GPBExtensionRegistry > extensionRegistry ,
GPBMessage * existingValue ) {
GPBMessage * existingValue ) {
@ -681,8 +684,20 @@ static id NewSingleValueFromInputStream(GPBExtensionDescriptor *extension,
return GPBCodedInputStreamReadRetainedBytes ( state ) ;
return GPBCodedInputStreamReadRetainedBytes ( state ) ;
case GPBDataTypeString :
case GPBDataTypeString :
return GPBCodedInputStreamReadRetainedString ( state ) ;
return GPBCodedInputStreamReadRetainedString ( state ) ;
case GPBDataTypeEnum :
case GPBDataTypeEnum : {
return [ [ NSNumber alloc ] initWithInt : GPBCodedInputStreamReadEnum ( state ) ] ;
int32_t val = GPBCodedInputStreamReadEnum ( & input - > state_ ) ;
GPBEnumDescriptor * enumDescriptor = extension . enumDescriptor ;
/ / If run with source generated before the closed enum support , all enums
/ / will be considers not closed , so casing to the enum type for a switch
/ / could cause things to fall off the end of a switch .
if ( !enumDescriptor . isClosed || enumDescriptor . enumVerifier ( val ) ) {
return [ [ NSNumber alloc ] initWithInt : val ] ;
} else {
GPBUnknownFieldSet * unknownFields = GetOrMakeUnknownFields ( messageToGetExtension ) ;
[ unknownFields mergeVarintField : extension - > description_ - > fieldNumber value : val ] ;
return nil ;
}
}
case GPBDataTypeGroup :
case GPBDataTypeGroup :
case GPBDataTypeMessage : {
case GPBDataTypeMessage : {
GPBMessage * message ;
GPBMessage * message ;
@ -726,9 +741,11 @@ static void ExtensionMergeFromInputStream(GPBExtensionDescriptor *extension, BOO
int32_t length = GPBCodedInputStreamReadInt32 ( state ) ;
int32_t length = GPBCodedInputStreamReadInt32 ( state ) ;
size_t limit = GPBCodedInputStreamPushLimit ( state , length ) ;
size_t limit = GPBCodedInputStreamPushLimit ( state , length ) ;
while ( GPBCodedInputStreamBytesUntilLimit ( state ) > 0 ) {
while ( GPBCodedInputStreamBytesUntilLimit ( state ) > 0 ) {
id value = NewSingleValueFromInputStream ( extension , input , extensionRegistry , nil ) ;
id value = NewSingleValueFromInputStream ( extension , message , input , extensionRegistry , nil ) ;
[ message addExtension : extension value : value ] ;
if ( value ) {
[ value release ] ;
[ message addExtension : extension value : value ] ;
[ value release ] ;
}
}
}
GPBCodedInputStreamPopLimit ( state , limit ) ;
GPBCodedInputStreamPopLimit ( state , limit ) ;
} else {
} else {
@ -737,13 +754,16 @@ static void ExtensionMergeFromInputStream(GPBExtensionDescriptor *extension, BOO
if ( !isRepeated && GPBDataTypeIsMessage ( description - > dataType ) ) {
if ( !isRepeated && GPBDataTypeIsMessage ( description - > dataType ) ) {
existingValue = [ message getExistingExtension : extension ] ;
existingValue = [ message getExistingExtension : extension ] ;
}
}
id value = NewSingleValueFromInputStream ( extension , input , extensionRegistry , existingValue ) ;
id value =
if ( isRepeated ) {
NewSingleValueFromInputStream ( extension , message , input , extensionRegistry , existingValue ) ;
[ message addExtension : extension value : value ] ;
if ( value ) {
} else {
if ( isRepeated ) {
[ message setExtension : extension value : value ] ;
[ message addExtension : extension value : value ] ;
} else {
[ message setExtension : extension value : value ] ;
}
[ value release ] ;
}
}
[ value release ] ;
}
}
}
}