]> granicus.if.org Git - clang/commitdiff
Register CallAndMessageChecker before AttrNonNullChecker. Then we can assume
authorZhongxing Xu <xuzhongxing@gmail.com>
Wed, 16 Jun 2010 05:45:09 +0000 (05:45 +0000)
committerZhongxing Xu <xuzhongxing@gmail.com>
Wed, 16 Jun 2010 05:45:09 +0000 (05:45 +0000)
arguments are not undefined.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@106083 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Checker/AttrNonNullChecker.cpp
lib/Checker/GRExprEngine.cpp

index 309a74ce544b5463a21f96a4e3b9311d347f65a6..471cf19717038d4798b09192af97a128a1219f38 100644 (file)
@@ -60,15 +60,11 @@ void AttrNonNullChecker::PreVisitCallExpr(CheckerContext &C,
     if (!Att->isNonNull(idx))
       continue;
 
-    const SVal &V = state->getSVal(*I);
-    const DefinedSVal *DV = dyn_cast<DefinedSVal>(&V);
-
-    if (!DV)
-      continue;
+    const DefinedSVal &V = cast<DefinedSVal>(state->getSVal(*I));
 
     ConstraintManager &CM = C.getConstraintManager();
     const GRState *stateNotNull, *stateNull;
-    llvm::tie(stateNotNull, stateNull) = CM.AssumeDual(state, *DV);
+    llvm::tie(stateNotNull, stateNull) = CM.AssumeDual(state, V);
 
     if (stateNull && !stateNotNull) {
       // Generate an error node.  Check for a null node in case
index d5bd4b0cb0f1a2ac5a37deae8e41bf2c7549713e..615e8e3791c6d6779c9ad8ee17b005b6ea5e59bb 100644 (file)
@@ -312,8 +312,10 @@ static void RegisterInternalChecks(GRExprEngine &Eng) {
   // automatically.  Note that the check itself is owned by the GRExprEngine
   // object.
   RegisterAdjustedReturnValueChecker(Eng);
-  RegisterAttrNonNullChecker(Eng);
+  // CallAndMessageChecker should be registered before AttrNonNullChecker,
+  // where we assume arguments are not undefined.
   RegisterCallAndMessageChecker(Eng);
+  RegisterAttrNonNullChecker(Eng);
   RegisterDereferenceChecker(Eng);
   RegisterVLASizeChecker(Eng);
   RegisterDivZeroChecker(Eng);