forked from OSchip/llvm-project
Downgrade the "excess elements in initializer" errors to warnings *in
C*. They're required errors in C++. llvm-svn: 64964
This commit is contained in:
parent
e60ec0abca
commit
1cba5fe1d1
|
@ -685,8 +685,12 @@ DIAG(err_array_init_list_required, ERROR,
|
|||
"initialization with '{...}' expected for array")
|
||||
DIAG(err_excess_initializers, ERROR,
|
||||
"excess elements in %select{array|vector|scalar|union|struct}0 initializer")
|
||||
DIAG(warn_excess_initializers, WARNING,
|
||||
"excess elements in %select{array|vector|scalar|union|struct}0 initializer")
|
||||
DIAG(err_excess_initializers_in_char_array_initializer, ERROR,
|
||||
"excess elements in char array initializer")
|
||||
DIAG(warn_excess_initializers_in_char_array_initializer, WARNING,
|
||||
"excess elements in char array initializer")
|
||||
DIAG(warn_initializer_string_for_char_array_too_long, WARNING,
|
||||
"initializer-string for char array is too long")
|
||||
DIAG(warn_braces_around_scalar_init, WARNING,
|
||||
|
|
|
@ -323,9 +323,11 @@ void InitListChecker::CheckExplicitInitList(InitListExpr *IList, QualType &T,
|
|||
// We have leftover initializers
|
||||
if (IList->getNumInits() > 0 &&
|
||||
SemaRef->IsStringLiteralInit(IList->getInit(Index), T)) {
|
||||
unsigned DK = diag::warn_excess_initializers_in_char_array_initializer;
|
||||
if (SemaRef->getLangOptions().CPlusPlus)
|
||||
DK = diag::err_excess_initializers_in_char_array_initializer;
|
||||
// Special-case
|
||||
SemaRef->Diag(IList->getInit(Index)->getLocStart(),
|
||||
diag::err_excess_initializers_in_char_array_initializer)
|
||||
SemaRef->Diag(IList->getInit(Index)->getLocStart(), DK)
|
||||
<< IList->getInit(Index)->getSourceRange();
|
||||
hadError = true;
|
||||
} else if (!T->isIncompleteType()) {
|
||||
|
@ -338,8 +340,12 @@ void InitListChecker::CheckExplicitInitList(InitListExpr *IList, QualType &T,
|
|||
CurrentObjectType->isScalarType()? 2 :
|
||||
CurrentObjectType->isUnionType()? 3 :
|
||||
4;
|
||||
SemaRef->Diag(IList->getInit(Index)->getLocStart(),
|
||||
diag::err_excess_initializers)
|
||||
|
||||
unsigned DK = diag::warn_excess_initializers;
|
||||
if (SemaRef->getLangOptions().CPlusPlus)
|
||||
DK = diag::err_excess_initializers;
|
||||
|
||||
SemaRef->Diag(IList->getInit(Index)->getLocStart(), DK)
|
||||
<< initKind << IList->getInit(Index)->getSourceRange();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -20,7 +20,7 @@ void func() {
|
|||
|
||||
int x3[x] = { 1, 2 }; // expected-error{{variable-sized object may not be initialized}}
|
||||
|
||||
int x4 = { 1, 2 }; // expected-warning{{braces around scalar initializer}} expected-error{{excess elements in scalar initializer}}
|
||||
int x4 = { 1, 2 }; // expected-warning{{braces around scalar initializer}} expected-warning{{excess elements in scalar initializer}}
|
||||
|
||||
int y[4][3] = {
|
||||
{ 1, 3, 5 },
|
||||
|
@ -37,7 +37,7 @@ void func() {
|
|||
{ 2, 4, 6 },
|
||||
{ 3, 5, 7 },
|
||||
{ 4, 6, 8 },
|
||||
{ 5 }, // expected-error{{excess elements in array initializer}}
|
||||
{ 5 }, // expected-warning{{excess elements in array initializer}}
|
||||
};
|
||||
|
||||
struct threeElements {
|
||||
|
@ -53,17 +53,17 @@ void func() {
|
|||
|
||||
void test() {
|
||||
int y1[3] = {
|
||||
{ 1, 2, 3 } // expected-warning{{braces around scalar initializer}} expected-error{{excess elements in scalar initializer}}
|
||||
{ 1, 2, 3 } // expected-warning{{braces around scalar initializer}} expected-warning{{excess elements in scalar initializer}}
|
||||
};
|
||||
int y3[4][3] = {
|
||||
{ 1, 3, 5 },
|
||||
{ 2, 4, 6 },
|
||||
{ 3, 5, 7 },
|
||||
{ 4, 6, 8 },
|
||||
{ }, // expected-warning{{use of GNU empty initializer extension}} expected-error{{excess elements in array initializer}}
|
||||
{ }, // expected-warning{{use of GNU empty initializer extension}} expected-warning{{excess elements in array initializer}}
|
||||
};
|
||||
int y4[4][3] = {
|
||||
{ 1, 3, 5, 2 }, // expected-error{{excess elements in array initializer}}
|
||||
{ 1, 3, 5, 2 }, // expected-warning{{excess elements in array initializer}}
|
||||
{ 4, 6 },
|
||||
{ 3, 5, 7 },
|
||||
{ 4, 6, 8 },
|
||||
|
@ -149,7 +149,7 @@ void charArrays()
|
|||
static char const test[] = "test";
|
||||
int test_sizecheck[(sizeof(test) / sizeof(char)) == 5? 1 : -1];
|
||||
static char const test2[] = { "weird stuff" };
|
||||
static char const test3[] = { "test", "excess stuff" }; // expected-error{{excess elements in char array initializer}}
|
||||
static char const test3[] = { "test", "excess stuff" }; // expected-warning{{excess elements in char array initializer}}
|
||||
|
||||
char* cp[] = { "Hello" };
|
||||
|
||||
|
@ -157,7 +157,7 @@ void charArrays()
|
|||
int l[sizeof(c) == 6 ? 1 : -1];
|
||||
|
||||
int i[] = { "Hello "}; // expected-warning{{incompatible pointer to integer conversion initializing 'char [7]', expected 'int'}}
|
||||
char c2[] = { "Hello", "Good bye" }; //expected-error{{excess elements in char array initializer}}
|
||||
char c2[] = { "Hello", "Good bye" }; //expected-warning{{excess elements in char array initializer}}
|
||||
|
||||
int i2[1] = { "Hello" }; //expected-warning{{incompatible pointer to integer conversion initializing 'char [6]', expected 'int'}}
|
||||
char c3[5] = { "Hello" };
|
||||
|
@ -178,7 +178,7 @@ float r2[] = {{8}}; //expected-warning{{braces around scalar initializer}}
|
|||
char r3[][5] = {1,2,3,4,5,6};
|
||||
int r3_sizecheck[(sizeof(r3) / sizeof(char[5])) == 2? 1 : -1];
|
||||
char r3_2[sizeof r3 == 10 ? 1 : -1];
|
||||
float r4[1][2] = {1,{2},3,4}; //expected-warning{{braces around scalar initializer}} expected-error{{excess elements in array initializer}}
|
||||
float r4[1][2] = {1,{2},3,4}; //expected-warning{{braces around scalar initializer}} expected-warning{{excess elements in array initializer}}
|
||||
char r5[][5] = {"aa", "bbb", "ccccc"};
|
||||
char r6[sizeof r5 == 15 ? 1 : -1];
|
||||
const char r7[] = "zxcv";
|
||||
|
@ -207,7 +207,7 @@ union {char a; int b;} t7[] = {1, 2, 3};
|
|||
int t8[sizeof t7 == (3*sizeof(int)) ? 1 : -1];
|
||||
|
||||
struct bittest{int : 31, a, :21, :12, b;};
|
||||
struct bittest bittestvar = {1, 2, 3, 4}; //expected-error{{excess elements in struct initializer}}
|
||||
struct bittest bittestvar = {1, 2, 3, 4}; //expected-warning{{excess elements in struct initializer}}
|
||||
|
||||
// Not completely sure what should happen here...
|
||||
int u1 = {}; //expected-warning{{use of GNU empty initializer extension}} expected-error{{scalar initializer cannot be empty}}
|
||||
|
@ -242,7 +242,7 @@ struct soft_segment_descriptor gdt_segs[] = {
|
|||
};
|
||||
|
||||
static void sppp_ipv6cp_up();
|
||||
const struct {} ipcp = { sppp_ipv6cp_up }; //expected-warning{{empty struct extension}} expected-error{{excess elements in struct initializer}}
|
||||
const struct {} ipcp = { sppp_ipv6cp_up }; //expected-warning{{empty struct extension}} expected-warning{{excess elements in struct initializer}}
|
||||
|
||||
struct _Matrix { union { float m[4][4]; }; }; //expected-warning{{anonymous unions are a GNU extension in C}}
|
||||
typedef struct _Matrix Matrix;
|
||||
|
|
|
@ -185,4 +185,4 @@ const union wibble wobble = { .arr2[0] = 0xffff,
|
|||
.arr2[1] = 0xffff,
|
||||
.arr2[2] = 0xffff };
|
||||
|
||||
const union wibble wobble2 = { .arr2 = {4, 5, 6}, 7 }; // expected-error{{excess elements in union initializer}}
|
||||
const union wibble wobble2 = { .arr2 = {4, 5, 6}, 7 }; // expected-warning{{excess elements in union initializer}}
|
||||
|
|
|
@ -4,7 +4,7 @@ struct one {
|
|||
int values[];
|
||||
} x = {5, {1, 2, 3}};
|
||||
|
||||
struct one x2 = { 5, 1, 2, 3 }; // expected-error{{excess elements in struct initializer}}
|
||||
struct one x2 = { 5, 1, 2, 3 }; // expected-warning{{excess elements in struct initializer}}
|
||||
|
||||
void test() {
|
||||
struct one x3 = {5, {1, 2, 3}};
|
||||
|
|
|
@ -108,3 +108,5 @@ struct foo2 {
|
|||
struct foo2 bar2[] = {
|
||||
{ (intptr_t)bbb }
|
||||
};
|
||||
|
||||
struct foo2 bar3 = { 1, 2 }; // expected-warning{{excess elements in struct initializer}}
|
||||
|
|
|
@ -1,15 +1,17 @@
|
|||
// RUN: clang %s -fsyntax-only -verify
|
||||
|
||||
typedef __attribute__(( ext_vector_type(4) )) float float4;
|
||||
//typedef float float4 __attribute__((vector_size(16)));
|
||||
//typedef __attribute__(( ext_vector_type(4) )) float float4;
|
||||
typedef float float4 __attribute__((vector_size(16)));
|
||||
|
||||
float4 foo = (float4){ 1.0, 2.0, 3.0, 4.0 };
|
||||
|
||||
float4 foo2 = (float4){ 1.0, 2.0, 3.0, 4.0 , 5.0 }; // expected-warning{{excess elements in vector initializer}}
|
||||
|
||||
float4 array[] = { 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0};
|
||||
int array_sizecheck[(sizeof(array) / sizeof(float4)) == 3? 1 : -1];
|
||||
|
||||
float4 array2[2] = { 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0,
|
||||
9.0 }; // expected-error {{excess elements in array initializer}}
|
||||
9.0 }; // expected-warning {{excess elements in array initializer}}
|
||||
|
||||
float4 array3[2] = { {1.0, 2.0, 3.0}, 5.0, 6.0, 7.0, 8.0,
|
||||
9.0 }; // expected-error {{excess elements in array initializer}}
|
||||
9.0 }; // expected-warning {{excess elements in array initializer}}
|
||||
|
|
Loading…
Reference in New Issue