2019-09-23 04:19:24 -05:00
|
|
|
// run-rustfix
|
2020-11-05 07:29:48 -06:00
|
|
|
// aux-build:macro_rules.rs
|
2014-12-24 19:48:03 -06:00
|
|
|
|
2019-09-23 04:19:24 -05:00
|
|
|
#![warn(clippy::toplevel_ref_arg)]
|
2014-12-24 19:48:03 -06:00
|
|
|
|
2020-11-05 07:29:48 -06:00
|
|
|
#[macro_use]
|
|
|
|
extern crate macro_rules;
|
|
|
|
|
|
|
|
macro_rules! gen_binding {
|
|
|
|
() => {
|
|
|
|
let ref _y = 42;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2014-12-24 19:48:03 -06:00
|
|
|
fn main() {
|
2018-12-09 16:26:16 -06:00
|
|
|
// Closures should not warn
|
|
|
|
let y = |ref x| println!("{:?}", x);
|
|
|
|
y(1u8);
|
2015-09-22 02:08:42 -05:00
|
|
|
|
2019-09-25 20:53:39 -05:00
|
|
|
let ref _x = 1;
|
2017-02-08 07:58:07 -06:00
|
|
|
|
2019-09-25 20:53:39 -05:00
|
|
|
let ref _y: (&_, u8) = (&1, 2);
|
2017-02-08 07:58:07 -06:00
|
|
|
|
2019-09-25 20:53:39 -05:00
|
|
|
let ref _z = 1 + 2;
|
2017-02-08 07:58:07 -06:00
|
|
|
|
2019-09-25 20:53:39 -05:00
|
|
|
let ref mut _z = 1 + 2;
|
2017-02-08 07:58:07 -06:00
|
|
|
|
2019-01-30 19:15:29 -06:00
|
|
|
let (ref x, _) = (1, 2); // ok, not top level
|
2018-12-09 16:26:16 -06:00
|
|
|
println!("The answer is {}.", x);
|
2019-04-19 08:18:32 -05:00
|
|
|
|
2019-09-25 20:53:39 -05:00
|
|
|
let ref _x = vec![1, 2, 3];
|
2019-09-24 23:06:52 -05:00
|
|
|
|
2019-04-19 08:18:32 -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!();
|
|
|
|
}
|
2014-12-24 19:48:03 -06:00
|
|
|
}
|