blob: ac8fd9d8fb0937c841491f15e995af378c3b25e3 (
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
|
// aux-build:macro_rules.rs
#![warn(clippy::mut_mut)]
#![allow(unused)]
#![allow(clippy::no_effect, clippy::uninlined_format_args, clippy::unnecessary_operation)]
#[macro_use]
extern crate macro_rules;
fn fun(x: &mut &mut u32) -> bool {
**x > 0
}
fn less_fun(x: *mut *mut u32) {
let y = x;
}
macro_rules! mut_ptr {
($p:expr) => {
&mut $p
};
}
#[allow(unused_mut, unused_variables)]
fn main() {
let mut x = &mut &mut 1u32;
{
let mut y = &mut x;
}
if fun(x) {
let y: &mut &mut u32 = &mut &mut 2;
**y + **x;
}
if fun(x) {
let y: &mut &mut &mut u32 = &mut &mut &mut 2;
***y + **x;
}
let mut z = mut_ptr!(&mut 3u32);
}
fn issue939() {
let array = [5, 6, 7, 8, 9];
let mut args = array.iter().skip(2);
for &arg in &mut args {
println!("{}", arg);
}
let args = &mut args;
for arg in args {
println!(":{}", arg);
}
}
fn issue6922() {
// do not lint from an external macro
mut_mut!();
}
|