aboutsummaryrefslogtreecommitdiff
path: root/lib/Index/DeclReferenceMap.cpp
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2009-07-21 00:05:38 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2009-07-21 00:05:38 +0000
commit80ede1d7148582b7647d7cbe09c86e3305976839 (patch)
tree854536012f2e37d5d14e3237a4fb4fe2c5336517 /lib/Index/DeclReferenceMap.cpp
parentec930d3d816d69d2e8bee857de276e68beda1a07 (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.cpp17
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) {