teak-llvm/clang/test/Sema/empty1.c
Hans Wennborg c9bd88e681 Remove the -cxx-abi command-line flag.
This makes the C++ ABI depend entirely on the target: MS ABI for -win32 triples,
Itanium otherwise. It's no longer possible to do weird combinations.

To be able to run a test with a specific ABI without constraining it to a
specific triple, new substitutions are added to lit: %itanium_abi_triple and
%ms_abi_triple can be used to get the current target triple adjusted to the
desired ABI. For example, if the test suite is running with the i686-pc-win32
target, %itanium_abi_triple will expand to i686-pc-mingw32.

Differential Revision: http://llvm-reviews.chandlerc.com/D2545

llvm-svn: 199250
2014-01-14 19:35:09 +00:00

88 lines
2.8 KiB
C

// RUN: %clang_cc1 %s -triple %itanium_abi_triple -fsyntax-only -verify -Wc++-compat
// Note: Empty C structs are 4 bytes in the Microsoft ABI.
struct emp_1 { // expected-warning {{empty struct has size 0 in C, size 1 in C++}}
};
union emp_2 { // expected-warning {{empty union has size 0 in C, size 1 in C++}}
};
struct emp_3 { // expected-warning {{struct has size 0 in C, size 1 in C++}}
int : 0;
};
union emp_4 { // expected-warning {{union has size 0 in C, size 1 in C++}}
int : 0;
};
struct emp_5 { // expected-warning {{struct has size 0 in C, size 1 in C++}}
int : 0;
int : 0;
};
union emp_6 { // expected-warning {{union has size 0 in C, size 1 in C++}}
int : 0;
int : 0;
};
struct emp_7 { // expected-warning {{struct has size 0 in C, size 1 in C++}}
struct emp_1 f1;
};
union emp_8 { // expected-warning {{union has size 0 in C, size 1 in C++}}
struct emp_1 f1;
};
struct emp_9 { // expected-warning {{struct has size 0 in C, non-zero size in C++}}
struct emp_1 f1;
union emp_2 f2;
};
// Checks for pointer subtraction (PR15683)
struct emp_1 *func_1p(struct emp_1 *x) { return x - 5; }
int func_1() {
struct emp_1 v[1];
return v - v; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
}
int func_2(struct emp_1 *x) {
return 1 + x - x; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
}
int func_3(struct emp_1 *x, struct emp_1 *y) {
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
}
int func_4(struct emp_1 *x, const struct emp_1 *y) {
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
}
int func_5(volatile struct emp_1 *x, const struct emp_1 *y) {
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1' of zero size has undefined behavior}}
}
int func_6() {
union emp_2 v[1];
return v - v; // expected-warning {{subtraction of pointers to type 'union emp_2' of zero size has undefined behavior}}
}
struct A; // expected-note {{forward declaration of 'struct A'}}
int func_7(struct A *x, struct A *y) {
return x - y; // expected-error {{arithmetic on a pointer to an incomplete type 'struct A'}}
}
int func_8(struct emp_1 (*x)[10], struct emp_1 (*y)[10]) {
return x - y; // expected-warning {{subtraction of pointers to type 'struct emp_1 [10]' of zero size has undefined behavior}}
}
int func_9(struct emp_1 (*x)[], struct emp_1 (*y)[]) {
return x - y; // expected-error {{arithmetic on a pointer to an incomplete type 'struct emp_1 []'}}
}
int func_10(int (*x)[0], int (*y)[0]) {
return x - y; // expected-warning {{subtraction of pointers to type 'int [0]' of zero size has undefined behavior}}
}