summaryrefslogtreecommitdiffstats
path: root/clang/lib/Serialization/ASTWriter.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-12-02 18:58:38 +0000
committerDouglas Gregor <dgregor@apple.com>2011-12-02 18:58:38 +0000
commit24bb923aa84354bfa18240bdda6d9aa07ef83427 (patch)
tree68eac8e51724d44c1974729dc0a78f1cb8dc3f9b /clang/lib/Serialization/ASTWriter.cpp
parentc5be44aaa2bf1c6f7b2716938329bcb3aedd4778 (diff)
downloadbcm5719-llvm-24bb923aa84354bfa18240bdda6d9aa07ef83427.tar.gz
bcm5719-llvm-24bb923aa84354bfa18240bdda6d9aa07ef83427.zip
Implement (de-)serialization of the set of exported modules in a
module map. llvm-svn: 145695
Diffstat (limited to 'clang/lib/Serialization/ASTWriter.cpp')
-rw-r--r--clang/lib/Serialization/ASTWriter.cpp15
1 files changed, 14 insertions, 1 deletions
diff --git a/clang/lib/Serialization/ASTWriter.cpp b/clang/lib/Serialization/ASTWriter.cpp
index 6d51dbce3e2..00dbfabb451 100644
--- a/clang/lib/Serialization/ASTWriter.cpp
+++ b/clang/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());
OpenPOWER on IntegriCloud