aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorPatrick Palka <ppalka@redhat.com>2020-05-22 10:28:19 -0400
committerJason Merrill <jason@redhat.com>2020-05-29 18:18:29 -0400
commitc75ebe76ae12ac4020f20a24f34606a594a40d15 (patch)
treedc384665b2d840345b339c600b84a27994d98fc0 /gcc
parent2fb595f8348e164d2f06536ba98322616eeaeeb6 (diff)
downloadgcc-c75ebe76ae12ac4020f20a24f34606a594a40d15.zip
gcc-c75ebe76ae12ac4020f20a24f34606a594a40d15.tar.gz
gcc-c75ebe76ae12ac4020f20a24f34606a594a40d15.tar.bz2
c++: P0848R3 and member function templates [PR95181]
When comparing two special member function templates to see if one hides the other (as per P0848R3), we need to check satisfaction which we can't do on templates. So this patch makes add_method skip the eligibility test on member function templates and just lets them coexist. gcc/cp/ChangeLog: PR c++/95181 * class.c (add_method): Let special member function templates coexist if they are not equivalently constrained, or in a class template. gcc/testsuite/ChangeLog: PR c++/95181 * g++.dg/concepts/pr95181.C: New test. * g++.dg/concepts/pr95181-2.C: New test. Co-authored-by: Jason Merrill <jason@redhat.com>
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/class.c15
-rw-r--r--gcc/testsuite/g++.dg/concepts/pr95181-2.C8
-rw-r--r--gcc/testsuite/g++.dg/concepts/pr95181.C9
3 files changed, 28 insertions, 4 deletions
diff --git a/gcc/cp/class.c b/gcc/cp/class.c
index ca492cd..c818826 100644
--- a/gcc/cp/class.c
+++ b/gcc/cp/class.c
@@ -1081,12 +1081,19 @@ add_method (tree type, tree method, bool via_using)
{
if (!equivalently_constrained (fn, method))
{
+ if (processing_template_decl)
+ /* We can't check satisfaction in dependent context, wait until
+ the class is instantiated. */
+ continue;
+
special_function_kind sfk = special_memfn_p (method);
- if (sfk == sfk_none || DECL_INHERITED_CTOR (fn))
- /* Non-special member functions coexist if they are not
- equivalently constrained. A member function is not hidden
- by an inherited constructor. */
+ if (sfk == sfk_none
+ || DECL_INHERITED_CTOR (fn)
+ || TREE_CODE (fn) == TEMPLATE_DECL)
+ /* Member function templates and non-special member functions
+ coexist if they are not equivalently constrained. A member
+ function is not hidden by an inherited constructor. */
continue;
/* P0848: For special member functions, deleted, unsatisfied, or
diff --git a/gcc/testsuite/g++.dg/concepts/pr95181-2.C b/gcc/testsuite/g++.dg/concepts/pr95181-2.C
new file mode 100644
index 0000000..6d67350
--- /dev/null
+++ b/gcc/testsuite/g++.dg/concepts/pr95181-2.C
@@ -0,0 +1,8 @@
+// { dg-do compile { target concepts } }
+
+template<bool B> struct g {
+ g() requires B && false;
+ g() requires B;
+};
+
+g<true> b; // error
diff --git a/gcc/testsuite/g++.dg/concepts/pr95181.C b/gcc/testsuite/g++.dg/concepts/pr95181.C
new file mode 100644
index 0000000..0185c86
--- /dev/null
+++ b/gcc/testsuite/g++.dg/concepts/pr95181.C
@@ -0,0 +1,9 @@
+// PR c++/95181
+// { dg-do compile { target concepts } }
+
+template <typename> struct f {
+ template <typename T=int> f();
+ template <typename T=int> requires false f();
+};
+
+f<int> a;