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