rust/src/test/ui/lint/lint-unused-mut-variables.rs

199 lines
4.4 KiB
Rust
Raw Normal View History

2019-07-26 17:52:37 -05:00
// edition:2018
// Exercise the unused_mut attribute in some positive and negative cases
#![deny(unused_mut)]
2019-08-29 18:44:30 -05:00
#![feature(async_closure)]
2019-07-26 17:52:37 -05:00
async fn baz_async(
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
) {}
fn baz(
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
#[allow(unused_mut)] (mut c, d): (i32, i32)
) {}
2019-07-26 17:52:37 -05:00
struct RefStruct {}
impl RefStruct {
async fn baz_async(
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
) {}
fn baz(
&self,
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
#[allow(unused_mut)] (mut c, d): (i32, i32)
) {}
}
trait RefTrait {
fn baz(
&self,
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
#[allow(unused_mut)] (mut c, d): (i32, i32)
) {}
}
impl RefTrait for () {
fn baz(
&self,
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
#[allow(unused_mut)] (mut c, d): (i32, i32)
) {}
}
fn main() {
2019-07-26 17:52:37 -05:00
let _ = async move |
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
| {};
let _ = |
mut a: i32,
//~^ ERROR: variable does not need to be mutable
#[allow(unused_mut)] mut b: i32,
#[allow(unused_mut)] (mut c, d): (i32, i32)
| {};
// negative cases
let mut a = 3; //~ ERROR: variable does not need to be mutable
let mut a = 2; //~ ERROR: variable does not need to be mutable
let mut b = 3; //~ ERROR: variable does not need to be mutable
let mut a = vec![3]; //~ ERROR: variable does not need to be mutable
let (mut a, b) = (1, 2); //~ ERROR: variable does not need to be mutable
let mut a; //~ ERROR: variable does not need to be mutable
a = 3;
let mut b; //~ ERROR: variable does not need to be mutable
if true {
b = 3;
} else {
b = 4;
}
2013-10-22 22:51:45 -05:00
2015-01-31 10:23:42 -06:00
match 30 {
mut x => {} //~ ERROR: variable does not need to be mutable
2013-10-22 22:51:45 -05:00
}
2015-01-31 10:23:42 -06:00
match (30, 2) {
(mut x, 1) | //~ ERROR: variable does not need to be mutable
(mut x, 2) |
(mut x, 3) => {
}
_ => {}
}
2013-10-22 22:51:45 -05:00
let x = |mut y: isize| 10; //~ ERROR: variable does not need to be mutable
fn what(mut foo: isize) {} //~ ERROR: variable does not need to be mutable
let mut a = &mut 5; //~ ERROR: variable does not need to be mutable
2017-08-01 16:06:26 -05:00
*a = 4;
let mut a = 5;
let mut b = (&mut a,); //~ ERROR: variable does not need to be mutable
*b.0 = 4;
let mut x = &mut 1; //~ ERROR: variable does not need to be mutable
2017-08-01 16:06:26 -05:00
2017-08-06 12:25:31 -05:00
let mut f = || {
*x += 1;
};
f();
2017-08-01 16:06:26 -05:00
fn mut_ref_arg(mut arg : &mut [u8]) -> &mut [u8] {
&mut arg[..] //~^ ERROR: variable does not need to be mutable
2017-08-01 16:06:26 -05:00
}
let mut v : &mut Vec<()> = &mut vec![]; //~ ERROR: variable does not need to be mutable
2017-08-01 16:06:26 -05:00
v.push(());
// positive cases
2015-01-31 10:23:42 -06:00
let mut a = 2;
a = 3;
let mut a = Vec::new();
2015-01-31 10:23:42 -06:00
a.push(3);
let mut a = Vec::new();
callback(|| {
2015-01-31 10:23:42 -06:00
a.push(3);
});
let mut a = Vec::new();
callback(|| {
callback(|| {
a.push(3);
});
});
2015-01-31 10:23:42 -06:00
let (mut a, b) = (1, 2);
2013-10-22 22:51:45 -05:00
a = 34;
2015-01-31 10:23:42 -06:00
match 30 {
2013-10-22 22:51:45 -05:00
mut x => {
2015-01-31 10:23:42 -06:00
x = 21;
2013-10-22 22:51:45 -05:00
}
}
2015-01-31 10:23:42 -06:00
match (30, 2) {
(mut x, 1) |
(mut x, 2) |
(mut x, 3) => {
x = 21
}
_ => {}
}
// Attribute should be respected on match arms
match 0 {
#[allow(unused_mut)]
mut x => {
let mut y = 1;
},
}
let x = |mut y: isize| y = 32;
2015-01-31 10:23:42 -06:00
fn nothing(mut foo: isize) { foo = 37; }
// leading underscore should avoid the warning, just like the
// unused variable lint.
2015-01-31 10:23:42 -06:00
let mut _allowed = 1;
}
2015-01-03 09:45:00 -06:00
fn callback<F>(f: F) where F: FnOnce() {}
// make sure the lint attribute can be turned off
#[allow(unused_mut)]
fn foo(mut a: isize) {
2015-01-31 10:23:42 -06:00
let mut a = 3;
let mut b = vec![2];
}
// make sure the lint attribute can be turned off on let statements
#[deny(unused_mut)]
fn bar() {
#[allow(unused_mut)]
let mut a = 3;
let mut b = vec![2]; //~ ERROR: variable does not need to be mutable
}