aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2019-03-10 14:02:48 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2019-03-10 14:02:48 +0100
commitc98eece2bac43f80f8f3b1edeae253e3935d5df1 (patch)
treedac53a5ff1fa2a75c82f083169f33893a3f53a3f
parent6f8fc6f932414e051e4c1c4c48e4c694cb9a0447 (diff)
downloadgcc-c98eece2bac43f80f8f3b1edeae253e3935d5df1.zip
gcc-c98eece2bac43f80f8f3b1edeae253e3935d5df1.tar.gz
gcc-c98eece2bac43f80f8f3b1edeae253e3935d5df1.tar.bz2
re PR c++/89648 (rejects-valid error starting with r268850)
PR c++/89648 * g++.dg/cpp0x/lambda/lambda-89648.C: New test. From-SVN: r269554
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/lambda/lambda-89648.C60
2 files changed, 65 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index cb07129..e5f1da7 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2019-03-10 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89648
+ * g++.dg/cpp0x/lambda/lambda-89648.C: New test.
+
2019-03-10 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/66089
diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-89648.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-89648.C
new file mode 100644
index 0000000..c7a3e84
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-89648.C
@@ -0,0 +1,60 @@
+// PR c++/89648
+// { dg-do compile { target c++11 } }
+
+template <typename T, T U> struct A { static const T e = U; };
+template <typename> struct B;
+template <unsigned long, typename> struct C;
+template <long i, typename T> using E = typename C<i, T>::k;
+template <typename T, T...> struct F {};
+template <typename T, T U> using G = F<T, __integer_pack(U)...>;
+template <unsigned long... U> using H = F<unsigned long, U...>;
+template <unsigned long U> using I = G<unsigned long, U>;
+template <typename...> class J {};
+template <typename... U> struct B<J<U...>> : A<long, sizeof...(U)> {};
+template <unsigned long N, typename T, typename... U>
+struct C<N, J<T, U...>> : C<N - 1, J<U...>> {};
+template <typename T, typename... U> struct C<0, J<T, U...>> { typedef T k; };
+template <unsigned long N, typename... U> E<N, J<U...>> qux (J<U...>);
+struct D { template <typename T> void foo (T) {} };
+void bar (...);
+struct K { void baz (int &); int l; D m; int *n, o; };
+template <typename T, typename U, typename V, unsigned long... W>
+void quux (int, int *, D x, int *, int, int, T, U, V y, H<W...>) {
+ x.foo ([=] { bar (qux <W>(y)...); });
+}
+void K::baz (int &x) {
+ J<int, int> p;
+ int q, r;
+ long s;
+ quux (x, &l, m, n, o, r, s, q, p, I<B<decltype(p)>::e> ());
+}
+// PR c++/89648
+// { dg-do compile { target c++11 } }
+
+template <typename T, T U> struct A { static const T e = U; };
+template <typename> struct B;
+template <unsigned long, typename> struct C;
+template <long i, typename T> using E = typename C<i, T>::k;
+template <typename T, T...> struct F {};
+template <typename T, T U> using G = F<T, __integer_pack(U)...>;
+template <unsigned long... U> using H = F<unsigned long, U...>;
+template <unsigned long U> using I = G<unsigned long, U>;
+template <typename...> class J {};
+template <typename... U> struct B<J<U...>> : A<long, sizeof...(U)> {};
+template <unsigned long N, typename T, typename... U>
+struct C<N, J<T, U...>> : C<N - 1, J<U...>> {};
+template <typename T, typename... U> struct C<0, J<T, U...>> { typedef T k; };
+template <unsigned long N, typename... U> E<N, J<U...>> qux (J<U...>);
+struct D { template <typename T> void foo (T) {} };
+void bar (...);
+struct K { void baz (int &); int l; D m; int *n, o; };
+template <typename T, typename U, typename V, unsigned long... W>
+void quux (int, int *, D x, int *, int, int, T, U, V y, H<W...>) {
+ x.foo ([=] { bar (qux <W>(y)...); });
+}
+void K::baz (int &x) {
+ J<int, int> p;
+ int q, r;
+ long s;
+ quux (x, &l, m, n, o, r, s, q, p, I<B<decltype(p)>::e> ());
+}