aboutsummaryrefslogtreecommitdiff
path: root/lib/AST/Stmt.cpp
diff options
context:
space:
mode:
authorTom Care <tcare@apple.com>2010-07-06 21:43:29 +0000
committerTom Care <tcare@apple.com>2010-07-06 21:43:29 +0000
commitdb2fa8a7eb67b1e8f32a590b8e000e1259cff91a (patch)
tree8800214bfcdc2f28ca4c21fb12680a2ce97ebb62 /lib/AST/Stmt.cpp
parent03d98c5d592d74ae97aa3f93f80441b64960e4b6 (diff)
Added a path-sensitive idempotent operation checker (-analyzer-idempotent-operation). Finds idempotent and/or tautological operations in a path sensitive context, flagging operations that have no effect or a predictable effect.
Example: { int a = 1; int b = 5; int c = b / a; // a is 1 on all paths } - New IdempotentOperationChecker class - Moved recursive Stmt functions in r107675 to IdempotentOperationChecker - Minor refactoring of SVal to allow checking for any integer - Added command line option for check - Added basic test cases git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@107706 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST/Stmt.cpp')
-rw-r--r--lib/AST/Stmt.cpp66
1 files changed, 0 insertions, 66 deletions
diff --git a/lib/AST/Stmt.cpp b/lib/AST/Stmt.cpp
index d1084327a2..6dbe8f4d18 100644
--- a/lib/AST/Stmt.cpp
+++ b/lib/AST/Stmt.cpp
@@ -127,72 +127,6 @@ bool Stmt::hasImplicitControlFlow() const {
}
}
-// Recursively find any substatements containing macros
-bool Stmt::containsMacro(const Stmt *S) {
- if (S->getLocStart().isMacroID())
- return true;
-
- if (S->getLocEnd().isMacroID())
- return true;
-
- for (Stmt::const_child_iterator I = S->child_begin(); I != S->child_end(); ++I)
- if (const Stmt *child = *I)
- if (containsMacro(child))
- return true;
-
- return false;
-}
-
-// Recursively find any substatements containing enum constants
-bool Stmt::containsEnum(const Stmt *S) {
- const DeclRefExpr *DR = dyn_cast<DeclRefExpr>(S);
-
- if (DR && isa<EnumConstantDecl>(DR->getDecl()))
- return true;
-
- for (Stmt::const_child_iterator I = S->child_begin(); I != S->child_end(); ++I)
- if (const Stmt *child = *I)
- if (containsEnum(child))
- return true;
-
- return false;
-}
-
-bool Stmt::containsZeroConstant(const Stmt *S) {
- const IntegerLiteral *IL = dyn_cast<IntegerLiteral>(S);
- if (IL && IL->getValue() == 0)
- return true;
-
- const FloatingLiteral *FL = dyn_cast<FloatingLiteral>(S);
- if (FL && FL->getValue().isZero())
- return true;
-
- for (Stmt::const_child_iterator I = S->child_begin(); I != S->child_end(); ++I)
- if (const Stmt *child = *I)
- if (containsZeroConstant(child))
- return true;
-
- return false;
-}
-
-bool Stmt::containsOneConstant(const Stmt *S) {
- const IntegerLiteral *IL = dyn_cast<IntegerLiteral>(S);
- if (IL && IL->getValue() == 1)
- return true;
-
- const FloatingLiteral *FL = dyn_cast<FloatingLiteral>(S);
- const llvm::APFloat one(1.0);
- if (FL && FL->getValue().compare(one) == llvm::APFloat::cmpEqual)
- return true;
-
- for (Stmt::const_child_iterator I = S->child_begin(); I != S->child_end(); ++I)
- if (const Stmt *child = *I)
- if (containsOneConstant(child))
- return true;
-
- return false;
-}
-
Expr *AsmStmt::getOutputExpr(unsigned i) {
return cast<Expr>(Exprs[i]);
}