summaryrefslogtreecommitdiffstats
path: root/clang/test
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2011-03-31 04:46:53 +0000
committerTed Kremenek <kremenek@apple.com>2011-03-31 04:46:53 +0000
commit40d16c0e752485eaf87dc95d1423920aae4f2312 (patch)
tree21ceb773540c179c2f0ea8496f9b6d01e0e999b9 /clang/test
parent61a4f6682ae0837f2590e0cd8e60ce342ea9ff42 (diff)
downloadbcm5719-llvm-40d16c0e752485eaf87dc95d1423920aae4f2312.tar.gz
bcm5719-llvm-40d16c0e752485eaf87dc95d1423920aae4f2312.zip
Static analyzer: fix bug in handling of dynamic_cast<>. The sink node wouldn't always be the final node, thus causing the state to continue propagating. Instead,
recover some path-sensitivity by conjuring a symbol. llvm-svn: 128612
Diffstat (limited to 'clang/test')
-rw-r--r--clang/test/Analysis/misc-ps-region-store.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/clang/test/Analysis/misc-ps-region-store.cpp b/clang/test/Analysis/misc-ps-region-store.cpp
index 26a31526b74..4ead8bb6179 100644
--- a/clang/test/Analysis/misc-ps-region-store.cpp
+++ b/clang/test/Analysis/misc-ps-region-store.cpp
@@ -264,3 +264,17 @@ void rdar9212512() {
}
}
+// Test basic support for dynamic_cast<>.
+struct Rdar9212495_C { virtual void bar() const; };
+class Rdar9212495_B : public Rdar9212495_C {};
+class Rdar9212495_A : public Rdar9212495_B {};
+const Rdar9212495_A& rdar9212495(const Rdar9212495_C* ptr) {
+ const Rdar9212495_A& val = dynamic_cast<const Rdar9212495_A&>(*ptr);
+
+ if (&val == 0) {
+ val.bar(); // FIXME: This should eventually be a null dereference.
+ }
+
+ return val;
+}
+
OpenPOWER on IntegriCloud