2015-05-18 02:02:24 -05:00
|
|
|
#![feature(plugin)]
|
|
|
|
#![plugin(clippy)]
|
|
|
|
|
2016-05-13 09:43:47 -05:00
|
|
|
#![allow(unused, no_effect, unnecessary_operation)]
|
2016-06-21 15:54:22 -05:00
|
|
|
#![deny(mut_mut)]
|
2015-09-07 15:58:15 -05:00
|
|
|
|
2015-05-25 18:45:15 -05:00
|
|
|
//#![plugin(regex_macros)]
|
|
|
|
//extern crate regex;
|
|
|
|
|
2015-08-13 01:12:07 -05:00
|
|
|
fn fun(x : &mut &mut u32) -> bool { //~ERROR generally you want to avoid `&mut &mut
|
2015-08-11 13:22:20 -05:00
|
|
|
**x > 0
|
2015-05-18 02:02:24 -05:00
|
|
|
}
|
|
|
|
|
2015-09-07 15:58:15 -05:00
|
|
|
fn less_fun(x : *mut *mut u32) {
|
|
|
|
let y = x;
|
|
|
|
}
|
|
|
|
|
2015-05-25 18:45:15 -05:00
|
|
|
macro_rules! mut_ptr {
|
2015-08-11 13:22:20 -05:00
|
|
|
($p:expr) => { &mut $p }
|
2016-05-20 12:18:32 -05:00
|
|
|
//~^ ERROR generally you want to avoid `&mut &mut
|
2015-08-11 13:22:20 -05:00
|
|
|
}
|
2015-05-25 18:45:15 -05:00
|
|
|
|
2015-05-18 03:41:15 -05:00
|
|
|
#[allow(unused_mut, unused_variables)]
|
2015-05-18 02:02:24 -05:00
|
|
|
fn main() {
|
2015-08-13 01:12:07 -05:00
|
|
|
let mut x = &mut &mut 1u32; //~ERROR generally you want to avoid `&mut &mut
|
2015-08-11 13:22:20 -05:00
|
|
|
{
|
2015-08-13 01:12:07 -05:00
|
|
|
let mut y = &mut x; //~ERROR this expression mutably borrows a mutable reference
|
2015-08-11 13:22:20 -05:00
|
|
|
}
|
|
|
|
|
2016-06-21 15:54:22 -05:00
|
|
|
if fun(x) {
|
|
|
|
let y : &mut &mut u32 = &mut &mut 2;
|
|
|
|
//~^ ERROR generally you want to avoid `&mut &mut
|
|
|
|
//~| ERROR generally you want to avoid `&mut &mut
|
|
|
|
//~| ERROR generally you want to avoid `&mut &mut
|
|
|
|
**y + **x;
|
|
|
|
}
|
|
|
|
|
2015-08-11 13:22:20 -05:00
|
|
|
if fun(x) {
|
|
|
|
let y : &mut &mut &mut u32 = &mut &mut &mut 2;
|
2016-05-20 12:18:32 -05:00
|
|
|
//~^ ERROR generally you want to avoid `&mut &mut
|
|
|
|
//~| ERROR generally you want to avoid `&mut &mut
|
|
|
|
//~| ERROR generally you want to avoid `&mut &mut
|
|
|
|
//~| ERROR generally you want to avoid `&mut &mut
|
2016-06-21 15:54:22 -05:00
|
|
|
//~| ERROR generally you want to avoid `&mut &mut
|
|
|
|
//~| ERROR generally you want to avoid `&mut &mut
|
2015-08-11 13:22:20 -05:00
|
|
|
***y + **x;
|
|
|
|
}
|
|
|
|
|
2016-06-05 11:07:12 -05:00
|
|
|
let mut z = mut_ptr!(&mut 3u32);
|
|
|
|
//~^ NOTE in this expansion of mut_ptr!
|
2015-05-18 02:02:24 -05:00
|
|
|
}
|
2016-06-21 15:54:22 -05:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|