From: Argyrios Kyrtzidis Date: Tue, 7 Feb 2012 22:46:16 +0000 (+0000) Subject: [libclang] Do not index implicit C++ member functions. rdar://10769813 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d08900848307fdaea19d52249bdced94eefdb9bb;p=clang [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 --- 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(D)); if (!Handled && isa(D)) indexDeclContext(cast(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(D)) return false; if (isa(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 {