4 // RUN: %hmaptool write %S/Inputs/framework-public-includes-private/a.hmap.json %t/a.hmap
5 // RUN: %hmaptool write %S/Inputs/framework-public-includes-private/z.hmap.json %t/z.hmap
7 // RUN: sed -e "s@TEST_DIR@%{/S:regex_replacement}/Inputs/framework-public-includes-private@g" \
8 // RUN: %S/Inputs/framework-public-includes-private/z.yaml > %t/z.yaml
10 // The output with and without modules should be the same, without modules first.
12 // RUN: -iquote %t/z.hmap -iquote %t/a.hmap -ivfsoverlay %t/z.yaml \
13 // RUN: -F%S/Inputs/framework-public-includes-private \
14 // RUN: -fsyntax-only %s -verify
16 // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t/cache \
17 // RUN: -iquote %t/z.hmap -iquote %t/a.hmap -ivfsoverlay %t/z.yaml \
18 // RUN: -F%S/Inputs/framework-public-includes-private \
19 // RUN: -fsyntax-only %s \
22 // The same warnings show up when modules is on but -verify doesn't get it
23 // because they only show up under the module A building context.
24 // RUN: FileCheck --input-file=%t/stderr %s
25 // CHECK: public framework header includes private framework header 'A/APriv.h'
26 // CHECK: public framework header includes private framework header 'A/APriv2.h'
27 // CHECK: public framework header includes private framework header 'Z/ZPriv.h'
31 int bar(void) { return foo(); }
33 // expected-warning@Inputs/framework-public-includes-private/A.framework/Headers/A.h:1{{public framework header includes private framework header 'A/APriv.h'}}
34 // expected-warning@Inputs/framework-public-includes-private/A.framework/Headers/A.h:2{{public framework header includes private framework header 'A/APriv2.h'}}
35 // expected-warning@Inputs/framework-public-includes-private/flat-header-path/Z.h:2{{public framework header includes private framework header 'Z/ZPriv.h'}}