mirror of git://gcc.gnu.org/git/gcc.git
re PR c++/71665 (ICE on invalid C++ code with non-integral constant enumerator value: in cxx_eval_constant_expression, at cp/constexpr.c:3918)
/cp 2016-07-28 Paolo Carlini <paolo.carlini@oracle.com> PR c++/71665 * decl.c (build_enumerator): Check the type of the enumerator before calling cxx_constant_value. /testsuite 2016-07-28 Paolo Carlini <paolo.carlini@oracle.com> PR c++/71665 * g++.dg/cpp0x/pr71665-1.C: New. * g++.dg/cpp0x/pr71665-2.C: Likewise. * g++.dg/cpp0x/enum29.C: Adjust dg-error string. * g++.dg/ext/label10.C: Likewise. * g++.dg/parse/constant5.C: Likewise. From-SVN: r238828
This commit is contained in:
parent
1b70aaad4c
commit
f064da6af5
|
|
@ -1,3 +1,9 @@
|
||||||
|
2016-07-28 Paolo Carlini <paolo.carlini@oracle.com>
|
||||||
|
|
||||||
|
PR c++/71665
|
||||||
|
* decl.c (build_enumerator): Check the type of the enumerator before
|
||||||
|
calling cxx_constant_value.
|
||||||
|
|
||||||
2016-07-27 Jason Merrill <jason@redhat.com>
|
2016-07-27 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
PR c++/71747
|
PR c++/71747
|
||||||
|
|
|
||||||
|
|
@ -13587,15 +13587,24 @@ build_enumerator (tree name, tree value, tree enumtype, tree attributes,
|
||||||
|
|
||||||
if (value != NULL_TREE)
|
if (value != NULL_TREE)
|
||||||
{
|
{
|
||||||
value = cxx_constant_value (value);
|
if (! INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P
|
||||||
|
(TREE_TYPE (value)))
|
||||||
if (TREE_CODE (value) != INTEGER_CST
|
|
||||||
|| ! INTEGRAL_OR_ENUMERATION_TYPE_P (TREE_TYPE (value)))
|
|
||||||
{
|
{
|
||||||
error ("enumerator value for %qD is not an integer constant",
|
error ("enumerator for %qD must have integral or "
|
||||||
name);
|
"unscoped enumeration type", name);
|
||||||
value = NULL_TREE;
|
value = NULL_TREE;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
value = cxx_constant_value (value);
|
||||||
|
|
||||||
|
if (TREE_CODE (value) != INTEGER_CST)
|
||||||
|
{
|
||||||
|
error ("enumerator value for %qD is not an integer "
|
||||||
|
"constant", name);
|
||||||
|
value = NULL_TREE;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,12 @@
|
||||||
|
2016-07-28 Paolo Carlini <paolo.carlini@oracle.com>
|
||||||
|
|
||||||
|
PR c++/71665
|
||||||
|
* g++.dg/cpp0x/pr71665-1.C: New.
|
||||||
|
* g++.dg/cpp0x/pr71665-2.C: Likewise.
|
||||||
|
* g++.dg/cpp0x/enum29.C: Adjust dg-error string.
|
||||||
|
* g++.dg/ext/label10.C: Likewise.
|
||||||
|
* g++.dg/parse/constant5.C: Likewise.
|
||||||
|
|
||||||
2016-07-28 Steven G. Kargl <kargl@gcc.gnu.org>
|
2016-07-28 Steven G. Kargl <kargl@gcc.gnu.org>
|
||||||
|
|
||||||
PR fortran/71859
|
PR fortran/71859
|
||||||
|
|
|
||||||
|
|
@ -38,7 +38,7 @@ enum E0 { e0 = X0() };
|
||||||
enum E1 { e1 = X1() };
|
enum E1 { e1 = X1() };
|
||||||
enum E2 { e2 = X2() };
|
enum E2 { e2 = X2() };
|
||||||
enum E3 { e3 = X3() };
|
enum E3 { e3 = X3() };
|
||||||
enum E4 { e4 = X4() }; // { dg-error "integer constant" }
|
enum E4 { e4 = X4() }; // { dg-error "integral" }
|
||||||
enum E5 { e5 = X5() }; // { dg-error "ambiguous" }
|
enum E5 { e5 = X5() }; // { dg-error "ambiguous" }
|
||||||
|
|
||||||
enum F0 : int { f0 = X0() };
|
enum F0 : int { f0 = X0() };
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,8 @@
|
||||||
|
// PR c++/71665
|
||||||
|
// { dg-do compile { target c++11 } }
|
||||||
|
|
||||||
|
class A
|
||||||
|
{
|
||||||
|
int f ();
|
||||||
|
enum { a = f }; // { dg-error "enumerator" }
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,8 @@
|
||||||
|
// PR c++/71665
|
||||||
|
// { dg-do compile { target c++11 } }
|
||||||
|
|
||||||
|
class A
|
||||||
|
{
|
||||||
|
enum class E { e = 1 };
|
||||||
|
enum { a = E::e }; // { dg-error "integral or unscoped enumeration" }
|
||||||
|
};
|
||||||
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
template<int N> struct A
|
template<int N> struct A
|
||||||
{
|
{
|
||||||
enum { M = && N }; // { dg-error "referenced outside|cannot appear in|not an integer constant" }
|
enum { M = && N }; // { dg-error "referenced outside|cannot appear in|integral" }
|
||||||
};
|
};
|
||||||
|
|
||||||
A<0> a;
|
A<0> a;
|
||||||
|
|
@ -12,6 +12,6 @@ A<0> a;
|
||||||
void foo ()
|
void foo ()
|
||||||
{
|
{
|
||||||
__label__ P;
|
__label__ P;
|
||||||
enum { O = && P }; // { dg-error "cannot appear in|not an integer constant" }
|
enum { O = && P }; // { dg-error "cannot appear in|integral" }
|
||||||
P:;
|
P:;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
// { dg-options "-std=c++98 -pedantic-errors" }
|
// { dg-options "-std=c++98 -pedantic-errors" }
|
||||||
|
|
||||||
enum E {
|
enum E {
|
||||||
a = 24.2, // { dg-error "constant" }
|
a = 24.2, // { dg-error "integral|constant" }
|
||||||
b = (int)3.7,
|
b = (int)3.7,
|
||||||
c = int(4.2),
|
c = int(4.2),
|
||||||
d = (int)(4.2 + 3.7), // { dg-error "constant" }
|
d = (int)(4.2 + 3.7), // { dg-error "constant" }
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue