From 2b9b5bb697d40fe6a348464a6da66e74c81fdbd4 Mon Sep 17 00:00:00 2001 From: Argyrios Kyrtzidis Date: Fri, 5 Oct 2012 00:22:37 +0000 Subject: [libclang] Introduce new C functions that provide information about modules: clang_Cursor_getModule clang_Module_getParent clang_Module_getName clang_Module_getFullName clang_Module_getNumTopLevelHeaders clang_Module_getTopLevelHeader llvm-svn: 165280 --- clang/tools/c-index-test/c-index-test.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'clang/tools/c-index-test') diff --git a/clang/tools/c-index-test/c-index-test.c b/clang/tools/c-index-test/c-index-test.c index f4efa900cb6..caa50d0167c 100644 --- a/clang/tools/c-index-test/c-index-test.c +++ b/clang/tools/c-index-test/c-index-test.c @@ -1956,6 +1956,25 @@ static int inspect_cursor_at(int argc, const char **argv) { if (clang_Cursor_isDynamicCall(Cursor)) printf(" Dynamic-call"); + { + CXModule mod = clang_Cursor_getModule(Cursor); + CXString name; + unsigned i, numHeaders; + if (mod) { + name = clang_Module_getFullName(mod); + numHeaders = clang_Module_getNumTopLevelHeaders(mod); + printf(" ModuleName=%s Headers(%d):", + clang_getCString(name), numHeaders); + clang_disposeString(name); + for (i = 0; i < numHeaders; ++i) { + CXFile file = clang_Module_getTopLevelHeader(mod, i); + CXString filename = clang_getFileName(file); + printf("\n%s", clang_getCString(filename)); + clang_disposeString(filename); + } + } + } + if (completionString != NULL) { printf("\nCompletion string: "); print_completion_string(completionString, stdout); -- cgit v1.2.3