зеркало из https://github.com/microsoft/clang-1.git
Actually keep track of the source locations at which particular module
files are loaded. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@169027 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
830ea5b7c7
Коммит
87e2cfcec7
|
@ -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);
|
||||
|
|
|
@ -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.
|
||||
|
|
|
@ -34,9 +34,9 @@ llvm::MemoryBuffer *ModuleManager::lookupBuffer(StringRef Name) {
|
|||
}
|
||||
|
||||
std::pair<ModuleFile *, bool>
|
||||
ModuleManager::addModule(StringRef FileName, ModuleKind Type,
|
||||
ModuleFile *ImportedBy, unsigned Generation,
|
||||
std::string &ErrorStr) {
|
||||
ModuleManager::addModule(StringRef FileName, ModuleKind Type,
|
||||
SourceLocation ImportLoc, ModuleFile *ImportedBy,
|
||||
unsigned Generation, std::string &ErrorStr) {
|
||||
const FileEntry *Entry = FileMgr.getFile(FileName);
|
||||
if (!Entry && FileName != "-") {
|
||||
ErrorStr = "file not found";
|
||||
|
@ -51,10 +51,11 @@ 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;
|
||||
|
||||
|
||||
// Load the contents of the module
|
||||
if (llvm::MemoryBuffer *Buffer = lookupBuffer(FileName)) {
|
||||
// The buffer was already provided for us.
|
||||
|
@ -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;
|
||||
}
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче