aboutsummaryrefslogtreecommitdiff
path: root/clang/test/Modules/merge-record-definition-nonmodular.m
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;
}