check for nil

git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@37318 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
rfm 2013-10-29 15:31:24 +00:00
parent 07152c53ae
commit 5ecbbfe3bb

View file

@ -131,6 +131,8 @@ static IMP unlockImp;
*/ */
static NSDictionary* static NSDictionary*
cacheAttributes(NSDictionary *attrs) cacheAttributes(NSDictionary *attrs)
{
if (nil != attrs)
{ {
GSIMapNode node; GSIMapNode node;
@ -138,12 +140,13 @@ cacheAttributes(NSDictionary *attrs)
node = GSIMapNodeForKey(&attrMap, (GSIMapKey)((id)attrs)); node = GSIMapNodeForKey(&attrMap, (GSIMapKey)((id)attrs));
if (node == 0) if (node == 0)
{ {
/* /* Shallow copy of dictionary, without copying objects ....
* Shallow copy of dictionary, without copying objects ... results * result in an immutable dictionary that can safely be cached.
* in an immutable dictionary that can safely be cached.
*/ */
attrs = [[NSDictionary alloc] initWithDictionary: attrs copyItems: NO]; attrs = [[NSDictionary alloc] initWithDictionary: attrs
GSIMapAddPair(&attrMap, (GSIMapKey)((id)attrs), (GSIMapVal)(NSUInteger)1); copyItems: NO];
GSIMapAddPair(&attrMap,
(GSIMapKey)((id)attrs), (GSIMapVal)(NSUInteger)1);
} }
else else
{ {
@ -151,6 +154,7 @@ cacheAttributes(NSDictionary *attrs)
attrs = RETAIN(node->key.obj); attrs = RETAIN(node->key.obj);
} }
AUNLOCK(); AUNLOCK();
}
return attrs; return attrs;
} }
@ -159,6 +163,8 @@ cacheAttributes(NSDictionary *attrs)
*/ */
static void static void
unCacheAttributes(NSDictionary *attrs) unCacheAttributes(NSDictionary *attrs)
{
if (nil != attrs)
{ {
GSIMapBucket bucket; GSIMapBucket bucket;
NSDictionary *found; NSDictionary *found;
@ -170,7 +176,8 @@ unCacheAttributes(NSDictionary *attrs)
{ {
GSIMapNode node; GSIMapNode node;
node = GSIMapNodeForKeyInBucket(&attrMap, bucket, (GSIMapKey)((id)attrs)); node = GSIMapNodeForKeyInBucket(&attrMap,
bucket, (GSIMapKey)((id)attrs));
if (node != 0) if (node != 0)
{ {
found = node->key.obj; found = node->key.obj;
@ -185,6 +192,7 @@ unCacheAttributes(NSDictionary *attrs)
NSCAssert(found == attrs, NSInternalInconsistencyException); NSCAssert(found == attrs, NSInternalInconsistencyException);
RELEASE(found); RELEASE(found);
} }
}