blob: 641066b002273cc2f15a1cbc266112500e97f146 [file] [log] [blame]
//@ edition:2021
//@ check-pass
#![allow(unreachable_code)]
#![warn(unused)]
#![allow(dead_code)]
#[derive(Debug)]
struct Point {
x: i32,
y: i32,
}
pub fn f() {
let mut a = 1;
let mut c = Point { x: 1, y: 0 };
// Captured by value, but variable is dead on entry.
(move || {
c.x = 1; //~ WARN value captured by `c.x` is never read
println!("{}", c.x);
a = 1; //~ WARN value captured by `a` is never read
println!("{}", a);
})();
// Read and written to, but never actually used.
(move || {
c.x += 1; //~ WARN value captured by `c.x` is never read
//~| WARN value assigned to `c.x` is never read
a += 1; //~ WARN value captured by `a` is never read
//~| WARN value assigned to `a` is never read
})();
(move || {
println!("{}", c.x);
// Value is read by closure itself on later invocations.
// This will not trigger a warning for unused variable as
// c.x will be treated as a Non-tracked place
c.x += 1;
println!("{}", a);
a += 1;
})();
let b = Box::new(42);
(move || {
println!("{}", c.x);
c.x += 1; //~ WARN value assigned to `c.x` is never read
println!("{}", a);
a += 1; //~ WARN value assigned to `a` is never read
drop(b);
})();
}
#[derive(Debug)]
struct MyStruct<'a> {
x: Option<&'a str>,
y: i32,
}
pub fn nested() {
let mut a: Option<&str>;
a = None;
let mut b: Option<&str>;
b = None;
let mut d = MyStruct { x: None, y: 1 };
let mut e = MyStruct { x: None, y: 1 };
(|| {
(|| {
d.x = Some("d1"); //~ WARN value assigned to `d.x` is never read
d.x = Some("d2");
a = Some("d1"); //~ WARN value assigned to `a` is never read
a = Some("d2");
})();
(move || {
e.x = Some("e1"); //~ WARN value captured by `e.x` is never read
//~| WARN value assigned to `e.x` is never read
e.x = Some("e2"); //~ WARN value assigned to `e.x` is never read
b = Some("e1"); //~ WARN value captured by `b` is never read
//~| WARN value assigned to `b` is never read
b = Some("e2"); //~ WARN value assigned to `b` is never read
})();
})();
}
fn main() {}