| // Test check that consuming -E -fdirectives-only output produces the expected | 
 | // header unit. | 
 |  | 
 | // RUN: rm -rf %t | 
 | // RUN: mkdir -p %t | 
 | // RUN: split-file %s %t | 
 | // RUN: cd %t | 
 |  | 
 | // RUN: %clang_cc1 -std=c++20 -E -fdirectives-only -xc++-user-header hu-01.h \ | 
 | // RUN: -o hu-01.iih | 
 |  | 
 | // RUN: %clang_cc1 -std=c++20 -emit-header-unit \ | 
 | // RUN: -xc++-user-header-cpp-output hu-01.iih -o hu-01.pcm | 
 |  | 
 | // RUN: %clang_cc1 -std=c++20 -emit-header-unit -xc++-user-header hu-02.h \ | 
 | // RUN: -DFOO -fmodule-file=hu-01.pcm -o hu-02.pcm -Rmodule-import 2>&1 | \ | 
 | // RUN: FileCheck --check-prefix=CHECK-IMP %s -DTDIR=%t | 
 |  | 
 | //--- hu-01.h | 
 | #ifndef __GUARD | 
 | #define __GUARD | 
 |  | 
 | int baz(int); | 
 | #define FORTYTWO 42 | 
 |  | 
 | #define SHOULD_NOT_BE_DEFINED -1 | 
 | #undef SHOULD_NOT_BE_DEFINED | 
 |  | 
 | #endif // __GUARD | 
 | // expected-no-diagnostics | 
 |  | 
 | //--- hu-02.h | 
 | export import "hu-01.h"; | 
 | #if !defined(FORTYTWO) || FORTYTWO != 42 | 
 | #error FORTYTWO missing in hu-02 | 
 | #endif | 
 |  | 
 | #ifndef __GUARD | 
 | #error __GUARD missing in hu-02 | 
 | #endif | 
 |  | 
 | #ifdef SHOULD_NOT_BE_DEFINED | 
 | #error SHOULD_NOT_BE_DEFINED is visible | 
 | #endif | 
 |  | 
 | // Make sure that we have not discarded macros from the builtin file. | 
 | #ifndef __cplusplus | 
 | #error we dropped a defined macro | 
 | #endif | 
 |  | 
 | #define KAP 6174 | 
 |  | 
 | #ifdef FOO | 
 | #define FOO_BRANCH(X) (X) + 1 | 
 | inline int foo(int x) { | 
 |   if (x == FORTYTWO) | 
 |     return FOO_BRANCH(x); | 
 |   return FORTYTWO; | 
 | } | 
 | #else | 
 | #define BAR_BRANCH(X) (X) + 2 | 
 | inline int bar(int x) { | 
 |   if (x == FORTYTWO) | 
 |     return BAR_BRANCH(x); | 
 |   return FORTYTWO; | 
 | } | 
 | #endif | 
 | // CHECK-IMP: remark: importing module '.{{/|\\\\?}}hu-01.h' from 'hu-01.pcm' |