Author: kremenek
Date: Wed Feb 18 22:07:38 2009
New Revision: 65004

URL: http://llvm.org/viewvc/llvm-project?rev=65004&view=rev
Log:
Add test case for 'nil receiver returns undefined struct value' check.

Added:
    cfe/trunk/test/Analysis/rdar-6600344-nil-receiver-undefined-struct-ret.m

Added: cfe/trunk/test/Analysis/rdar-6600344-nil-receiver-undefined-struct-ret.m
URL: 
http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Analysis/rdar-6600344-nil-receiver-undefined-struct-ret.m?rev=65004&view=auto

==============================================================================
--- cfe/trunk/test/Analysis/rdar-6600344-nil-receiver-undefined-struct-ret.m 
(added)
+++ cfe/trunk/test/Analysis/rdar-6600344-nil-receiver-undefined-struct-ret.m 
Wed Feb 18 22:07:38 2009
@@ -0,0 +1,19 @@
+// RUN: clang -analyze -checker-cfref -analyzer-constraints=basic 
-analyzer-store=basic %s -verify
+
+typedef struct Foo { int x; } Bar;
+
+...@interface MyClass {}
+- (Bar)foo;
+...@end
+...@implementation MyClass
+- (Bar)foo { 
+  struct Foo f = { 0 };
+  return f;
+}
+...@end
+
+void createFoo() {
+  MyClass *obj = 0;  
+  Bar f = [obj foo]; // expected-warning{{The receiver in the message 
expression is 'nil' and results in the returned value (of type 'Bar') to be 
garbage or otherwise undefined.}}
+}
+


_______________________________________________
cfe-commits mailing list
[email protected]
http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits

Reply via email to