71 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| // RUN: rm -rf %t
 | |
| //
 | |
| // First, create two modules a and b, with a dependency b -> a, both within
 | |
| // the same directory p1.
 | |
| //
 | |
| // RUN: mkdir -p %t/p1
 | |
| // RUN: cd %t/p1
 | |
| //
 | |
| // RUN: grep "<AM>" %s > %t/p1/a.modulemap
 | |
| // RUN: %clang_cc1 -x c++ -fmodules -emit-module -fmodule-map-file-home-is-cwd \
 | |
| // RUN:   -fmodules-embed-all-files -fmodules-local-submodule-visibility \
 | |
| // RUN:   -fmodule-name="a" -o a.pcm a.modulemap
 | |
| //
 | |
| // RUN: grep "<BM>" %s > %t/p1/b.modulemap
 | |
| // RUN: %clang_cc1 -x c++ -fmodules -emit-module -fmodule-map-file-home-is-cwd \
 | |
| // RUN:   -fmodules-embed-all-files -fmodules-local-submodule-visibility \
 | |
| // RUN:   -fmodule-name="b" -o b.pcm b.modulemap
 | |
| //
 | |
| // Next, move the whole tree p1 -> p2.
 | |
| //
 | |
| // RUN: cd %t
 | |
| // RUN: mv %t/p1 %t/p2
 | |
| // RUN: cd %t/p2
 | |
| //
 | |
| // Compile a new module c in the newly generated tree that depends on b; c.pcm
 | |
| // has to be within a subdirectory so a.modulemap will be one step up (../) from
 | |
| // c.pcm.
 | |
| //
 | |
| // RUN: mkdir %t/p2/c
 | |
| // RUN: grep "<CM>" %s > %t/p2/c/c.modulemap
 | |
| // RUN: grep "<CH>" %s > %t/p2/c/c.h
 | |
| // RUN: %clang_cc1 -x c++ -fmodules -emit-module -fmodule-map-file-home-is-cwd \
 | |
| // RUN:   -fmodules-embed-all-files -fmodules-local-submodule-visibility \
 | |
| // RUN:   -fmodule-name="c" -fmodule-file=b.pcm -o c/c.pcm c/c.modulemap
 | |
| //
 | |
| // Delete a.modulemap from its original location, and instead inject a different
 | |
| // (unrelated) a.modulemap in the path p2/p2.
 | |
| //
 | |
| // RUN: rm %t/p2/a.modulemap
 | |
| // RUN: mkdir -p %t/p2/p2
 | |
| // RUN: touch %t/p2/p2/a.modulemap
 | |
| //
 | |
| // Now compile a file c.cpp that uses c.h and the module c; it is important
 | |
| // to first load b.pcm and a.pcm before c.pcm on the command line to trigger
 | |
| // the right order of module loading. This used to trigger clang to find the
 | |
| // p2/p2/a.modulemap via the path c/../p2/a.modulemap, which is not the correct
 | |
| // relative path from c.
 | |
| //
 | |
| // RUN: grep "<CC>" %s > %t/p2/c/c.cpp
 | |
| // RUN: %clang_cc1 -I. -x c++ -fmodules \
 | |
| // RUN:     -fmodule-file=b.pcm -fmodule-file=a.pcm -fmodule-file=c/c.pcm  \
 | |
| // RUN:     -o c/c.o -emit-obj c/c.cpp
 | |
| 
 | |
| module "a" {                // <AM>
 | |
| }                           // <AM>
 | |
| 
 | |
| module "b" {                // <BM>
 | |
|   use "a"                   // <BM>
 | |
| }                           // <BM>
 | |
| 
 | |
| module "c" {                // <CM>
 | |
|   header "c/c.h"            // <CM>
 | |
|   use "a"                   // <CM>
 | |
|   use "b"                   // <CM>
 | |
| }                           // <CM>
 | |
| 
 | |
| inline void c() {}          // <CH>
 | |
| 
 | |
| #include "c/c.h"            // <CC>
 | |
| void foo() { c(); }         // <CC>
 |