]> granicus.if.org Git - clang/commitdiff
[analyzer] BugReporterVisitors: handle the case where a ternary operator is wrapped...
authorAnna Zaks <ganna@apple.com>
Fri, 15 Mar 2013 23:34:25 +0000 (23:34 +0000)
committerAnna Zaks <ganna@apple.com>
Fri, 15 Mar 2013 23:34:25 +0000 (23:34 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@177205 91177308-0d34-0410-b5e6-96231b3b80d8

lib/StaticAnalyzer/Core/BugReporterVisitors.cpp
test/Analysis/inlining/false-positive-suppression.c

index d5b4714451dc0f5d4f15031b64b22339f27d4988..6e5f6b8f2c0d5820c2ac9f7f8e6f49feb7abedd3 100644 (file)
@@ -787,14 +787,17 @@ bool bugreporter::trackNullOrUndefValue(const ExplodedNode *N,
     S = OVE->getSourceExpr();
 
   // Peel off the ternary operator.
-  if (const ConditionalOperator *CO = dyn_cast<ConditionalOperator>(S)) {
-    ProgramStateRef State = N->getState();
-    SVal CondVal = State->getSVal(CO->getCond(), N->getLocationContext());
-    if (State->isNull(CondVal).isConstrainedTrue()) {
-      S = CO->getTrueExpr();
-    } else {
-      assert(State->isNull(CondVal).isConstrainedFalse());
-      S =  CO->getFalseExpr();
+  if (const Expr *Ex = dyn_cast<Expr>(S)) {
+    Ex = Ex->IgnoreParenCasts();
+    if (const ConditionalOperator *CO = dyn_cast<ConditionalOperator>(Ex)) {
+      ProgramStateRef State = N->getState();
+      SVal CondVal = State->getSVal(CO->getCond(), N->getLocationContext());
+      if (State->isNull(CondVal).isConstrainedTrue()) {
+        S = CO->getTrueExpr();
+      } else {
+        assert(State->isNull(CondVal).isConstrainedFalse());
+        S =  CO->getFalseExpr();
+      }
     }
   }
 
index fbdb1650ff409d404fde086d834768d2277c9d92..31ad8917621689ab27ac0f0aaf9d08314644abd1 100644 (file)
@@ -202,6 +202,17 @@ void ternaryArg(char cond) {
        derefArg(cond ? &x : getNull());
 }
 
+int derefArgCast(char *p) {
+       return *p;
+#ifndef SUPPRESSED
+  // expected-warning@-2 {{Dereference of null pointer}}
+#endif
+}
+void ternaryArgCast(char cond) {
+       static int x;
+       derefArgCast((char*)((unsigned)cond ? &x : getNull()));
+}
+
 int derefAssignment(int *p) {
        return *p;
 #ifndef SUPPRESSED