[gcc r14-3907] c++: ICE with -fno-exceptions and array init [PR107198]
Jason Merrill
jason@gcc.gnu.org
Tue Sep 12 17:27:12 GMT 2023
https://gcc.gnu.org/g:ea5abbb263315e558c876b50c9371b90ddd5e028
commit r14-3907-gea5abbb263315e558c876b50c9371b90ddd5e028
Author: Jason Merrill <jason@redhat.com>
Date: Thu Sep 7 05:15:01 2023 -0400
c++: ICE with -fno-exceptions and array init [PR107198]
The removed line no longer has an effect on anew5.C error recovery, and
removing it improves error recovery for this testcase.
PR c++/107198
gcc/cp/ChangeLog:
* typeck2.cc (process_init_constructor_array): Use VEC_INIT_EXPR
regardless of seen_error.
gcc/testsuite/ChangeLog:
* g++.dg/eh/no-exceptions1.C: New test.
Diff:
---
gcc/cp/typeck2.cc | 1 -
gcc/testsuite/g++.dg/eh/no-exceptions1.C | 19 +++++++++++++++++++
2 files changed, 19 insertions(+), 1 deletion(-)
diff --git a/gcc/cp/typeck2.cc b/gcc/cp/typeck2.cc
index 582a73bb053d..cd1ea045720d 100644
--- a/gcc/cp/typeck2.cc
+++ b/gcc/cp/typeck2.cc
@@ -1683,7 +1683,6 @@ process_init_constructor_array (tree type, tree init, int nested, int flags,
if (next)
{
if (next != error_mark_node
- && ! seen_error () // Improves error-recovery on anew5.C.
&& (initializer_constant_valid_p (next, TREE_TYPE (next))
!= null_pointer_node))
{
diff --git a/gcc/testsuite/g++.dg/eh/no-exceptions1.C b/gcc/testsuite/g++.dg/eh/no-exceptions1.C
new file mode 100644
index 000000000000..4b77064c6469
--- /dev/null
+++ b/gcc/testsuite/g++.dg/eh/no-exceptions1.C
@@ -0,0 +1,19 @@
+// PR c++/107198
+// { dg-additional-options -fno-exceptions }
+
+struct A {
+ A() { throw 0; } // { dg-error disabled }
+ A(int i) { throw i; }
+ A(const A&) { throw 10; }
+};
+
+void try_idx (int i)
+{
+ int t = 10;
+ try {
+ struct X {
+ A e1[2], e2;
+ }
+ x2[3] = { { 1, 2, 3 }, { 4, 5, 6 } };
+ } catch (int x) { t = x; } // { dg-prune-output "not declared" }
+}
More information about the Gcc-cvs
mailing list