Mercurial > hg > CbC > CbC_llvm
view clang/test/SemaCXX/c99.cpp @ 266:00f31e85ec16 default tip
Added tag current for changeset 31d058e83c98
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sat, 14 Oct 2023 10:13:55 +0900 |
parents | 1d019706d866 |
children |
line wrap: on
line source
// RUN: %clang_cc1 -fsyntax-only -pedantic -verify=expected,cxx17 -std=c++17 %s // RUN: %clang_cc1 -fsyntax-only -pedantic -verify=expected,cxx20 -std=c++2a %s // cxx17-warning@* 0+{{designated initializers are a C++20 extension}} void f1(int i[static 5]) { // expected-error{{C99}} } struct Point { int x; int y; int z[]; }; // expected-warning{{flexible array members are a C99 feature}} Point p1 = { .x = 17, y: 25 }; // expected-warning{{use of GNU old-style field designator extension}} Point p2 = { .x = 17, // expected-warning {{mixture of designated and non-designated initializers in the same initializer list is a C99 extension}} 25 // expected-note {{first non-designated initializer}} }; Point p3 = { .x = 17, // expected-note {{previous initialization is here}} .x = 18, // expected-warning {{initializer overrides prior initialization of this subobject}} }; Point p4 = { .x = 17, // expected-warning {{mixture of designated and non-designated initializers in the same initializer list is a C99 extension}} 25, // expected-note {{first non-designated initializer}} // expected-note@-1 {{previous initialization is here}} .y = 18, // expected-warning {{initializer overrides prior initialization of this subobject}} }; int arr[1] = {[0] = 0}; // expected-warning {{array designators are a C99 extension}} struct Pt { int x, y; }; struct Rect { Pt tl, br; }; Rect r = { .tl.x = 0 // expected-warning {{nested designators are a C99 extension}} }; struct NonTrivial { NonTrivial(); ~NonTrivial(); }; struct S { int a; NonTrivial b; }; struct T { S s; }; S f(); T t1 = { .s = f() }; // It's important that we reject this; we would not destroy the existing // 'NonTrivial' object before overwriting it (and even calling its destructor // would not necessarily be correct). T t2 = { .s = f(), // expected-note {{previous}} .s.b = NonTrivial() // expected-error {{initializer would partially override prior initialization of object of type 'S' with non-trivial destruction}} // expected-warning@-1 {{nested}} }; // FIXME: It might be reasonable to accept this. T t3 = { .s = f(), // expected-note {{previous}} .s.a = 0 // expected-error {{initializer would partially override prior initialization of object of type 'S' with non-trivial destruction}} // expected-warning@-1 {{nested}} };