blob: 1a78940eee25e7577f9e4ca4cbab039002e2da86 [file] [log] [blame]
Ted Kremenekcdc3a892012-08-24 20:39:55 +00001// RUN: %clang_cc1 -analyze -analyzer-checker=core,alpha.core -analyzer-store=region -verify %s
Andy Gibbs8e8fb3b2012-10-19 12:44:48 +00002// expected-no-diagnostics
Ted Kremenekc5302912009-03-05 20:22:13 +00003
4// Test function pointer casts. Currently we track function addresses using
5// loc::FunctionVal. Because casts can be arbitrary, do we need to model
6// functions with regions?
Ted Kremenek5c42f9b2009-03-05 22:47:06 +00007typedef void* (*MyFuncTest1)(void);
Ted Kremenekc5302912009-03-05 20:22:13 +00008
9MyFuncTest1 test1_aux(void);
10void test1(void) {
11 void *x;
12 void* (*p)(void);
13 p = ((void*) test1_aux());
14 if (p != ((void*) 0)) x = (*p)();
15}
Ted Kremenek5c42f9b2009-03-05 22:47:06 +000016
17// Test casts from void* to function pointers. Same issue as above:
18// should we eventually model function pointers using regions?
19void* test2(void *p) {
20 MyFuncTest1 fp = (MyFuncTest1) p;
21 return (*fp)();
22}
Anna Zaksf7afe4a2011-09-12 17:56:08 +000023
24// <radar://10087620>
25// A cast from int onjective C property reference to int.
26typedef signed char BOOL;
27@protocol NSObject - (BOOL)isEqual:(id)object; @end
28@interface NSObject <NSObject> {} - (id)init; @end
29typedef enum {
Anna Zaks773d8472011-09-12 18:28:35 +000030 EEOne,
31 EETwo
32} RDR10087620Enum;
33@interface RDR10087620 : NSObject {
34 RDR10087620Enum elem;
Anna Zaksf7afe4a2011-09-12 17:56:08 +000035}
Anna Zaks773d8472011-09-12 18:28:35 +000036@property (readwrite, nonatomic) RDR10087620Enum elem;
John McCall4b9c2d22011-11-06 09:01:30 +000037@end
38
Anna Zaksf7afe4a2011-09-12 17:56:08 +000039static void
Anna Zaks773d8472011-09-12 18:28:35 +000040adium_media_ready_cb(RDR10087620 *InObj)
Anna Zaksf7afe4a2011-09-12 17:56:08 +000041{
Anna Zaks773d8472011-09-12 18:28:35 +000042 InObj.elem |= EEOne;
Anna Zaksf7afe4a2011-09-12 17:56:08 +000043}