mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-19 11:35:51 -04:00

We used to have a flag to enable module maps, and two more flags to enable implicit module maps. This is all redundant; we don't need any flag for enabling module maps in the abstract, and we don't usually have -fno- flags for -cc1. We now have just a single flag, -fimplicit-module-maps, that enables implicitly searching the file system for module map files and loading them. The driver interface is unchanged for now. We should probably rename -fmodule-maps to -fimplicit-module-maps at some point. llvm-svn: 239789
28 lines
1.2 KiB
C
28 lines
1.2 KiB
C
// RUN: rm -rf %t
|
|
// RUN: %clang_cc1 -fmodules -fimplicit-module-maps -x objective-c -emit-module -fmodules-cache-path=%t -fmodule-name=diamond_top %S/Inputs/module.map
|
|
// RUN: %clang_cc1 -fmodules -fimplicit-module-maps -x objective-c -emit-module -fmodules-cache-path=%t -fmodule-name=diamond_left %S/Inputs/module.map
|
|
// RUN: %clang_cc1 -fmodules -fimplicit-module-maps -x objective-c -emit-module -fmodules-cache-path=%t -fmodule-name=diamond_right %S/Inputs/module.map
|
|
// RUN: %clang_cc1 -fmodules -fimplicit-module-maps -x objective-c -emit-module -fmodules-cache-path=%t -fmodule-name=diamond_bottom %S/Inputs/module.map
|
|
// RUN: %clang_cc1 -fmodules -fimplicit-module-maps -x objective-c -fmodules-cache-path=%t -I %S/Inputs %s -verify
|
|
// FIXME: When we have a syntax for modules in C, use that.
|
|
|
|
@import diamond_bottom;
|
|
|
|
void test_diamond(int i, float f, double d, char c) {
|
|
top(&i);
|
|
left(&f);
|
|
right(&d);
|
|
bottom(&c);
|
|
bottom(&d);
|
|
// expected-warning@-1{{incompatible pointer types passing 'double *' to parameter of type 'char *'}}
|
|
// expected-note@Inputs/diamond_bottom.h:4{{passing argument to parameter 'x' here}}
|
|
|
|
// Names in multiple places in the diamond.
|
|
top_left(&c);
|
|
|
|
left_and_right(&i);
|
|
struct left_and_right lr;
|
|
lr.left = 17;
|
|
}
|
|
|