From: Ted Kremenek Date: Fri, 19 Sep 2008 04:56:32 +0000 (+0000) Subject: Added test case for PR 2600: proper use of NSError** X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1cd920a1cb2aa4ccc9b098f645563627ea820d1a;p=clang Added test case for PR 2600: proper use of NSError** git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56332 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/Analysis/CheckNSError.m b/test/Analysis/CheckNSError.m new file mode 100644 index 0000000000..9e99c34d20 --- /dev/null +++ b/test/Analysis/CheckNSError.m @@ -0,0 +1,31 @@ +// RUN: clang -checker-cfref -verify %s + +typedef signed char BOOL; +typedef int NSInteger; +typedef struct _NSZone NSZone; +@class NSInvocation, NSMethodSignature, NSCoder, NSString, NSEnumerator; +@protocol NSObject - (BOOL)isEqual:(id)object; @end +@protocol NSCopying - (id)copyWithZone:(NSZone *)zone; @end +@protocol NSCoding - (void)encodeWithCoder:(NSCoder *)aCoder; @end +@interface NSObject {} @end +@class NSDictionary; +@interface NSError : NSObject {} ++ (id)errorWithDomain:(NSString *)domain code:(NSInteger)code userInfo:(NSDictionary *)dict; +@end +extern NSString * const NSXMLParserErrorDomain ; + +@interface A +- (void)myMethodWhichMayFail:(NSError **)error; +- (BOOL)myMethodWhichMayFail2:(NSError **)error; +@end + +@implementation A +- (void)myMethodWhichMayFail:(NSError **)error { // expected-warning: {{Method accepting NSError** argument should have non-void return value to indicate that an error occurred.}} + *error = [NSError errorWithDomain:@"domain" code:1 userInfo:0]; // expected-warning: {{Potential null dereference.}} +} + +- (BOOL)myMethodWhichMayFail2:(NSError **)error { // no-warning + if (error) *error = [NSError errorWithDomain:@"domain" code:1 userInfo:0]; // no-warning + return 0; +} +@end