diff options
Diffstat (limited to 'lib/Serialization/ASTReader.cpp')
-rw-r--r-- | lib/Serialization/ASTReader.cpp | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/lib/Serialization/ASTReader.cpp b/lib/Serialization/ASTReader.cpp index d8fb3113d5..26fca2290e 100644 --- a/lib/Serialization/ASTReader.cpp +++ b/lib/Serialization/ASTReader.cpp @@ -2533,6 +2533,19 @@ ASTReader::ASTReadResult ASTReader::ReadAST(const std::string &FileName, Id != IdEnd; ++Id) Id->second->setOutOfDate(true); + // Resolve any unresolved module exports. + for (unsigned I = 0, N = UnresolvedModuleExports.size(); I != N; ++I) { + UnresolvedModuleExport &Unresolved = UnresolvedModuleExports[I]; + SubmoduleID GlobalID = getGlobalSubmoduleID(*Unresolved.File, + Unresolved.ExportedID); + if (Module *Exported = getSubmodule(GlobalID)) { + Module *Exportee = Unresolved.ModuleAndWildcard.getPointer(); + bool Wildcard = Unresolved.ModuleAndWildcard.getInt(); + Exportee->Exports.push_back(Module::ExportDecl(Exported, Wildcard)); + } + } + UnresolvedModuleExports.clear(); + InitializeContext(); if (DeserializationListener) @@ -3050,6 +3063,30 @@ ASTReader::ASTReadResult ASTReader::ReadSubmoduleBlock(ModuleFile &F) { } break; } + + case SUBMODULE_EXPORTS: { + if (First) { + Error("missing submodule metadata record at beginning of block"); + return Failure; + } + + if (!CurrentModule) + break; + + for (unsigned Idx = 0; Idx + 1 < Record.size(); Idx += 2) { + UnresolvedModuleExport Unresolved; + Unresolved.File = &F; + Unresolved.ModuleAndWildcard.setPointer(CurrentModule); + Unresolved.ModuleAndWildcard.setInt(Record[Idx + 1]); + Unresolved.ExportedID = Record[Idx]; + UnresolvedModuleExports.push_back(Unresolved); + } + + // Once we've loaded the set of exports, there's no reason to keep + // the parsed, unresolved exports around. + CurrentModule->UnresolvedExports.clear(); + break; + } } } |