// RUN: %clang_cc1 %s -ast-print -verify > %t.c // RUN: FileCheck %s --input-file %t.c // // RUN: echo >> %t.c "// expected""-warning@* {{use of GNU old-style field designator extension}}" // RUN: echo >> %t.c "// expected""-warning@* {{'EnumWithAttributes' is deprecated}}" // RUN: echo >> %t.c "// expected""-note@* {{'EnumWithAttributes' has been explicitly marked deprecated here}}" // RUN: echo >> %t.c "// expected""-warning@* {{'EnumWithAttributes2' is deprecated}}" // RUN: echo >> %t.c "// expected""-note@* {{'EnumWithAttributes2' has been explicitly marked deprecated here}}" // RUN: echo >> %t.c "// expected""-warning@* {{'EnumWithAttributes3' is deprecated}}" // RUN: echo >> %t.c "// expected""-note@* {{'EnumWithAttributes3' has been explicitly marked deprecated here}}" // RUN: %clang_cc1 -fsyntax-only %t.c -verify typedef void func_typedef(); func_typedef xxx; typedef void func_t(int x); func_t a; struct blah { struct { struct { int b; }; }; }; // This used to crash clang. struct { }(s1); int foo(const struct blah *b) { // CHECK: return b->b; return b->b; } int arr(int a[static 3]) { // CHECK: int a[static 3] return a[2]; } int rarr(int a[restrict static 3]) { // CHECK: int a[restrict static 3] return a[2]; } int varr(int n, int a[static n]) { // CHECK: int a[static n] return a[2]; } int rvarr(int n, int a[restrict static n]) { // CHECK: int a[restrict static n] return a[2]; } // CHECK: typedef struct { typedef struct { int f; } T __attribute__ ((__aligned__)); // CHECK: struct __attribute__((visibility("default"))) S; struct __attribute__((visibility("default"))) S; struct pair_t { int a; int b; }; // CHECK: struct pair_t p = {a: 3, .b = 4}; struct pair_t p = {a: 3, .b = 4}; // expected-warning {{use of GNU old-style field designator extension}} void initializers() { // CHECK: int *x = ((void *)0), *y = ((void *)0); int *x = ((void *)0), *y = ((void *)0); struct Z{}; struct { struct Z z; // CHECK: } z = {(struct Z){}}; } z = {(struct Z){}}; } // CHECK-LABEL: enum __attribute__((deprecated(""))) EnumWithAttributes { enum EnumWithAttributes { // expected-warning {{'EnumWithAttributes' is deprecated}} // CHECK-NEXT: EnumWithAttributesFoo __attribute__((deprecated(""))), EnumWithAttributesFoo __attribute__((deprecated)), // CHECK-NEXT: EnumWithAttributesBar __attribute__((unavailable(""))) = 50 EnumWithAttributesBar __attribute__((unavailable)) = 50 // CHECK-NEXT: } *EnumWithAttributesPtr; } __attribute__((deprecated)) *EnumWithAttributesPtr; // expected-note {{'EnumWithAttributes' has been explicitly marked deprecated here}} // CHECK-LABEL: enum __attribute__((deprecated(""))) EnumWithAttributes2 *EnumWithAttributes2Ptr; // expected-warning@+2 {{'EnumWithAttributes2' is deprecated}} // expected-note@+1 {{'EnumWithAttributes2' has been explicitly marked deprecated here}} enum __attribute__((deprecated)) EnumWithAttributes2 *EnumWithAttributes2Ptr; // CHECK-LABEL: EnumWithAttributes3Fn void EnumWithAttributes3Fn() { // CHECK-NEXT: enum __attribute__((deprecated(""))) EnumWithAttributes3 *EnumWithAttributes3Ptr; // expected-warning@+2 {{'EnumWithAttributes3' is deprecated}} // expected-note@+1 {{'EnumWithAttributes3' has been explicitly marked deprecated here}} enum __attribute__((deprecated)) EnumWithAttributes3 *EnumWithAttributes3Ptr; // Printing must not put the attribute after the tag where it would apply to // the variable instead of the type, and then our deprecation warning would // move to this use of the variable. void *p = EnumWithAttributes3Ptr; }