// RUN: %clang_cc1 -analyze -analyzer-experimental-internal-checks -analyzer-check-dead-stores -verify %s typedef signed char BOOL; typedef unsigned int NSUInteger; 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 extern id NSAllocateObject(Class aClass, NSUInteger extraBytes, NSZone *zone); @interface NSValue : NSObject - (void)getValue:(void *)value; @end typedef float CGFloat; typedef struct _NSPoint {} NSRange; @interface NSValue (NSValueRangeExtensions) + (NSValue *)valueWithRange:(NSRange)range; - (BOOL)containsObject:(id)anObject; @end @class NSURLAuthenticationChallenge; @interface NSResponder : NSObject {} @end @class NSArray, NSDictionary, NSString; @interface NSObject (NSKeyValueBindingCreation) + (void)exposeBinding:(NSString *)binding; - (NSArray *)exposedBindings; @end extern NSString *NSAlignmentBinding; // This test case was reported as a false positive due to a bug in the // LiveVariables <-> DeadStores interplay. We should not flag a warning // here. The test case was reported in: // http://lists.cs.uiuc.edu/pipermail/cfe-dev/2008-July/002157.html void DeadStoreTest(NSObject *anObject) { NSArray *keys; if ((keys = [anObject exposedBindings]) && // no-warning ([keys containsObject:@"name"] && [keys containsObject:@"icon"])) {} } // This test case was a false positive due to how clang models // pointer types and ObjC object pointer types differently. Here // we don't warn about a dead store because 'nil' is assigned to // an object pointer for the sake of defensive programming. void rdar_7631278(NSObject *x) { x = ((void*)0); }