]> granicus.if.org Git - clang/commitdiff
Bug fix in dead-store checker when walking the Decls in a DeclStmt: don't
authorTed Kremenek <kremenek@apple.com>
Mon, 14 Apr 2008 17:52:13 +0000 (17:52 +0000)
committerTed Kremenek <kremenek@apple.com>
Mon, 14 Apr 2008 17:52:13 +0000 (17:52 +0000)
assume that DeclStmts only have VarDecls; they can have TypedefDecls.

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

lib/Analysis/DeadStores.cpp

index 2e57757f5c23b859ac861eb63540d96ba79590f5..e64214e6948aff5036d89d1c88c46bdcc5eb145e 100644 (file)
@@ -54,8 +54,11 @@ public:
     else if(DeclStmt* DS = dyn_cast<DeclStmt>(S))
       // Iterate through the decls.  Warn if any initializers are complex
       // expressions that are not live (never used).
-      for (VarDecl* V = cast<VarDecl>(DS->getDecl()); V != NULL ; 
-                    V = cast_or_null<VarDecl>(V->getNextDeclarator())) {
+      for (ScopedDecl* SD = DS->getDecl(); SD; SD = SD->getNextDeclarator()) {        
+        
+        VarDecl* V = dyn_cast<VarDecl>(SD);
+        if (!V) continue;
+        
         if (V->hasLocalStorage())
           if (Expr* E = V->getInit()) {
             if (!Live(DS->getDecl(),AD)) {