1 // RUN: rm -rf %t 2 // RUN: mkdir %t 3 // RUN: echo '// A' > %t/A.h 4 // RUN: echo '#include "C.h"' > %t/B.h 5 // RUN: echo '// C' > %t/C.h 6 // RUN: echo 'module A { header "A.h" }' > %t/module.modulemap 7 // RUN: echo 'module B { header "B.h" }' >> %t/module.modulemap 8 // RUN: echo 'module C { header "C.h" }' >> %t/module.modulemap 9 10 // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t -fsyntax-only %s -verify \ 11 // RUN: -I %t -Rmodule-build 12 13 @import A; // expected-remark{{building module 'A' as}} expected-remark {{finished building module 'A'}} 14 @import B; // expected-remark{{building module 'B' as}} expected-remark {{finished building module 'B'}} 15 @import A; // no diagnostic 16 @import B; // no diagnostic 17 18 // RUN: echo ' ' >> %t/C.h 19 // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t -fsyntax-only %s -I %t \ 20 // RUN: -Rmodule-build 2>&1 | FileCheck %s 21 22 // RUN: echo ' ' >> %t/C.h 23 // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t -fsyntax-only %s -I %t \ 24 // RUN: -Reverything 2>&1 | FileCheck %s 25 26 // RUN: echo ' ' >> %t/B.h 27 // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t -fsyntax-only %s -I %t \ 28 // RUN: 2>&1 | FileCheck -allow-empty -check-prefix=NO-REMARKS %s 29 30 // RUN: echo ' ' >> %t/B.h 31 // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t -fsyntax-only %s -I %t \ 32 // RUN: -Rmodule-build -Rno-everything 2>&1 | \ 33 // RUN: FileCheck -allow-empty -check-prefix=NO-REMARKS %s 34 35 // CHECK-NOT: building module 'A' 36 // CHECK: building module 'B' 37 // CHECK: building module 'C' 38 // CHECK: finished building module 'C' 39 // CHECK: finished building module 'B' 40 // NO-REMARKS-NOT: building module 'A' 41 // NO-REMARKS-NOT: building module 'B' 42