diff options
Diffstat (limited to 'tools/libclang')
-rw-r--r-- | tools/libclang/CIndex.cpp | 14 | ||||
-rw-r--r-- | tools/libclang/CIndexCodeCompletion.cpp | 18 |
2 files changed, 28 insertions, 4 deletions
diff --git a/tools/libclang/CIndex.cpp b/tools/libclang/CIndex.cpp index 2c69f53d39..c3ebe13709 100644 --- a/tools/libclang/CIndex.cpp +++ b/tools/libclang/CIndex.cpp @@ -2689,9 +2689,14 @@ unsigned clang_visitChildrenWithBlock(CXCursor parent, static CXString getDeclSpelling(Decl *D) { NamedDecl *ND = dyn_cast_or_null<NamedDecl>(D); - if (!ND) + if (!ND) { + if (ObjCPropertyImplDecl *PropImpl =llvm::dyn_cast<ObjCPropertyImplDecl>(D)) + if (ObjCPropertyDecl *Property = PropImpl->getPropertyDecl()) + return createCXString(Property->getIdentifier()->getName()); + return createCXString(""); - + } + if (ObjCMethodDecl *OMD = dyn_cast<ObjCMethodDecl>(ND)) return createCXString(OMD->getSelector().getAsString()); @@ -3392,7 +3397,10 @@ CXCursor clang_getCursorReferenced(CXCursor C) { if (ObjCForwardProtocolDecl *Protocols = dyn_cast<ObjCForwardProtocolDecl>(D)) return MakeCursorOverloadedDeclRef(Protocols, D->getLocation(), tu); - + if (ObjCPropertyImplDecl *PropImpl =llvm::dyn_cast<ObjCPropertyImplDecl>(D)) + if (ObjCPropertyDecl *Property = PropImpl->getPropertyDecl()) + return MakeCXCursor(Property, tu); + return C; } diff --git a/tools/libclang/CIndexCodeCompletion.cpp b/tools/libclang/CIndexCodeCompletion.cpp index d0eb5cc7e3..74c3274ad6 100644 --- a/tools/libclang/CIndexCodeCompletion.cpp +++ b/tools/libclang/CIndexCodeCompletion.cpp @@ -250,9 +250,20 @@ struct AllocatedCXCodeCompleteResults : public CXCodeCompleteResults { llvm::SmallVector<const llvm::MemoryBuffer *, 1> TemporaryBuffers; }; +/// \brief Tracks the number of code-completion result objects that are +/// currently active. +/// +/// Used for debugging purposes only. +static unsigned CodeCompletionResultObjects; + AllocatedCXCodeCompleteResults::AllocatedCXCodeCompleteResults() : CXCodeCompleteResults(), Diag(new Diagnostic), - SourceMgr(*Diag, FileMgr, FileSystemOpts) { } + SourceMgr(*Diag, FileMgr, FileSystemOpts) { + if (getenv("LIBCLANG_OBJTRACKING")) { + ++CodeCompletionResultObjects; + fprintf(stderr, "+++ %d completion results\n", CodeCompletionResultObjects); + } +} AllocatedCXCodeCompleteResults::~AllocatedCXCodeCompleteResults() { for (unsigned I = 0, N = NumResults; I != N; ++I) @@ -263,6 +274,11 @@ AllocatedCXCodeCompleteResults::~AllocatedCXCodeCompleteResults() { TemporaryFiles[I].eraseFromDisk(); for (unsigned I = 0, N = TemporaryBuffers.size(); I != N; ++I) delete TemporaryBuffers[I]; + + if (getenv("LIBCLANG_OBJTRACKING")) { + --CodeCompletionResultObjects; + fprintf(stderr, "--- %d completion results\n", CodeCompletionResultObjects); + } } } // end extern "C" |