summaryrefslogtreecommitdiffstats
path: root/tests/ui/closures/closure-return-type-must-be-sized.rs
blob: 8cfa0291229bd7f4c0d70b2bca4a243be7547ef1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#![feature(unboxed_closures)]

trait A {
    fn a() where Self: Sized;
}

mod a {
    use crate::A;

    pub fn foo<F: FnOnce<()>>() where F::Output: A {
        F::Output::a()
    }

    pub fn bar<F: FnOnce() -> R, R: ?Sized>() {}

    pub fn baz<F: FnOnce<()>>() where F::Output: A, F::Output: Sized {
        F::Output::a()
    }
}

mod b {
    use crate::A;

    pub fn foo<F: Fn<()>>() where F::Output: A {
        F::Output::a()
    }

    pub fn bar<F: Fn() -> R, R: ?Sized>() {}

    pub fn baz<F: Fn<()>>() where F::Output: A, F::Output: Sized {
        F::Output::a()
    }
}

mod c {
    use crate::A;

    pub fn foo<F: FnMut<()>>() where F::Output: A {
        F::Output::a()
    }

    pub fn bar<F: FnMut() -> R, R: ?Sized>() {}

    pub fn baz<F: FnMut<()>>() where F::Output: A, F::Output: Sized {
        F::Output::a()
    }
}

impl A for Box<dyn A> {
    fn a() {}
}

fn main() {
    a::foo::<fn() -> dyn A>();         //~ ERROR E0277
    a::bar::<fn() -> dyn A, _>();      //~ ERROR E0277
    a::baz::<fn() -> dyn A>();         //~ ERROR E0277
    a::foo::<fn() -> Box<dyn A>>();    //  ok
    a::bar::<fn() -> Box<dyn A>, _>(); //  ok
    a::baz::<fn() -> Box<dyn A>>();    //  ok

    b::foo::<fn() -> dyn A>();         //~ ERROR E0277
    b::bar::<fn() -> dyn A, _>();      //~ ERROR E0277
    b::baz::<fn() -> dyn A>();         //~ ERROR E0277
    b::foo::<fn() -> Box<dyn A>>();    //  ok
    b::bar::<fn() -> Box<dyn A>, _>(); //  ok
    b::baz::<fn() -> Box<dyn A>>();    //  ok

    c::foo::<fn() -> dyn A>();         //~ ERROR E0277
    c::bar::<fn() -> dyn A, _>();      //~ ERROR E0277
    c::baz::<fn() -> dyn A>();         //~ ERROR E0277
    c::foo::<fn() -> Box<dyn A>>();    //  ok
    c::bar::<fn() -> Box<dyn A>, _>(); //  ok
    c::baz::<fn() -> Box<dyn A>>();    //  ok
}