File: generics-and-bounds.rs

package info (click to toggle)
rustc-web 1.78.0%2Bdfsg1-2~deb12u3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 1,245,420 kB
  • sloc: xml: 147,985; javascript: 18,022; sh: 11,083; python: 10,265; ansic: 6,172; cpp: 5,023; asm: 4,390; makefile: 4,269
file content (88 lines) | stat: -rw-r--r-- 1,919 bytes parent folder | download | duplicates (7)
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
//@ build-pass (FIXME(62277): could be check-pass?)
//@ edition:2018
//@ compile-flags: --crate-type lib

use std::future::Future;

pub async fn simple_generic<T>() {}

pub trait Foo {
    fn foo(&self) {}
}

struct FooType;
impl Foo for FooType {}

pub async fn call_generic_bound<F: Foo>(f: F) {
    f.foo()
}

pub async fn call_where_clause<F>(f: F)
where
    F: Foo,
{
    f.foo()
}

pub async fn call_impl_trait(f: impl Foo) {
    f.foo()
}

pub async fn call_with_ref(f: &impl Foo) {
    f.foo()
}

pub fn async_fn_with_same_generic_params_unifies() {
    let mut a = call_generic_bound(FooType);
    a = call_generic_bound(FooType);

    let mut b = call_where_clause(FooType);
    b = call_where_clause(FooType);

    let mut c = call_impl_trait(FooType);
    c = call_impl_trait(FooType);

    let f_one = FooType;
    let f_two = FooType;
    let mut d = call_with_ref(&f_one);
    d = call_with_ref(&f_two);
}

pub fn simple_generic_block<T>() -> impl Future<Output = ()> {
    async move {}
}

pub fn call_generic_bound_block<F: Foo>(f: F) -> impl Future<Output = ()> {
    async move { f.foo() }
}

pub fn call_where_clause_block<F>(f: F) -> impl Future<Output = ()>
where
    F: Foo,
{
    async move { f.foo() }
}

pub fn call_impl_trait_block(f: impl Foo) -> impl Future<Output = ()> {
    async move { f.foo() }
}

pub fn call_with_ref_block<'a>(f: &'a (impl Foo + 'a)) -> impl Future<Output = ()> + 'a {
    async move { f.foo() }
}

pub fn async_block_with_same_generic_params_unifies() {
    let mut a = call_generic_bound_block(FooType);
    a = call_generic_bound_block(FooType);

    let mut b = call_where_clause_block(FooType);
    b = call_where_clause_block(FooType);

    let mut c = call_impl_trait_block(FooType);
    c = call_impl_trait_block(FooType);

    let f_one = FooType;
    let f_two = FooType;
    let mut d = call_with_ref_block(&f_one);
    d = call_with_ref_block(&f_two);
}