summaryrefslogtreecommitdiffstats
path: root/tests/ui/issues/issue-59494.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
commit218caa410aa38c29984be31a5229b9fa717560ee (patch)
treec54bd55eeb6e4c508940a30e94c0032fbd45d677 /tests/ui/issues/issue-59494.rs
parentReleasing progress-linux version 1.67.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-218caa410aa38c29984be31a5229b9fa717560ee.tar.xz
rustc-218caa410aa38c29984be31a5229b9fa717560ee.zip
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/issues/issue-59494.rs')
-rw-r--r--tests/ui/issues/issue-59494.rs23
1 files changed, 23 insertions, 0 deletions
diff --git a/tests/ui/issues/issue-59494.rs b/tests/ui/issues/issue-59494.rs
new file mode 100644
index 000000000..a53e28f72
--- /dev/null
+++ b/tests/ui/issues/issue-59494.rs
@@ -0,0 +1,23 @@
+fn t7p<A, B, C>(f: impl Fn(B) -> C, g: impl Fn(A) -> B) -> impl Fn(A) -> C {
+ move |a: A| -> C { f(g(a)) }
+}
+
+fn t8n<A, B, C>(f: impl Fn(A) -> B, g: impl Fn(A) -> C) -> impl Fn(A) -> (B, C)
+where
+ A: Copy,
+{
+ move |a: A| -> (B, C) {
+ let b = a;
+ let fa = f(a);
+ let ga = g(b);
+ (fa, ga)
+ }
+}
+
+fn main() {
+ let f = |(_, _)| {};
+ let g = |(a, _)| a;
+ let t7 = |env| |a| |b| t7p(f, g)(((env, a), b));
+ let t8 = t8n(t7, t7p(f, g));
+ //~^ ERROR: expected a `Fn<(_,)>` closure, found `impl Fn(((_, _), _))` [E0277]
+}