1f74d9466SRichard Smith // RUN: rm -rf %t
28128f332SRichard Smith // RUN: mkdir %t
3f74d9466SRichard Smith 
4f74d9466SRichard Smith // RUN: not %clang_cc1 -fmodules -fmodule-name=file -I%S/Inputs/preprocess -x c++-module-map %S/Inputs/preprocess/module.modulemap -E 2>&1 | FileCheck %s --check-prefix=MISSING-FWD
5f74d9466SRichard Smith // MISSING-FWD: module 'fwd' is needed
6f74d9466SRichard Smith 
78128f332SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=fwd -I%S/Inputs/preprocess -x c++-module-map %S/Inputs/preprocess/module.modulemap -emit-module -o %t/fwd.pcm
88128f332SRichard Smith 
98128f332SRichard Smith // Check that we can preprocess modules, and get the expected output.
108128f332SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -I%S/Inputs/preprocess -x c++-module-map %S/Inputs/preprocess/module.modulemap -E -o %t/no-rewrite.ii
118128f332SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -I%S/Inputs/preprocess -x c++-module-map %S/Inputs/preprocess/module.modulemap -E -frewrite-includes -o %t/rewrite.ii
128128f332SRichard Smith //
138128f332SRichard Smith // RUN: FileCheck %s --input-file %t/no-rewrite.ii --check-prefix=CHECK --check-prefix=NO-REWRITE
148128f332SRichard Smith // RUN: FileCheck %s --input-file %t/rewrite.ii    --check-prefix=CHECK --check-prefix=REWRITE
158128f332SRichard Smith 
168128f332SRichard Smith // Check that we can build a module from the preprocessed output.
178128f332SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -x c++-module-map-cpp-output %t/no-rewrite.ii -emit-module -o %t/no-rewrite.pcm
188128f332SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -x c++-module-map-cpp-output %t/rewrite.ii -emit-module -o %t/rewrite.pcm
198128f332SRichard Smith 
204a3751ffSRichard Smith // Check that we can load the original module map in the same compilation (this
214a3751ffSRichard Smith // could happen if we had a redundant -fmodule-map-file= in the original
224a3751ffSRichard Smith // build).
234a3751ffSRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -fmodule-map-file=%S/Inputs/preprocess/module.modulemap -x c++-module-map-cpp-output %t/rewrite.ii -emit-module -o /dev/null
244a3751ffSRichard Smith 
258128f332SRichard Smith // Check the module we built works.
2654f0440cSRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-file=%t/no-rewrite.pcm %s -I%t -verify -fno-modules-error-recovery
2754f0440cSRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-file=%t/rewrite.pcm %s -I%t -verify -fno-modules-error-recovery -DREWRITE
288b706104SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-file=%t/no-rewrite.pcm %s -I%t -verify -fno-modules-error-recovery -DINCLUDE -I%S/Inputs/preprocess
298b706104SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-file=%t/rewrite.pcm %s -I%t -verify -fno-modules-error-recovery -DREWRITE -DINCLUDE -I%S/Inputs/preprocess
308128f332SRichard Smith 
31040e1266SRichard Smith // Now try building the module when the header files are missing.
32a21c8e14SRichard Smith // RUN: cp %S/Inputs/preprocess/fwd.h %S/Inputs/preprocess/file.h %S/Inputs/preprocess/file2.h %S/Inputs/preprocess/other.h %S/Inputs/preprocess/module.modulemap %t
33040e1266SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -I%t -x c++-module-map %t/module.modulemap -E -frewrite-includes -o %t/copy.ii
34a21c8e14SRichard Smith // RUN: rm %t/fwd.h %t/file.h %t/file2.h %t/other.h %t/module.modulemap
35040e1266SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -x c++-module-map-cpp-output %t/copy.ii -emit-module -o %t/copy.pcm
36040e1266SRichard Smith 
37ab75597dSRichard Smith // Check that our module contains correct mapping information for the headers.
38a21c8e14SRichard Smith // RUN: cp %S/Inputs/preprocess/fwd.h %S/Inputs/preprocess/file.h %S/Inputs/preprocess/file2.h %S/Inputs/preprocess/other.h %S/Inputs/preprocess/module.modulemap %t
39040e1266SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-file=%t/copy.pcm %s -I%t -verify -fno-modules-error-recovery -DCOPY -DINCLUDE
40a21c8e14SRichard Smith // RUN: rm %t/fwd.h %t/file.h %t/file2.h %t/other.h %t/module.modulemap
418128f332SRichard Smith 
42ab75597dSRichard Smith // Check that we can preprocess from a .pcm file and that we get the same result as preprocessing from the original sources.
43ab75597dSRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -I%S/Inputs/preprocess -x c++-module-map %S/Inputs/preprocess/module.modulemap -emit-module -o %t/file.pcm
44ab75597dSRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -I%S/Inputs/preprocess %t/file.pcm -E -frewrite-includes -o %t/file.rewrite.ii
456b199349SRichard Smith // FIXME: This check fails on Windows targets, due to canonicalization of directory separators.
466b199349SRichard Smith // FIXME: cmp %t/rewrite.ii %t/file.rewrite.ii
476b199349SRichard Smith // FIXME: Instead, just check that the preprocessed output is functionally equivalent to the output when preprocessing from the original sources.
486b199349SRichard Smith // RUN: FileCheck %s --input-file %t/file.rewrite.ii    --check-prefix=CHECK --check-prefix=REWRITE
496b199349SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -x c++-module-map-cpp-output %t/file.rewrite.ii -emit-module -o %t/file.rewrite.pcm
506b199349SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-file=%t/file.rewrite.pcm %s -I%t -verify -fno-modules-error-recovery -DFILE_REWRITE
516b199349SRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-file=%t/file.rewrite.pcm %s -I%t -verify -fno-modules-error-recovery -DFILE_REWRITE -DINCLUDE -I%S/Inputs/preprocess
521893475dSRichard Smith //
53a21c8e14SRichard Smith // Check that we can preprocess this user of the .pcm file.
54*533434fcSLubos Lunak // RUN: %clang_cc1 -fmodules -fmodule-file=%t/file.pcm %s -I%t -E -frewrite-imports -DFILE_REWRITE_FULL -o %t/preprocess-module.ii
55a21c8e14SRichard Smith // RUN: %clang_cc1 -fmodules %t/preprocess-module.ii -verify -fno-modules-error-recovery -DFILE_REWRITE_FULL
56a21c8e14SRichard Smith //
571893475dSRichard Smith // Check that language / header search options are ignored when preprocessing from a .pcm file.
581893475dSRichard Smith // RUN: %clang_cc1 %t/file.pcm -E -frewrite-includes -o %t/file.rewrite.ii.2
591893475dSRichard Smith // RUN: cmp %t/file.rewrite.ii %t/file.rewrite.ii.2
601893475dSRichard Smith //
611893475dSRichard Smith // RUN: %clang_cc1 -fmodules -fmodule-name=file -fmodule-file=%t/fwd.pcm -I%S/Inputs/preprocess %t/file.pcm -E -o %t/file.no-rewrite.ii
621893475dSRichard Smith // RUN: %clang_cc1 %t/file.pcm -E -o %t/file.no-rewrite.ii.2 -Dstruct=error
631893475dSRichard Smith // RUN: cmp %t/file.no-rewrite.ii %t/file.no-rewrite.ii.2
64ab75597dSRichard Smith 
658128f332SRichard Smith // == module map
668128f332SRichard Smith // CHECK: # 1 "{{.*}}module.modulemap"
678128f332SRichard Smith // CHECK: module file {
68040e1266SRichard Smith // CHECK:   header "file.h" { size
69040e1266SRichard Smith // CHECK:   header "file2.h" { size
708128f332SRichard Smith // CHECK: }
71d1386300SRichard Smith 
72d1386300SRichard Smith // == file.h
73f74d9466SRichard Smith // CHECK: # 1 "<module-includes>"
74d1386300SRichard Smith // REWRITE: #if 0
75d1386300SRichard Smith // REWRITE: #include "file.h"
76d1386300SRichard Smith // REWRITE: #endif
77d1386300SRichard Smith //
78d1386300SRichard Smith // FIXME: It would be preferable to consistently put the module begin/end in
79d1386300SRichard Smith // the same file, but the relative ordering of PP callbacks and module
80d1386300SRichard Smith // begin/end tokens makes that difficult.
81d1386300SRichard Smith //
82d1386300SRichard Smith // REWRITE: #pragma clang module begin file
83f74d9466SRichard Smith // CHECK: # 1 "{{.*}}file.h" 1
84d1386300SRichard Smith // NO-REWRITE: #pragma clang module begin file
85d1386300SRichard Smith //
86a21c8e14SRichard Smith // REWRITE: #ifndef FILE_H
87a21c8e14SRichard Smith // REWRITE: #define FILE_H
88a21c8e14SRichard Smith //
89d1386300SRichard Smith // CHECK: #pragma clang module import fwd /* clang {{-E|-frewrite-includes}}: implicit import
90f74d9466SRichard Smith // CHECK: typedef struct __FILE FILE;
91d1386300SRichard Smith //
92a21c8e14SRichard Smith // REWRITE: #endif
93a21c8e14SRichard Smith //
94d1386300SRichard Smith // REWRITE: #pragma clang module end
95f74d9466SRichard Smith // CHECK: # 2 "<module-includes>" 2
96d1386300SRichard Smith // NO-REWRITE: #pragma clang module end
97d1386300SRichard Smith 
98d1386300SRichard Smith // == file2.h
99d1386300SRichard Smith // REWRITE: #if 0
100d1386300SRichard Smith // REWRITE: #include "file2.h"
101d1386300SRichard Smith // REWRITE: #endif
102d1386300SRichard Smith //
103d1386300SRichard Smith // REWRITE: #pragma clang module begin file
104d1386300SRichard Smith // CHECK: # 1 "{{.*}}file2.h" 1
105d1386300SRichard Smith // NO-REWRITE: #pragma clang module begin file
106d1386300SRichard Smith //
107d1386300SRichard Smith // ==== recursively re-enter file.h
108d1386300SRichard Smith // REWRITE: #if 0
109d1386300SRichard Smith // REWRITE: #include "file.h"
110d1386300SRichard Smith // REWRITE: #endif
111d1386300SRichard Smith //
112d1386300SRichard Smith // REWRITE: #pragma clang module begin file
113d1386300SRichard Smith // CHECK: # 1 "{{.*}}file.h" 1
114d1386300SRichard Smith // NO-REWRITE: #pragma clang module begin file
115d1386300SRichard Smith //
116a21c8e14SRichard Smith // REWRITE: #ifndef FILE_H
117a21c8e14SRichard Smith // REWRITE: #define FILE_H
118a21c8e14SRichard Smith // REWRITE: #if 0
119a21c8e14SRichard Smith // REWRITE: #include "fwd.h"
120a21c8e14SRichard Smith // REWRITE: #endif
121a21c8e14SRichard Smith // REWRITE-NOT: #pragma clang module import fwd
122a21c8e14SRichard Smith // REWRITE: #endif
123a21c8e14SRichard Smith //
124a21c8e14SRichard Smith // NO-REWRITE-NOT: struct __FILE;
125d1386300SRichard Smith //
126d1386300SRichard Smith // REWRITE: #pragma clang module end
127d1386300SRichard Smith // CHECK: # 2 "{{.*}}file2.h" 2
128d1386300SRichard Smith // NO-REWRITE: #pragma clang module end
129d1386300SRichard Smith // NO-REWRITE: # 2 "{{.*}}file2.h"{{$}}
130d1386300SRichard Smith // ==== return to file2.h
131d1386300SRichard Smith //
132d1386300SRichard Smith // CHECK: extern int file2;
133d1386300SRichard Smith //
134d1386300SRichard Smith // REWRITE: #pragma clang module end
135d1386300SRichard Smith // CHECK: # 3 "<module-includes>" 2
136d1386300SRichard Smith // NO-REWRITE: #pragma clang module end
1378128f332SRichard Smith 
1388128f332SRichard Smith 
139a21c8e14SRichard Smith __FILE *a; // expected-error-re {{{{declaration of '__FILE' must be imported|unknown type name '__FILE'}}}}
1406b199349SRichard Smith #if FILE_REWRITE
141a21c8e14SRichard Smith // [email protected]:* {{here}}
142a21c8e14SRichard Smith #elif FILE_REWRITE_FULL
143a21c8e14SRichard Smith // No note diagnostic at all in this case: we've built the 'file' module but not loaded it into this compilation yet.
1446b199349SRichard Smith #elif REWRITE
145a21c8e14SRichard Smith // [email protected]:* {{here}}
146040e1266SRichard Smith #elif COPY
147a21c8e14SRichard Smith // [email protected]:* {{here}}
14854f0440cSRichard Smith #else
149a21c8e14SRichard Smith // [email protected]:* {{here}}
15054f0440cSRichard Smith #endif
1518128f332SRichard Smith 
1528b706104SRichard Smith #ifdef INCLUDE
1538b706104SRichard Smith #include "file.h"
1548b706104SRichard Smith #else
1558128f332SRichard Smith #pragma clang module import file
1568b706104SRichard Smith #endif
1578128f332SRichard Smith 
1588128f332SRichard Smith FILE *b;
1598b706104SRichard Smith int x = file2; // ok, found in file2.h, even under -DINCLUDE
160