aboutsummaryrefslogtreecommitdiff
path: root/tools/index-test/index-test.cpp
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2009-07-14 03:19:30 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2009-07-14 03:19:30 +0000
commitbe125444cf48d0fbc80c2f438a6842ae74424f16 (patch)
treed8bf924e80cce90959b79759bcd1e3a96198e7e4 /tools/index-test/index-test.cpp
parentba0a9006dbc4814e1e35f82812cb5a1dad65e8b8 (diff)
For index-test, if the ASTLocation points at a CallExpr, get a Decl out of it.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@75599 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/index-test/index-test.cpp')
-rw-r--r--tools/index-test/index-test.cpp23
1 files changed, 16 insertions, 7 deletions
diff --git a/tools/index-test/index-test.cpp b/tools/index-test/index-test.cpp
index b7471a1c9d..63c86aac46 100644
--- a/tools/index-test/index-test.cpp
+++ b/tools/index-test/index-test.cpp
@@ -150,18 +150,27 @@ static void ProcessDecl(Decl *D) {
}
}
+static Decl *getDeclFromExpr(Stmt *E) {
+ if (DeclRefExpr *RefExpr = dyn_cast<DeclRefExpr>(E))
+ return RefExpr->getDecl();
+ if (MemberExpr *ME = dyn_cast<MemberExpr>(E))
+ return ME->getMemberDecl();
+ if (CallExpr *CE = dyn_cast<CallExpr>(E))
+ return getDeclFromExpr(CE->getCallee());
+ if (CastExpr *CE = dyn_cast<CastExpr>(E))
+ return getDeclFromExpr(CE->getSubExpr());
+
+ return 0;
+}
+
static void ProcessASTLocation(ASTLocation ASTLoc, IndexProvider &IdxProvider) {
assert(ASTLoc.isValid());
Decl *D = 0;
- if (ASTLoc.isStmt()) {
- if (DeclRefExpr *RefExpr = dyn_cast<DeclRefExpr>(ASTLoc.getStmt()))
- D = RefExpr->getDecl();
- else if (MemberExpr *ME = dyn_cast<MemberExpr>(ASTLoc.getStmt()))
- D = ME->getMemberDecl();
- } else {
+ if (ASTLoc.isStmt())
+ D = getDeclFromExpr(ASTLoc.getStmt());
+ else
D = ASTLoc.getDecl();
- }
if (D == 0) {
llvm::errs() << "Error: Couldn't get a Decl out of the ASTLocation";