diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-02-07 22:46:16 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-02-07 22:46:16 +0000 |
commit | d08900848307fdaea19d52249bdced94eefdb9bb (patch) | |
tree | 6254bcf52cf162dde37787f4821ca727379c1e7d | |
parent | d7a3e2c5f61cd4893f95b69a424fe4def3aa0f69 (diff) |
[libclang] Do not index implicit C++ member functions. rdar://10769813
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@150007 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | tools/libclang/IndexDecl.cpp | 3 | ||||
-rw-r--r-- | tools/libclang/IndexingContext.cpp | 2 | ||||
-rw-r--r-- | tools/libclang/IndexingContext.h | 2 |
3 files changed, 5 insertions, 2 deletions
diff --git a/tools/libclang/IndexDecl.cpp b/tools/libclang/IndexDecl.cpp index c6080df592..d2eb402ba2 100644 --- a/tools/libclang/IndexDecl.cpp +++ b/tools/libclang/IndexDecl.cpp @@ -243,6 +243,9 @@ public: } // anonymous namespace void IndexingContext::indexDecl(const Decl *D) { + if (D->isImplicit() && shouldIgnoreIfImplicit(D)) + return; + bool Handled = IndexingDeclVisitor(*this).Visit(const_cast<Decl*>(D)); if (!Handled && isa<DeclContext>(D)) indexDeclContext(cast<DeclContext>(D)); diff --git a/tools/libclang/IndexingContext.cpp b/tools/libclang/IndexingContext.cpp index 32eb326abb..2e69c46849 100644 --- a/tools/libclang/IndexingContext.cpp +++ b/tools/libclang/IndexingContext.cpp @@ -1012,7 +1012,7 @@ CXCursor IndexingContext::getRefCursor(const NamedDecl *D, SourceLocation Loc) { return clang_getNullCursor(); } -bool IndexingContext::shouldIgnoreIfImplicit(const NamedDecl *D) { +bool IndexingContext::shouldIgnoreIfImplicit(const Decl *D) { if (isa<ObjCInterfaceDecl>(D)) return false; if (isa<ObjCCategoryDecl>(D)) diff --git a/tools/libclang/IndexingContext.h b/tools/libclang/IndexingContext.h index bc33005e89..ef8e24e7c3 100644 --- a/tools/libclang/IndexingContext.h +++ b/tools/libclang/IndexingContext.h @@ -459,7 +459,7 @@ private: CXCursor getRefCursor(const NamedDecl *D, SourceLocation Loc); - static bool shouldIgnoreIfImplicit(const NamedDecl *D); + static bool shouldIgnoreIfImplicit(const Decl *D); }; class ScratchAlloc { |