diff mbox series

c++: ICE with variable template and [[deprecated]] [PR110031]

Message ID 20240304221114.475713-1-polacek@redhat.com
State New
Headers show
Series c++: ICE with variable template and [[deprecated]] [PR110031] | expand

Commit Message

Marek Polacek March 4, 2024, 10:11 p.m. UTC
Bootstrapped/regtested on x86_64-pc-linux-gnu, ok for trunk/13?

-- >8 --
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                              |  2 +-
 gcc/testsuite/g++.dg/cpp1z/inline-var11.C | 32 +++++++++++++++++++++++
 2 files changed, 33 insertions(+), 1 deletion(-)
 create mode 100644 gcc/testsuite/g++.dg/cpp1z/inline-var11.C


base-commit: a89c5df317d1de74871e2a05c36aed9cbbb21f42

Comments

Jason Merrill March 7, 2024, 3:56 a.m. UTC | #1
On 3/4/24 17:11, Marek Polacek wrote:
> Bootstrapped/regtested on x86_64-pc-linux-gnu, ok for trunk/13?

OK.

> -- >8 --
> 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                              |  2 +-
>   gcc/testsuite/g++.dg/cpp1z/inline-var11.C | 32 +++++++++++++++++++++++
>   2 files changed, 33 insertions(+), 1 deletion(-)
>   create mode 100644 gcc/testsuite/g++.dg/cpp1z/inline-var11.C
> 
> diff --git a/gcc/cp/pt.cc b/gcc/cp/pt.cc
> index c4bc54a8fdb..48d2b3cbac6 100644
> --- a/gcc/cp/pt.cc
> +++ b/gcc/cp/pt.cc
> @@ -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
> index 00000000000..d92911ed3a9
> --- /dev/null
> +++ b/gcc/testsuite/g++.dg/cpp1z/inline-var11.C
> @@ -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;
> +}
> 
> base-commit: a89c5df317d1de74871e2a05c36aed9cbbb21f42
diff mbox series

Patch

diff --git a/gcc/cp/pt.cc b/gcc/cp/pt.cc
index c4bc54a8fdb..48d2b3cbac6 100644
--- a/gcc/cp/pt.cc
+++ b/gcc/cp/pt.cc
@@ -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
index 00000000000..d92911ed3a9
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp1z/inline-var11.C
@@ -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;
+}