diff options
author | Ted Kremenek <kremenek@apple.com> | 2011-03-30 17:41:19 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2011-03-30 17:41:19 +0000 |
commit | 98a24e37c565d6eabca0cff7e9541734d1e7e224 (patch) | |
tree | b7fa5240e627046deca355b09bf9272d8e6be8c7 /clang/lib/AST/ExprCXX.cpp | |
parent | f0901227e30de7c55fb9a430e6a4aebb88a454cd (diff) | |
download | bcm5719-llvm-98a24e37c565d6eabca0cff7e9541734d1e7e224.tar.gz bcm5719-llvm-98a24e37c565d6eabca0cff7e9541734d1e7e224.zip |
Begin reworking static analyzer support for C++ method calls. The current logic was divorced
from how we process ordinary function calls, had a tremendous about of redundancy, and relied
strictly on inlining behavior (which was incomplete) to provide semantics instead of falling
back to the conservative analysis we use for C functions. This is a significant step into
making C++ analyzer support more useful.
llvm-svn: 128557
Diffstat (limited to 'clang/lib/AST/ExprCXX.cpp')
-rw-r--r-- | clang/lib/AST/ExprCXX.cpp | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/clang/lib/AST/ExprCXX.cpp b/clang/lib/AST/ExprCXX.cpp index 35c2d410082..02d60ef0a7d 100644 --- a/clang/lib/AST/ExprCXX.cpp +++ b/clang/lib/AST/ExprCXX.cpp @@ -384,14 +384,25 @@ SourceRange CXXOperatorCallExpr::getSourceRange() const { } } -Expr *CXXMemberCallExpr::getImplicitObjectArgument() { - if (MemberExpr *MemExpr = dyn_cast<MemberExpr>(getCallee()->IgnoreParens())) +Expr *CXXMemberCallExpr::getImplicitObjectArgument() const { + if (const MemberExpr *MemExpr = + dyn_cast<MemberExpr>(getCallee()->IgnoreParens())) return MemExpr->getBase(); // FIXME: Will eventually need to cope with member pointers. return 0; } +CXXMethodDecl *CXXMemberCallExpr::getMethodDecl() const { + if (const MemberExpr *MemExpr = + dyn_cast<MemberExpr>(getCallee()->IgnoreParens())) + return cast<CXXMethodDecl>(MemExpr->getMemberDecl()); + + // FIXME: Will eventually need to cope with member pointers. + return 0; +} + + CXXRecordDecl *CXXMemberCallExpr::getRecordDecl() { Expr* ThisArg = getImplicitObjectArgument(); if (!ThisArg) |