From d6bf03c2725124ab574ab902b1c312e771af31a8 Mon Sep 17 00:00:00 2001 From: Argyrios Kyrtzidis Date: Sat, 18 Jul 2009 21:17:58 +0000 Subject: Introduce ASTLocation::getReferencedDecl(), for getting the declaration that the ASTLocation references. llvm-svn: 76336 --- clang/tools/index-test/index-test.cpp | 22 ++-------------------- 1 file changed, 2 insertions(+), 20 deletions(-) (limited to 'clang/tools/index-test/index-test.cpp') diff --git a/clang/tools/index-test/index-test.cpp b/clang/tools/index-test/index-test.cpp index 10449ed0baa..9f02c2284fd 100644 --- a/clang/tools/index-test/index-test.cpp +++ b/clang/tools/index-test/index-test.cpp @@ -141,30 +141,12 @@ static void ProcessDecl(Decl *D) { } } -static Decl *getDeclFromExpr(Stmt *E) { - if (DeclRefExpr *RefExpr = dyn_cast(E)) - return RefExpr->getDecl(); - if (MemberExpr *ME = dyn_cast(E)) - return ME->getMemberDecl(); - if (CallExpr *CE = dyn_cast(E)) - return getDeclFromExpr(CE->getCallee()); - if (CastExpr *CE = dyn_cast(E)) - return getDeclFromExpr(CE->getSubExpr()); - - return 0; -} - static void ProcessASTLocation(ASTLocation ASTLoc, IndexProvider &IdxProvider) { assert(ASTLoc.isValid()); - Decl *D = 0; - if (ASTLoc.isStmt()) - D = getDeclFromExpr(ASTLoc.getStmt()); - else - D = ASTLoc.getDecl(); - + Decl *D = ASTLoc.getReferencedDecl(); if (D == 0) { - llvm::errs() << "Error: Couldn't get a Decl out of the ASTLocation"; + llvm::errs() << "Error: Couldn't get a referenced Decl for the ASTLocation"; HadErrors = true; return; } -- cgit v1.2.3