aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2010-02-05 06:10:46 +0000
committerTed Kremenek <kremenek@apple.com>2010-02-05 06:10:46 +0000
commitcada305b86cdcfe4f8ceb7007736522a98c0f403 (patch)
treee015a288601d687ef9929437469c1060309db055
parent72119c478ffb35354bb168890c77e6ab5271ba06 (diff)
Add test case showing the analyzer invalidates '__block' variables when the block is passed as an argument to an ObjC method.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@95366 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--test/Analysis/misc-ps-region-store.m13
1 files changed, 13 insertions, 0 deletions
diff --git a/test/Analysis/misc-ps-region-store.m b/test/Analysis/misc-ps-region-store.m
index 20284fe95b..6666dae2ed 100644
--- a/test/Analysis/misc-ps-region-store.m
+++ b/test/Analysis/misc-ps-region-store.m
@@ -590,6 +590,19 @@ int blocks_2(int *p, int z) {
return z;
}
+// Test that the value of 'x' is considered invalidated after the block
+// is passed as an argument to the message expression.
+typedef void (^RDar7582031CB)(void);
+@interface RDar7582031
+- rdar7582031:RDar7582031CB;
+@end
+
+unsigned rdar7582031(RDar7582031 *o) {
+ __block unsigned x;
+ [o rdar7582031:^{ x = 1; }];
+ return x; // no-warning
+}
+
//===----------------------------------------------------------------------===//
// <rdar://problem/7462324> - Test that variables passed using __blocks
// are not treated as being uninitialized.