diff options
-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 { |