]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: CTAD and constexpr ctor [PR115207]
authorJason Merrill <jason@redhat.com>
Fri, 2 May 2025 12:35:38 +0000 (08:35 -0400)
committerJason Merrill <jason@redhat.com>
Fri, 2 May 2025 13:39:02 +0000 (09:39 -0400)
Here we failed to constant-evaluate the A<int> constructor because DECL_SIZE
wasn't set on 'a' yet, so compare_address thinks we can't be sure it isn't
at the same address as 'i'.

Normally DECL_SIZE is set by build_decl calling layout_decl, but that
doesn't happen here because we don't have a type yet.  So we need to
layout_decl again after deduction.

PR c++/115207

gcc/cp/ChangeLog:

* decl.cc (cp_finish_decl): Call layout_decl after CTAD.

gcc/testsuite/ChangeLog:

* g++.dg/cpp1z/class-deduction118.C: New test.

gcc/cp/decl.cc
gcc/testsuite/g++.dg/cpp1z/class-deduction118.C [new file with mode: 0644]

index 84398e5952a176b40c679191a3e0bf9a14b2128e..03e8c98d4b6845d64eb9ce5b51356f91d3ffadb6 100644 (file)
@@ -8899,6 +8899,9 @@ cp_finish_decl (tree decl, tree init, bool init_const_expr_p,
          TREE_TYPE (decl) = error_mark_node;
          return;
        }
+
+      /* Now that we have a type, try these again.  */
+      layout_decl (decl, 0);
       cp_apply_type_quals_to_decl (cp_type_quals (type), decl);
 
       /* Update the type of the corresponding TEMPLATE_DECL to match.  */
diff --git a/gcc/testsuite/g++.dg/cpp1z/class-deduction118.C b/gcc/testsuite/g++.dg/cpp1z/class-deduction118.C
new file mode 100644 (file)
index 0000000..64d814b
--- /dev/null
@@ -0,0 +1,11 @@
+// PR c++/115207
+// { dg-do compile { target c++17 } }
+
+template <class T>
+struct A {
+  T t;
+  constexpr A(T* p): t (p != &t) { }
+};
+
+const int i = 42;
+constexpr A a = &i;