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