Actually keep track of the source locations at which particular module

files are loaded.

llvm-svn: 169027
This commit is contained in:
Douglas Gregor 2012-11-30 19:28:05 +00:00
parent 31e7d2deb3
commit 6fb03aeae1
3 changed files with 16 additions and 8 deletions

View File

@ -92,6 +92,8 @@ public:
///
/// \param Type The kind of module being loaded.
///
/// \param ImportLoc The location at which the module is imported.
///
/// \param ImportedBy The module that is importing this module, or NULL if
/// this module is imported directly by the user.
///
@ -103,8 +105,9 @@ public:
/// \return A pointer to the module that corresponds to this file name,
/// and a boolean indicating whether the module was newly added.
std::pair<ModuleFile *, bool>
addModule(StringRef FileName, ModuleKind Type, ModuleFile *ImportedBy,
unsigned Generation, std::string &ErrorStr);
addModule(StringRef FileName, ModuleKind Type, SourceLocation ImportLoc,
ModuleFile *ImportedBy, unsigned Generation,
std::string &ErrorStr);
/// \brief Remove the given set of modules.
void removeModules(ModuleIterator first, ModuleIterator last);

View File

@ -2818,8 +2818,9 @@ ASTReader::ReadASTCore(StringRef FileName,
ModuleFile *M;
bool NewModule;
std::string ErrorStr;
llvm::tie(M, NewModule) = ModuleMgr.addModule(FileName, Type, ImportedBy,
CurrentGeneration, ErrorStr);
llvm::tie(M, NewModule) = ModuleMgr.addModule(FileName, Type, ImportLoc,
ImportedBy, CurrentGeneration,
ErrorStr);
if (!M) {
// We couldn't load the module.

View File

@ -35,8 +35,8 @@ llvm::MemoryBuffer *ModuleManager::lookupBuffer(StringRef Name) {
std::pair<ModuleFile *, bool>
ModuleManager::addModule(StringRef FileName, ModuleKind Type,
ModuleFile *ImportedBy, unsigned Generation,
std::string &ErrorStr) {
SourceLocation ImportLoc, ModuleFile *ImportedBy,
unsigned Generation, std::string &ErrorStr) {
const FileEntry *Entry = FileMgr.getFile(FileName);
if (!Entry && FileName != "-") {
ErrorStr = "file not found";
@ -51,6 +51,7 @@ ModuleManager::addModule(StringRef FileName, ModuleKind Type,
ModuleFile *New = new ModuleFile(Type, Generation);
New->FileName = FileName.str();
New->File = Entry;
New->ImportLoc = ImportLoc;
Chain.push_back(New);
NewModule = true;
ModuleEntry = New;
@ -82,6 +83,9 @@ ModuleManager::addModule(StringRef FileName, ModuleKind Type,
ModuleEntry->ImportedBy.insert(ImportedBy);
ImportedBy->Imports.insert(ModuleEntry);
} else {
if (!ModuleEntry->DirectlyImported)
ModuleEntry->ImportLoc = ImportLoc;
ModuleEntry->DirectlyImported = true;
}