blob: 7ac65cc1d2b21c902b03f9c9411a3b58ebabb5e7 [file] [log] [blame]
Dominic Chen184c6242017-03-03 18:02:02 +00001// RUN: %clang_analyze_cc1 -analyzer-checker=core,osx.coreFoundation.CFNumber,osx.cocoa.RetainCount -analyzer-store=region -verify -triple x86_64-apple-darwin9 %s
Ted Kremenekcf1ab192008-06-26 23:59:48 +00002
3typedef signed long CFIndex;
4typedef const struct __CFAllocator * CFAllocatorRef;
5enum { kCFNumberSInt8Type = 1, kCFNumberSInt16Type = 2,
6 kCFNumberSInt32Type = 3, kCFNumberSInt64Type = 4,
7 kCFNumberFloat32Type = 5, kCFNumberFloat64Type = 6,
8 kCFNumberCharType = 7, kCFNumberShortType = 8,
9 kCFNumberIntType = 9, kCFNumberLongType = 10,
10 kCFNumberLongLongType = 11, kCFNumberFloatType = 12,
11 kCFNumberDoubleType = 13, kCFNumberCFIndexType = 14,
12 kCFNumberNSIntegerType = 15, kCFNumberCGFloatType = 16,
13 kCFNumberMaxType = 16 };
14typedef CFIndex CFNumberType;
15typedef const struct __CFNumber * CFNumberRef;
Anna Zaks5b2b3902016-10-26 22:51:47 +000016typedef unsigned char Boolean;
Ted Kremenekcf1ab192008-06-26 23:59:48 +000017extern CFNumberRef CFNumberCreate(CFAllocatorRef allocator, CFNumberType theType, const void *valuePtr);
Anna Zaks5b2b3902016-10-26 22:51:47 +000018Boolean CFNumberGetValue(CFNumberRef number, CFNumberType theType, void *valuePtr);
Ted Kremenekcf1ab192008-06-26 23:59:48 +000019
Anna Zaks5b2b3902016-10-26 22:51:47 +000020__attribute__((cf_returns_retained)) CFNumberRef f1(unsigned char x) {
21 return CFNumberCreate(0, kCFNumberSInt16Type, &x); // expected-warning{{An 8-bit integer is used to initialize a CFNumber object that represents a 16-bit integer; 8 bits of the CFNumber value will be garbage}}
Ted Kremenekcf1ab192008-06-26 23:59:48 +000022}
23
Ted Kremenek8e2c9b02011-05-25 06:19:45 +000024__attribute__((cf_returns_retained)) CFNumberRef f2(unsigned short x) {
Anna Zaks5b2b3902016-10-26 22:51:47 +000025 return CFNumberCreate(0, kCFNumberSInt8Type, &x); // expected-warning{{A 16-bit integer is used to initialize a CFNumber object that represents an 8-bit integer; 8 bits of the integer value will be lost}}
Ted Kremenekcf1ab192008-06-26 23:59:48 +000026}
Ted Kremenek137fc0e2008-09-18 00:28:23 +000027
Ted Kremenek86d49ce2011-05-25 06:29:39 +000028// test that the attribute overrides the naming convention.
29__attribute__((cf_returns_not_retained)) CFNumberRef CreateNum(unsigned char x) {
30 return CFNumberCreate(0, kCFNumberSInt8Type, &x); // expected-warning{{leak}}
31}
32
Anna Zaks5b2b3902016-10-26 22:51:47 +000033__attribute__((cf_returns_retained)) CFNumberRef f3(unsigned i) {
34 return CFNumberCreate(0, kCFNumberLongType, &i); // expected-warning{{A 32-bit integer is used to initialize a CFNumber object that represents a 64-bit integer}}
35}
36
37unsigned char getValueTest1(CFNumberRef x) {
38 unsigned char scalar = 0;
39 CFNumberGetValue(x, kCFNumberSInt16Type, &scalar); // expected-warning{{A CFNumber object that represents a 16-bit integer is used to initialize an 8-bit integer; 8 bits of the CFNumber value will overwrite adjacent storage}}
40 return scalar;
41}
42
43unsigned char getValueTest2(CFNumberRef x) {
44 unsigned short scalar = 0;
45 CFNumberGetValue(x, kCFNumberSInt8Type, &scalar); // expected-warning{{A CFNumber object that represents an 8-bit integer is used to initialize a 16-bit integer; 8 bits of the integer value will be garbage}}
46 return scalar;
Daniel Dunbar7dd97b12009-01-20 01:27:09 +000047}