blob: e487799e1522099e1fe2c529b2008ae9a63c54bb (
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
|
#![allow(unused)]
#![warn(clippy::ref_option_ref)]
// This lint is not tagged as run-rustfix because automatically
// changing the type of a variable would also means changing
// all usages of this variable to match and This is not handled
// by this lint.
static THRESHOLD: i32 = 10;
static REF_THRESHOLD: &Option<&i32> = &Some(&THRESHOLD);
const CONST_THRESHOLD: &i32 = &10;
const REF_CONST: &Option<&i32> = &Some(CONST_THRESHOLD);
type RefOptRefU32<'a> = &'a Option<&'a u32>;
type RefOptRef<'a, T> = &'a Option<&'a T>;
fn foo(data: &Option<&u32>) {}
fn bar(data: &u32) -> &Option<&u32> {
&None
}
struct StructRef<'a> {
data: &'a Option<&'a u32>,
}
struct StructTupleRef<'a>(u32, &'a Option<&'a u32>);
enum EnumRef<'a> {
Variant1(u32),
Variant2(&'a Option<&'a u32>),
}
trait RefOptTrait {
type A;
fn foo(&self, _: Self::A);
}
impl RefOptTrait for u32 {
type A = &'static Option<&'static Self>;
fn foo(&self, _: Self::A) {}
}
fn main() {
let x: &Option<&u32> = &None;
}
fn issue9682(arg: &Option<&mut String>) {
// Should not lint, as the inner ref is mutable making it non `Copy`
println!("{arg:?}");
}
|