Fix object ID parsing in XIB loading due to Apple moving to string ID represenatation

git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gui/branches/gnustep_testplant_branch@38224 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
Marcian Lytwyn 2014-12-02 20:36:00 +00:00
parent 9065c08f32
commit 34bcb2c7c4
2 changed files with 10 additions and 21 deletions

View file

@ -121,14 +121,14 @@
@interface IBObjectRecord: NSObject @interface IBObjectRecord: NSObject
{ {
int objectID; id objectID;
id object; id object;
id children; id children;
id parent; id parent;
} }
- (id) object; - (id) object;
- (id) parent; - (id) parent;
- (NSInteger) objectID; - (id) objectID;
@end @end
@interface IBMutableOrderedSet: NSObject @interface IBMutableOrderedSet: NSObject
@ -136,7 +136,7 @@
NSArray *orderedObjects; NSArray *orderedObjects;
} }
- (NSArray *)orderedObjects; - (NSArray *)orderedObjects;
- (id) objectWithObjectID: (NSInteger)objID; - (id) objectWithObjectID: (id)objID;
@end @end
@interface IBObjectContainer: NSObject <NSCoding> @interface IBObjectContainer: NSObject <NSCoding>

View file

@ -564,23 +564,12 @@
if ([coder containsValueForKey: @"objectID"]) if ([coder containsValueForKey: @"objectID"])
{ {
// PRE-4.6 XIBs.... // PRE-4.6 XIBs....
objectID = [coder decodeIntForKey: @"objectID"]; objectID = [coder decodeObjectForKey: @"objectID"];
} }
else if ([coder containsValueForKey: @"id"]) else if ([coder containsValueForKey: @"id"])
{ {
// 4.6+ XIBs.... // 4.6+ XIBs....
NSString *string = [coder decodeObjectForKey: @"id"]; objectID = [coder decodeObjectForKey: @"id"];
if (string && [string isKindOfClass:[NSString class]] && [string length])
{
objectID = [string intValue];
}
else
{
NSString *format = [NSString stringWithFormat:@"%s:class: %@ - object ID is missing or zero!",
__PRETTY_FUNCTION__, NSStringFromClass([self class])];
[NSException raise: NSInvalidArgumentException
format: format];
}
} }
else else
{ {
@ -632,7 +621,7 @@
return parent; return parent;
} }
- (NSInteger) objectID - (id) objectID
{ {
return objectID; return objectID;
} }
@ -678,7 +667,7 @@
return orderedObjects; return orderedObjects;
} }
- (id) objectWithObjectID: (NSInteger)objID - (id) objectWithObjectID: (id)objID
{ {
NSEnumerator *en; NSEnumerator *en;
IBObjectRecord *obj; IBObjectRecord *obj;
@ -686,7 +675,7 @@
en = [orderedObjects objectEnumerator]; en = [orderedObjects objectEnumerator];
while ((obj = [en nextObject]) != nil) while ((obj = [en nextObject]) != nil)
{ {
if ([obj objectID] == objID) if ([[obj objectID] isEqual:objID])
{ {
return [obj object]; return [obj object];
} }
@ -760,7 +749,7 @@
return [[objectRecords orderedObjects] objectEnumerator]; return [[objectRecords orderedObjects] objectEnumerator];
} }
- (NSDictionary*) propertiesForObjectID: (int)objectID - (NSDictionary*) propertiesForObjectID: (id)objectID
{ {
NSEnumerator *en; NSEnumerator *en;
NSString *idString; NSString *idString;
@ -768,7 +757,7 @@
NSMutableDictionary *properties; NSMutableDictionary *properties;
int idLength; int idLength;
idString = [NSString stringWithFormat: @"%d.", objectID]; idString = [NSString stringWithFormat: @"%@.", objectID];
idLength = [idString length]; idLength = [idString length];
properties = [[NSMutableDictionary alloc] init]; properties = [[NSMutableDictionary alloc] init];
en = [flattenedProperties keyEnumerator]; en = [flattenedProperties keyEnumerator];