Tested x86_64-pc-linux-gnu, applying to trunk.

-- 8< --

After r16-332 these tests started failing.  constexpr-89285.C should have
always given this error, and the new nonlit19.C needs to remove the
destructor body to prevent -fimplicit-constexpr from making the testcase
well-formed.

gcc/testsuite/ChangeLog:

        * g++.dg/cpp1y/constexpr-89285.C: Always diagnose reinterpret_cast.
        * g++.dg/cpp23/constexpr-nonlit19.C: Remove ~A body.
---
 gcc/testsuite/g++.dg/cpp1y/constexpr-89285.C    | 2 +-
 gcc/testsuite/g++.dg/cpp23/constexpr-nonlit19.C | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/gcc/testsuite/g++.dg/cpp1y/constexpr-89285.C 
b/gcc/testsuite/g++.dg/cpp1y/constexpr-89285.C
index efbf9bd15dd..d1aaecc1013 100644
--- a/gcc/testsuite/g++.dg/cpp1y/constexpr-89285.C
+++ b/gcc/testsuite/g++.dg/cpp1y/constexpr-89285.C
@@ -10,7 +10,7 @@ struct B {
     int *c = &x->a;
     while (*c)
       c = reinterpret_cast<int *>((reinterpret_cast<char *>(c) + *c));
-    *c = reinterpret_cast<char *>(this) - reinterpret_cast<char *>(c); // { 
dg-error "reinterpret_cast" "" { target c++20_down } }
+    *c = reinterpret_cast<char *>(this) - reinterpret_cast<char *>(c); // { 
dg-error "reinterpret_cast" }
   }
 };
 struct C : A {  // { dg-error "" "" { target c++14_down } }
diff --git a/gcc/testsuite/g++.dg/cpp23/constexpr-nonlit19.C 
b/gcc/testsuite/g++.dg/cpp23/constexpr-nonlit19.C
index 1b73e2d8209..834dc631778 100644
--- a/gcc/testsuite/g++.dg/cpp23/constexpr-nonlit19.C
+++ b/gcc/testsuite/g++.dg/cpp23/constexpr-nonlit19.C
@@ -1,6 +1,6 @@
 // { dg-do compile { target c++23 } }
 
-struct A { ~A() { } };
+struct A { ~A(); };
 
 struct B {
   constexpr B() {

base-commit: e6e3b0772ed40cc65a544bbe744ece62d8b9713e
-- 
2.49.0

Reply via email to