diff options
author | Ted Kremenek <kremenek@apple.com> | 2009-03-13 20:27:06 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2009-03-13 20:27:06 +0000 |
commit | 8be2a67620b6be5f2c15dc44099e71b2c8e59ef7 (patch) | |
tree | 8a4f06345135d501c3cb9ecb56447b26c9230a38 | |
parent | 9d25423797de98f4e286fd681a6bbe5b48b0493a (diff) |
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
-rw-r--r-- | lib/Analysis/CFRefCount.cpp | 9 | ||||
-rw-r--r-- | test/Analysis/retain-release.m | 14 |
2 files changed, 18 insertions, 5 deletions
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 <NSObject> { -} +@end +@interface NSObject <NSObject> {} + (id)alloc; ++ (id)allocWithZone:(NSZone *)zone; @end typedef float CGFloat; @interface NSString : NSObject <NSCopying, NSMutableCopying, NSCoding> - (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 + |