]> granicus.if.org Git - clang/commitdiff
When making a module visible, also make any of its exported modules
authorDouglas Gregor <dgregor@apple.com>
Fri, 2 Dec 2011 19:11:09 +0000 (19:11 +0000)
committerDouglas Gregor <dgregor@apple.com>
Fri, 2 Dec 2011 19:11:09 +0000 (19:11 +0000)
visible, allowing one to create modules that import (and then
re-export) other modules.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@145696 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Serialization/ASTReader.cpp
test/Modules/diamond.c

index 26fca2290e67b4558f85d3327a6ee0dd0124ca19..76bc0b840008b2b70f038171b69f02b745d56892 100644 (file)
@@ -2504,6 +2504,18 @@ void ASTReader::makeModuleVisible(Module *Mod,
       if (!Sub->getValue()->IsExplicit && Visited.insert(Sub->getValue()))
         Stack.push_back(Sub->getValue());
     }
+    
+    // Push any exported modules onto the stack to be marked as visible.
+    for (unsigned I = 0, N = Mod->Exports.size(); I != N; ++I) {
+      Module *Exported = Mod->Exports[I].getPointer();
+      if (Visited.insert(Exported)) {
+        // FIXME: The intent of wildcards is to re-export any imported modules.
+        // However, we don't yet have the module-dependency information to do
+        // this, so we ignore wildcards for now.
+        if (!Mod->Exports[I].getInt())
+          Stack.push_back(Exported);
+      }
+    }
   }
 }
 
index 93722e9fe2a7d239b833c72be9e5593382ac87bb..59181c533d48f7c4431af6f7a81f17af4d8a5180 100644 (file)
@@ -5,12 +5,6 @@
 
 __import_module__ diamond_bottom;
 
-// FIXME: We want 'bottom' to re-export left and right, and both of those to
-// re-export 'top'.
-__import_module__ diamond_top;
-__import_module__ diamond_left;
-__import_module__ diamond_right;
-
 void test_diamond(int i, float f, double d, char c) {
   top(&i);
   left(&f);