2023-04-20 09:37:15 -05:00
|
|
|
//@run-rustfix
|
2022-05-29 20:49:46 -05:00
|
|
|
|
|
|
|
#![allow(dead_code, unused_variables)]
|
|
|
|
|
2022-05-28 20:57:15 -05:00
|
|
|
fn main() {}
|
|
|
|
|
|
|
|
mod should_lint {
|
2022-06-01 10:32:26 -05:00
|
|
|
fn one_help() {
|
2022-05-28 20:57:15 -05:00
|
|
|
let a = &12;
|
|
|
|
let b = &*a;
|
|
|
|
|
|
|
|
let b = &mut &*bar(&12);
|
|
|
|
}
|
|
|
|
|
|
|
|
fn bar(x: &u32) -> &u32 {
|
|
|
|
x
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// this mod explains why we should not lint `&mut &* (&T)`
|
|
|
|
mod should_not_lint1 {
|
|
|
|
fn foo(x: &mut &u32) {
|
|
|
|
*x = &1;
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut x = &0;
|
|
|
|
foo(&mut &*x); // should not lint
|
|
|
|
assert_eq!(*x, 0);
|
|
|
|
|
|
|
|
foo(&mut x);
|
|
|
|
assert_eq!(*x, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// similar to should_not_lint1
|
|
|
|
mod should_not_lint2 {
|
|
|
|
struct S<'a> {
|
|
|
|
a: &'a u32,
|
|
|
|
b: u32,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let s = S { a: &1, b: 1 };
|
|
|
|
let x = &mut &*s.a;
|
|
|
|
*x = &2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// this mod explains why we should not lint `& &* (&T)`
|
|
|
|
mod false_negative {
|
|
|
|
fn foo() {
|
|
|
|
let x = &12;
|
|
|
|
let addr_x = &x as *const _ as usize;
|
|
|
|
let addr_y = &&*x as *const _ as usize; // assert ok
|
|
|
|
// let addr_y = &x as *const _ as usize; // assert fail
|
|
|
|
assert_ne!(addr_x, addr_y);
|
|
|
|
}
|
|
|
|
}
|