* \brief Data for IndexerCallbacks#importedASTFile.
*/
typedef struct {
+ /**
+ * \brief Top level AST file containing the imported PCH, module or submodule.
+ */
CXFile file;
/**
- * \brief Location where the file is imported. It is useful mostly for
- * modules.
+ * \brief Location where the file is imported. Applicable only for modules.
*/
CXIdxLoc loc;
/**
* \brief Non-zero if the AST file is a module otherwise it's a PCH.
*/
int isModule;
+ /**
+ * \brief Non-zero if an inclusion directive was automatically turned into
+ * a module import.
+ */
+ int isIncludeDirective;
+ /**
+ * \brief The name of the file being included or the module being imported,
+ * as written in the source code.
+ */
+ const char *sourceName;
+ /**
+ * \brief The actual name of the module or submodule being imported.
+ * The syntax is a sequence of identifiers separated by dots, e.g "std.vector"
+ * Applicable only for modules.
+ */
+ const char *moduleName;
+
} CXIdxImportedASTFileInfo;
typedef enum {
*
* AST files will not get indexed (there will not be callbacks to index all
* the entities in an AST file). The recommended action is that, if the AST
- * file is not already indexed, to block further indexing and initiate a new
- * indexing job specific to the AST file.
+ * file is not already indexed, to initiate a new indexing job specific to
+ * the AST file.
*/
CXIdxClientASTFile (*importedASTFile)(CXClientData client_data,
const CXIdxImportedASTFileInfo *);
return (CXIdxClientFile)info->file;
}
+static CXIdxClientFile index_importedASTFile(CXClientData client_data,
+ const CXIdxImportedASTFileInfo *info) {
+ IndexData *index_data;
+ index_data = (IndexData *)client_data;
+ printCheck(index_data);
+
+ printf("[importedASTFile]: ");
+ printCXIndexFile((CXIdxClientFile)info->file);
+ printf(" | loc: ");
+ printCXIndexLoc(info->loc, client_data);
+ printf(" | module name: \"%s\"", info->moduleName);
+ printf(" | source name: \"%s\"", info->sourceName);
+ printf(" | isModule: %d | isIncludeDirective: %d\n",
+ info->isModule, info->isIncludeDirective);
+
+ return (CXIdxClientFile)info->file;
+}
+
static CXIdxClientContainer index_startedTranslationUnit(CXClientData client_data,
void *reserved) {
IndexData *index_data;
index_diagnostic,
index_enteredMainFile,
index_ppIncludedFile,
- 0, /*importedASTFile*/
+ index_importedASTFile,
index_startedTranslationUnit,
index_indexDeclaration,
index_indexEntityReference
#include "IndexingContext.h"
#include "clang/AST/DeclVisitor.h"
+#include "clang/Basic/Module.h"
using namespace clang;
using namespace cxindex;
IndexCtx.indexTypeSourceInfo(D->getTemplatedDecl()->getTypeSourceInfo(), D);
return true;
}
+
+ bool VisitImportDecl(ImportDecl *D) {
+ Module *Imported = D->getImportedModule();
+ if (Imported)
+ IndexCtx.importedModule(D->getLocation(), Imported->getFullModuleName(),
+ /*isIncludeDirective=*/false, Imported);
+ return true;
+ }
};
} // anonymous namespace
StringRef SearchPath,
StringRef RelativePath,
const Module *Imported) {
+ if (Imported) {
+ IndexCtx.importedModule(HashLoc, FileName, /*isIncludeDirective=*/true,
+ Imported);
+ return;
+ }
+
bool isImport = (IncludeTok.is(tok::identifier) &&
IncludeTok.getIdentifierInfo()->getPPKeywordID() == tok::pp_import);
IndexCtx.ppIncludedFile(HashLoc, FileName, File, isImport, IsAngled);
FileMap[File] = idxFile;
}
+void IndexingContext::importedModule(SourceLocation Loc,
+ StringRef name, bool isIncludeDirective,
+ const Module *module) {
+ if (!CB.importedASTFile)
+ return;
+
+ std::string ModuleName = module->getFullModuleName();
+
+ ScratchAlloc SA(*this);
+ CXIdxImportedASTFileInfo Info = {
+ (CXFile)module->getASTFile(),
+ getIndexLoc(Loc),
+ /*isModule=*/true,
+ isIncludeDirective,
+ SA.toCStr(name),
+ ModuleName.c_str(),
+ };
+ CXIdxClientASTFile astFile = CB.importedASTFile(ClientData, &Info);
+ (void)astFile;
+}
+
void IndexingContext::startedTranslationUnit() {
CXIdxClientContainer idxCont = 0;
if (CB.startedTranslationUnit)
StringRef filename, const FileEntry *File,
bool isImport, bool isAngled);
+ void importedModule(SourceLocation Loc,
+ StringRef name, bool isIncludeDirective,
+ const Module *module);
+
void startedTranslationUnit();
void indexDecl(const Decl *D);