forked from OSchip/llvm-project
146 lines
3.2 KiB
C
146 lines
3.2 KiB
C
// RUN: %clang_cc1 %s -verify -fsyntax-only -ffreestanding
|
|
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
typedef void (* fp)(void);
|
|
void foo(void);
|
|
|
|
// PR clang/3377
|
|
fp a[(short int)1] = { foo };
|
|
|
|
int myArray[5] = {1, 2, 3, 4, 5};
|
|
int *myPointer2 = myArray;
|
|
int *myPointer = &(myArray[2]);
|
|
|
|
|
|
extern int x;
|
|
void *g = &x;
|
|
int *h = &x;
|
|
|
|
int test() {
|
|
int a[10];
|
|
int b[10] = a; // expected-error {{array initializer must be an initializer list}}
|
|
int +; // expected-error {{expected identifier or '('}}
|
|
}
|
|
|
|
|
|
// PR2050
|
|
struct cdiff_cmd {
|
|
const char *name;
|
|
unsigned short argc;
|
|
int (*handler)();
|
|
};
|
|
int cdiff_cmd_open();
|
|
struct cdiff_cmd commands[] = {
|
|
{"OPEN", 1, &cdiff_cmd_open }
|
|
};
|
|
|
|
// PR2348
|
|
static struct { int z; } s[2];
|
|
int *t = &(*s).z;
|
|
|
|
// PR2349
|
|
short *a2(void)
|
|
{
|
|
short int b;
|
|
static short *bp = &b; // expected-error {{initializer element is not a compile-time constant}}
|
|
|
|
return bp;
|
|
}
|
|
|
|
int pbool(void) {
|
|
typedef const _Bool cbool;
|
|
_Bool pbool1 = (void *) 0;
|
|
cbool pbool2 = &pbool;
|
|
return pbool2;
|
|
}
|
|
|
|
|
|
// rdar://5870981
|
|
union { float f; unsigned u; } u = { 1.0f };
|
|
|
|
// rdar://6156694
|
|
int f3(int x) { return x; }
|
|
typedef void (*vfunc)(void);
|
|
void *bar = (vfunc) f3;
|
|
|
|
// PR2747
|
|
struct sym_reg {
|
|
char nc_gpreg;
|
|
};
|
|
int sym_fw1a_scr[] = {
|
|
((int)(&((struct sym_reg *)0)->nc_gpreg)) & 0,
|
|
8 * ((int)(&((struct sym_reg *)0)->nc_gpreg))
|
|
};
|
|
|
|
// PR3001
|
|
struct s1 s2 = { // expected-error {{variable has incomplete type 'struct s1'}} \
|
|
// expected-note {{forward declaration of 'struct s1'}}
|
|
.a = sizeof(struct s3), // expected-error {{invalid application of 'sizeof'}} \
|
|
// expected-note{{forward declaration of 'struct s3'}}
|
|
.b = bogus // expected-error {{use of undeclared identifier 'bogus'}}
|
|
}
|
|
|
|
// PR3382
|
|
char t[] = ("Hello");
|
|
|
|
// <rdar://problem/6094855>
|
|
typedef struct { } empty;
|
|
|
|
typedef struct {
|
|
empty e;
|
|
int i2;
|
|
} st;
|
|
|
|
st st1 = { .i2 = 1 };
|
|
|
|
// <rdar://problem/6096826>
|
|
struct {
|
|
int a;
|
|
int z[2];
|
|
} y = { .z = {} };
|
|
|
|
int bbb[10];
|
|
|
|
struct foo2 {
|
|
uintptr_t a;
|
|
};
|
|
|
|
struct foo2 bar2[] = {
|
|
{ (intptr_t)bbb }
|
|
};
|
|
|
|
struct foo2 bar3 = { 1, 2 }; // expected-warning{{excess elements in struct initializer}}
|
|
|
|
int* ptest1 = __builtin_choose_expr(1, (int*)0, (int*)0);
|
|
|
|
typedef int32_t ivector4 __attribute((vector_size(16)));
|
|
ivector4 vtest1 = 1 ? (ivector4){1} : (ivector4){1};
|
|
ivector4 vtest2 = __builtin_choose_expr(1, (ivector4){1}, (ivector4){1});
|
|
|
|
uintptr_t ptrasintadd1 = (uintptr_t)&a - 4;
|
|
uintptr_t ptrasintadd2 = (uintptr_t)&a + 4;
|
|
uintptr_t ptrasintadd3 = 4 + (uintptr_t)&a;
|
|
|
|
// PR4285
|
|
const wchar_t widestr[] = L"asdf";
|
|
|
|
// PR5447
|
|
const double pr5447 = (0.05 < -1.0) ? -1.0 : 0.0499878;
|
|
|
|
// PR4386
|
|
|
|
// None of these are constant initializers, but we implement GCC's old
|
|
// behaviour of accepting bar and zed but not foo. GCC's behaviour was
|
|
// changed in 2007 (rev 122551), so we should be able to change too one
|
|
// day.
|
|
int PR4386_bar();
|
|
int PR4386_foo() __attribute((weak));
|
|
int PR4386_zed();
|
|
|
|
int PR4386_a = ((void *) PR4386_bar) != 0;
|
|
int PR4386_b = ((void *) PR4386_foo) != 0; // expected-error{{initializer element is not a compile-time constant}}
|
|
int PR4386_c = ((void *) PR4386_zed) != 0;
|
|
int PR4386_zed() __attribute((weak));
|