]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: ICE with variable template and [[deprecated]] [PR110031]
authorMarek Polacek <polacek@redhat.com>
Mon, 4 Mar 2024 17:35:18 +0000 (12:35 -0500)
committerMarek Polacek <polacek@redhat.com>
Thu, 7 Mar 2024 14:48:44 +0000 (09:48 -0500)
lookup_and_finish_template_variable already has and uses the complain
parameter but it is not passing it down to mark_used so we got the
default tf_warning_or_error, which causes various problems when
lookup_and_finish_template_variable gets called with complain=tf_none.

PR c++/110031

gcc/cp/ChangeLog:

* pt.cc (lookup_and_finish_template_variable): Pass complain to
mark_used.

gcc/testsuite/ChangeLog:

* g++.dg/cpp1z/inline-var11.C: New test.

gcc/cp/pt.cc
gcc/testsuite/g++.dg/cpp1z/inline-var11.C [new file with mode: 0644]

index d73f6d9348535514f4ea8f88d61ecaa6299aa28a..040ced45187eb4e5dc413d4e997fab5797986337 100644 (file)
@@ -10533,7 +10533,7 @@ lookup_and_finish_template_variable (tree templ, tree targs,
   if (var == error_mark_node)
     return error_mark_node;
   var = finish_template_variable (var, complain);
-  mark_used (var);
+  mark_used (var, complain);
   return var;
 }
 
diff --git a/gcc/testsuite/g++.dg/cpp1z/inline-var11.C b/gcc/testsuite/g++.dg/cpp1z/inline-var11.C
new file mode 100644 (file)
index 0000000..d92911e
--- /dev/null
@@ -0,0 +1,32 @@
+// PR c++/110031
+// { dg-do compile { target c++17 } }
+
+template <typename T>
+[[deprecated]]
+inline constexpr bool t = true ;
+
+template <bool a>
+struct enableif;
+
+template<>
+struct enableif<true>
+{
+        using y = int;
+};
+template <bool a>
+using enableif_t = typename enableif<a>::y;
+
+template <typename T, enableif_t<t<T>> = 0>   // { dg-warning "deprecated" }
+struct A {  A(T &&)  {  }};
+
+template <typename T>
+struct A<T> {
+  A(T &&) = delete;
+  A() = delete;
+};
+
+int main(void)
+{
+  A<double> a(5.3); // { dg-error "use of deleted function" }
+  return 0;
+}