summary refs log tree commit diff
path: root/src/tools/clippy/tests/ui/needless_borrow.fixed
blob: efeb5cf5b2b25aedb3ad0cb7a06edc97c84ad29b (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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
// run-rustfix

#[warn(clippy::all, clippy::needless_borrow)]
#[allow(unused_variables, clippy::unnecessary_mut_passed)]
fn main() {
    let a = 5;
    let ref_a = &a;
    let _ = x(&a); // no warning
    let _ = x(&a); // warn

    let mut b = 5;
    mut_ref(&mut b); // no warning
    mut_ref(&mut b); // warn

    let s = &String::from("hi");
    let s_ident = f(&s); // should not error, because `&String` implements Copy, but `String` does not
    let g_val = g(&Vec::new()); // should not error, because `&Vec<T>` derefs to `&[T]`
    let vec = Vec::new();
    let vec_val = g(&vec); // should not error, because `&Vec<T>` derefs to `&[T]`
    h(&"foo"); // should not error, because the `&&str` is required, due to `&Trait`
    let garbl = match 42 {
        44 => &a,
        45 => {
            println!("foo");
            &a
        },
        46 => &a,
        47 => {
            println!("foo");
            loop {
                println!("{}", a);
                if a == 25 {
                    break ref_a;
                }
            }
        },
        _ => panic!(),
    };

    let _ = x(&a);
    let _ = x(&a);
    let _ = x(&mut b);
    let _ = x(ref_a);
    {
        let b = &mut b;
        x(b);
    }

    // Issue #8191
    let mut x = 5;
    let mut x = &mut x;

    mut_ref(x);
    mut_ref(x);
    let y: &mut i32 = x;
    let y: &mut i32 = x;

    let y = match 0 {
        // Don't lint. Removing the borrow would move 'x'
        0 => &mut x,
        _ => &mut *x,
    };

    *x = 5;

    let s = String::new();
    // let _ = (&s).len();
    // let _ = (&s).capacity();
    // let _ = (&&s).capacity();

    let x = (1, 2);
    let _ = x.0;
    let x = &x as *const (i32, i32);
    let _ = unsafe { (*x).0 };
}

#[allow(clippy::needless_borrowed_reference)]
fn x(y: &i32) -> i32 {
    *y
}

fn mut_ref(y: &mut i32) {
    *y = 5;
}

fn f<T: Copy>(y: &T) -> T {
    *y
}

fn g(y: &[u8]) -> u8 {
    y[0]
}

trait Trait {}

impl<'a> Trait for &'a str {}

fn h(_: &dyn Trait) {}