annotate gcc/testsuite/g++.dg/cpp1y/lambda-generic-x.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // Explicit generic lambda test from N3690 5.1.2.5
kono
parents:
diff changeset
2 // { dg-do compile { target c++14 } }
kono
parents:
diff changeset
3 // { dg-options "-Wpedantic" }
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #include <iostream>
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 int main()
kono
parents:
diff changeset
8 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
9 auto glambda = [] <typename A, typename B> (A a, B&& b) { return a < b; }; // { dg-warning "lambda templates are only available with" "" { target c++17_down } }
111
kono
parents:
diff changeset
10 bool b = glambda(3, 3.14); // OK
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
11 auto vglambda = [] <typename P> (P printer) { // { dg-warning "lambda templates are only available with" "" { target c++17_down } }
111
kono
parents:
diff changeset
12 return [=] <typename... T> (T&& ... ts) { // OK: ts is a function parameter pack
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
13 printer(std::forward<decltype(ts)>(ts)...); // { dg-warning "lambda templates are only available with" "" { target c++17_down } .-1 }
111
kono
parents:
diff changeset
14 return [=]() {
kono
parents:
diff changeset
15 printer(ts ...);
kono
parents:
diff changeset
16 };
kono
parents:
diff changeset
17 };
kono
parents:
diff changeset
18 };
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
19 auto p = vglambda( [] <typename A, // { dg-warning "lambda templates are only available with" "" { target c++17_down } }
111
kono
parents:
diff changeset
20 typename B,
kono
parents:
diff changeset
21 typename C> (A v1, B v2, C v3)
kono
parents:
diff changeset
22 { std::cout << v1 << v2 << v3; } );
kono
parents:
diff changeset
23 auto q = p(1, 'a', 3.14); // OK: outputs 1a3.14
kono
parents:
diff changeset
24 q(); // OK: outputs 1a3.14
kono
parents:
diff changeset
25 }
kono
parents:
diff changeset
26