diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-12-02 18:58:38 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-12-02 18:58:38 +0000 |
commit | af13bfc3b40aa4a46f4e71d200ecfb10f45297fc (patch) | |
tree | 165d634ec08b0322c2a9966d40b8f944a512791d /lib/Serialization/ASTWriter.cpp | |
parent | a015cab273705d1198d13e8389c2f4775f539a8b (diff) |
Implement (de-)serialization of the set of exported modules in a
module map.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@145695 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Serialization/ASTWriter.cpp')
-rw-r--r-- | lib/Serialization/ASTWriter.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/lib/Serialization/ASTWriter.cpp b/lib/Serialization/ASTWriter.cpp index 6d51dbce3e..00dbfabb45 100644 --- a/lib/Serialization/ASTWriter.cpp +++ b/lib/Serialization/ASTWriter.cpp @@ -1893,6 +1893,7 @@ void ASTWriter::WriteSubmodules(Module *WritingModule) { while (!Q.empty()) { Module *Mod = Q.front(); Q.pop(); + assert(SubmoduleIDs.find(Mod) == SubmoduleIDs.end()); SubmoduleIDs[Mod] = NextSubmoduleID++; // Emit the definition of the block. @@ -1924,6 +1925,18 @@ void ASTWriter::WriteSubmodules(Module *WritingModule) { Mod->Headers[I]->getName()); } + // Emit the exports. + if (!Mod->Exports.empty()) { + Record.clear(); + for (unsigned I = 0, N = Mod->Exports.size(); I != N; ++I) { + unsigned ExportedID = SubmoduleIDs[Mod->Exports[I].getPointer()]; + assert(ExportedID && "Unknown submodule!"); + Record.push_back(ExportedID); + Record.push_back(Mod->Exports[I].getInt()); + } + Stream.EmitRecord(SUBMODULE_EXPORTS, Record); + } + // Queue up the submodules of this module. llvm::SmallVector<StringRef, 2> SubModules; @@ -3214,7 +3227,7 @@ void ASTWriter::WriteASTCore(Sema &SemaRef, MemorizeStatCalls *StatCalls, { llvm::raw_svector_ostream Out(Buffer); for (ModuleManager::ModuleConstIterator M = Chain->ModuleMgr.begin(), - MEnd = Chain->ModuleMgr.end(); + MEnd = Chain->ModuleMgr.end(); M != MEnd; ++M) { StringRef FileName = (*M)->FileName; io::Emit16(Out, FileName.size()); |