From: Ted Kremenek Date: Fri, 13 Mar 2009 20:27:06 +0000 (+0000) Subject: Fix PR 3677 [retain checker]: custom 'allocWithZone' methods should be allowed X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8be2a67620b6be5f2c15dc44099e71b2c8e59ef7;p=clang Fix PR 3677 [retain checker]: custom 'allocWithZone' methods should be allowed to return an owning pointer. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@66934 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/CFRefCount.cpp b/lib/Analysis/CFRefCount.cpp index 75a9f3dca1..b6c11c9cfc 100644 --- a/lib/Analysis/CFRefCount.cpp +++ b/lib/Analysis/CFRefCount.cpp @@ -119,12 +119,15 @@ static NamingConvention deriveNamingConvention(const char* s) { case 4: // Methods starting with 'alloc' or contain 'copy' follow the // create rule - if ((AtBeginning && StringsEqualNoCase("alloc", s, len)) || - (C == NoConvention && StringsEqualNoCase("copy", s, len))) + if (C == NoConvention && StringsEqualNoCase("copy", s, len)) C = CreateRule; else // Methods starting with 'init' follow the init rule. if (AtBeginning && StringsEqualNoCase("init", s, len)) - C = InitRule; + C = InitRule; + break; + case 5: + if (AtBeginning && StringsEqualNoCase("alloc", s, len)) + C = CreateRule; break; } diff --git a/test/Analysis/retain-release.m b/test/Analysis/retain-release.m index c05d730491..c6a05c0031 100644 --- a/test/Analysis/retain-release.m +++ b/test/Analysis/retain-release.m @@ -60,9 +60,10 @@ typedef struct _NSZone NSZone; @end @protocol NSCopying - (id)copyWithZone:(NSZone *)zone; @end @protocol NSMutableCopying - (id)mutableCopyWithZone:(NSZone *)zone; @end @protocol NSCoding - (void)encodeWithCoder:(NSCoder *)aCoder; -@end @interface NSObject { -} +@end +@interface NSObject {} + (id)alloc; ++ (id)allocWithZone:(NSZone *)zone; @end typedef float CGFloat; @interface NSString : NSObject - (NSUInteger)length; - (const char *)UTF8String; @@ -324,3 +325,12 @@ static void rdar_6659160(char *inkind, char *inname) [name release]; } +// PR 3677 - 'allocWithZone' should be treated as following the Cocoa naming +// conventions with respect to 'return'ing ownership. +@interface PR3677: NSObject @end +@implementation PR3677 ++ (id)allocWithZone:(NSZone *)inZone { + return [super allocWithZone:inZone]; // no-warning +} +@end +