// RUN: %clang_analyze_cc1 -analyzer-checker=core,unix.Malloc -analyzer-store=region -verify -Wno-objc-root-class -fblocks %s #include "Inputs/system-header-simulator-objc.h" @class NSString; typedef __typeof(sizeof(int)) size_t; void *malloc(size_t); void free(void *); // RDar10579586 - Test use of malloc() with Objective-C string literal as a // test condition. Not really a malloc() issue, but this also exercises // the check that malloc() returns uninitialized memory. @interface RDar10579586 struct rdar0579586_str { char str_c; }; @end void rdar10579586(char x); @implementation RDar10579586 + (NSString *)foobar { struct rdar0579586_str *buffer = ((void*)0); NSString *error = ((void*)0); if ((buffer = malloc(sizeof(struct rdar0579586_str))) == ((void*)0)) error = @"buffer allocation failure"; if (error != ((void*)0)) return error; rdar10579586(buffer->str_c); // expected-warning {{1st function call argument is an uninitialized value}} free(buffer); return ((void*)0); } @end @interface MyArray : NSObject { id * objects; } @end void _ArrayCreate() { MyArray *array = (MyArray *)malloc(12); array = [array init]; free(array); // no-warning } void testNSDataTruePositiveLeak() { char *b = (char *)malloc(12); NSData *d = [[NSData alloc] initWithBytes: b length: 12]; // expected-warning {{Potential leak of memory pointed to by 'b'}} } id wrapInNSValue() { void *buffer = malloc(4); return [NSValue valueWithPointer:buffer]; // no-warning } |