From: Ted Kremenek Date: Mon, 11 May 2009 17:45:06 +0000 (+0000) Subject: Add test case for . X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a0cc00dfb19897873cba1a1ff29e09a7f6ef9562;p=clang Add test case for . git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71444 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/Analysis/retain-release.m b/test/Analysis/retain-release.m index 162e2652ce..1c0bb964b2 100644 --- a/test/Analysis/retain-release.m +++ b/test/Analysis/retain-release.m @@ -129,6 +129,17 @@ typedef mach_error_t DAReturn; typedef const struct __DADissenter * DADissenterRef; extern DADissenterRef DADissenterCreate( CFAllocatorRef allocator, DAReturn status, CFStringRef string ); + @interface NSArray : NSObject + - (NSUInteger)count; + + (id)array; + @end + +@interface NSAutoreleasePool : NSObject {} ++ (void)addObject:(id)anObject; +- (void)addObject:(id)anObject; +- (void)drain; +@end + //===----------------------------------------------------------------------===// // Test cases. //===----------------------------------------------------------------------===// @@ -488,6 +499,18 @@ void rdar6704930(unsigned char *s, unsigned int length) { } @end +//===----------------------------------------------------------------------===// +// clang checker fails to catch use-after-release +//===----------------------------------------------------------------------===// + +int rdar_6257780() { + NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init]; + NSArray *array = [NSArray array]; + [array release]; // expected-warning{{Incorrect decrement of the reference count of an object is not owned at this point by the caller}} + [pool drain]; + return 0; +} + //===----------------------------------------------------------------------===// // Tests of ownership attributes. //===----------------------------------------------------------------------===//