blob: f045ec4122f0c80506a6d7c43c8e7a050a07ffe7 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
// UNSUPPORTED: target={{.*}}-zos{{.*}}, target={{.*}}-aix{{.*}}
// RUN: rm -rf %t
// RUN: mkdir %t
// RUN: %clang_cc1 -emit-llvm -o %t/test.bc -F%S/Inputs/merge-record-definition %s \
// RUN: -fmodules -fimplicit-module-maps -fmodules-cache-path=%t/modules.cache -fmodule-name=RecordDef
// RUN: %clang_cc1 -emit-llvm -o %t/test.bc -F%S/Inputs/merge-record-definition %s -DMODULAR_BEFORE_TEXTUAL \
// RUN: -fmodules -fimplicit-module-maps -fmodules-cache-path=%t/modules.cache -fmodule-name=RecordDef
// Test a case when a struct definition once is included from a textual header and once from a module.
#ifdef MODULAR_BEFORE_TEXTUAL
#import <RecordDefIncluder/RecordDefIncluder.h>
#else
#import <RecordDef/RecordDef.h>
#endif
void bibi(void) {
Buffer buf;
buf.b = 1;
AnonymousStruct strct;
strct.x = 1;
UnionRecord rec;
rec.u = 1;
}
#ifdef MODULAR_BEFORE_TEXTUAL
#import <RecordDef/RecordDef.h>
#else
#import <RecordDefIncluder/RecordDefIncluder.h>
#endif
void mbap(void) {
Buffer buf;
buf.c = 2;
AnonymousStruct strct;
strct.y = 2;
UnionRecord rec;
rec.v = 2;
}
|