aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2017-02-20 01:05:38 -0500
committerJason Merrill <jason@gcc.gnu.org>2017-02-20 01:05:38 -0500
commit4cd159317cb88496122bd3999a04c56c513bd915 (patch)
treeff7efd0f2974d9bdce317dc8faede16c6ebfa38d /gcc
parentcfb825648d585d15149c8e7658757ae9fc402b33 (diff)
downloadgcc-4cd159317cb88496122bd3999a04c56c513bd915.zip
gcc-4cd159317cb88496122bd3999a04c56c513bd915.tar.gz
gcc-4cd159317cb88496122bd3999a04c56c513bd915.tar.bz2
PR c++/79470 - partial ordering with reference parameters
* pt.c (unify) [INDIRECT_REF]: Handle pack expansions. From-SVN: r245589
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog3
-rw-r--r--gcc/cp/pt.c5
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/variadic-ref1.C10
3 files changed, 18 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index ee222b4..033831d 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,5 +1,8 @@
2017-02-19 Jason Merrill <jason@redhat.com>
+ PR c++/79470 - partial ordering with reference parameters
+ * pt.c (unify) [INDIRECT_REF]: Handle pack expansions.
+
PR c++/79500 - ICE with non-template deduction guide
* pt.c (do_class_deduction): Use STRIP_TEMPLATE rather than
DECL_TEMPLATE_RESULT.
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index 46e6498..0a9f5d5 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -20918,8 +20918,13 @@ unify (tree tparms, tree targs, tree parm, tree arg, int strict,
case INDIRECT_REF:
if (REFERENCE_REF_P (parm))
{
+ bool pexp = PACK_EXPANSION_P (arg);
+ if (pexp)
+ arg = PACK_EXPANSION_PATTERN (arg);
if (REFERENCE_REF_P (arg))
arg = TREE_OPERAND (arg, 0);
+ if (pexp)
+ arg = make_pack_expansion (arg);
return unify (tparms, targs, TREE_OPERAND (parm, 0), arg,
strict, explain_p);
}
diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic-ref1.C b/gcc/testsuite/g++.dg/cpp0x/variadic-ref1.C
new file mode 100644
index 0000000..441d386
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/variadic-ref1.C
@@ -0,0 +1,10 @@
+// PR c++/79470
+// { dg-do compile { target c++11 } }
+
+ template < const int&... > struct AA;
+
+ template < > struct AA<> { };
+
+ template < const int& II, const int&... Is >
+ struct AA<II,Is...> { };
+