2019-09-23 11:19:24 +02:00
|
|
|
// run-rustfix
|
2020-10-24 10:50:11 +02:00
|
|
|
// aux-build:macro_rules.rs
|
2019-09-23 11:19:24 +02:00
|
|
|
#![warn(clippy::toplevel_ref_arg)]
|
2022-10-02 15:13:22 -04:00
|
|
|
#![allow(clippy::uninlined_format_args)]
|
2019-09-23 11:19:24 +02:00
|
|
|
|
2020-10-24 10:50:11 +02:00
|
|
|
#[macro_use]
|
|
|
|
extern crate macro_rules;
|
|
|
|
|
|
|
|
macro_rules! gen_binding {
|
|
|
|
() => {
|
|
|
|
let _y = &42;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-09-23 11:19:24 +02:00
|
|
|
fn main() {
|
|
|
|
// Closures should not warn
|
|
|
|
let y = |ref x| println!("{:?}", x);
|
|
|
|
y(1u8);
|
|
|
|
|
2019-09-26 01:53:39 +00:00
|
|
|
let _x = &1;
|
2019-09-23 11:19:24 +02:00
|
|
|
|
2019-09-26 01:53:39 +00:00
|
|
|
let _y: &(&_, u8) = &(&1, 2);
|
2019-09-23 11:19:24 +02:00
|
|
|
|
2019-09-26 01:53:39 +00:00
|
|
|
let _z = &(1 + 2);
|
2019-09-23 11:19:24 +02:00
|
|
|
|
2019-09-26 01:53:39 +00:00
|
|
|
let _z = &mut (1 + 2);
|
2019-09-23 11:19:24 +02:00
|
|
|
|
|
|
|
let (ref x, _) = (1, 2); // ok, not top level
|
|
|
|
println!("The answer is {}.", x);
|
|
|
|
|
2019-09-26 01:53:39 +00:00
|
|
|
let _x = &vec![1, 2, 3];
|
2019-09-26 08:46:51 +07:00
|
|
|
|
2019-09-23 11:19:24 +02:00
|
|
|
// Make sure that allowing the lint works
|
|
|
|
#[allow(clippy::toplevel_ref_arg)]
|
2019-09-26 01:53:39 +00:00
|
|
|
let ref mut _x = 1_234_543;
|
2020-04-19 22:56:47 +09:00
|
|
|
|
|
|
|
// ok
|
|
|
|
for ref _x in 0..10 {}
|
2020-10-24 10:50:11 +02:00
|
|
|
|
|
|
|
// lint in macro
|
|
|
|
#[allow(unused)]
|
|
|
|
{
|
|
|
|
gen_binding!();
|
|
|
|
}
|
|
|
|
|
|
|
|
// do not lint in external macro
|
|
|
|
{
|
|
|
|
ref_arg_binding!();
|
|
|
|
}
|
2019-09-23 11:19:24 +02:00
|
|
|
}
|