diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-21 00:05:38 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-21 00:05:38 +0000 |
commit | 80ede1d7148582b7647d7cbe09c86e3305976839 (patch) | |
tree | 854536012f2e37d5d14e3237a4fb4fe2c5336517 /lib/Index/DeclReferenceMap.cpp | |
parent | ec930d3d816d69d2e8bee857de276e68beda1a07 (diff) |
Handle references from ObjCIvarRefExprs.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@76507 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Index/DeclReferenceMap.cpp')
-rw-r--r-- | lib/Index/DeclReferenceMap.cpp | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/lib/Index/DeclReferenceMap.cpp b/lib/Index/DeclReferenceMap.cpp index 2e5e7c389a..f99f4ae84d 100644 --- a/lib/Index/DeclReferenceMap.cpp +++ b/lib/Index/DeclReferenceMap.cpp @@ -35,6 +35,7 @@ public: void VisitDeclStmt(DeclStmt *Node); void VisitDeclRefExpr(DeclRefExpr *Node); void VisitMemberExpr(MemberExpr *Node); + void VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node); void VisitStmt(Stmt *Node); }; @@ -48,6 +49,7 @@ public: void VisitDeclContext(DeclContext *DC); void VisitVarDecl(VarDecl *D); void VisitFunctionDecl(FunctionDecl *D); + void VisitObjCMethodDecl(ObjCMethodDecl *D); void VisitBlockDecl(BlockDecl *D); void VisitDecl(Decl *D); }; @@ -75,6 +77,10 @@ void StmtMapper::VisitMemberExpr(MemberExpr *Node) { Map.insert(std::make_pair(PrimD, ASTLocation(Parent, Node))); } +void StmtMapper::VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node) { + Map.insert(std::make_pair(Node->getDecl(), ASTLocation(Parent, Node))); +} + void StmtMapper::VisitStmt(Stmt *Node) { for (Stmt::child_iterator I = Node->child_begin(), E = Node->child_end(); I != E; ++I) @@ -92,10 +98,13 @@ void DeclMapper::VisitDeclContext(DeclContext *DC) { } void DeclMapper::VisitFunctionDecl(FunctionDecl *D) { - if (!D->isThisDeclarationADefinition()) - return; - - StmtMapper(Map, D).Visit(D->getBody()); + if (D->isThisDeclarationADefinition()) + StmtMapper(Map, D).Visit(D->getBody()); +} + +void DeclMapper::VisitObjCMethodDecl(ObjCMethodDecl *D) { + if (D->getBody()) + StmtMapper(Map, D).Visit(D->getBody()); } void DeclMapper::VisitBlockDecl(BlockDecl *D) { |