rust/tests/ui/toplevel_ref_arg.fixed

41 lines
848 B
Rust
Raw Normal View History

//@run-rustfix
2023-04-20 15:19:36 +00:00
//@aux-build:proc_macros.rs:proc-macro
#![warn(clippy::toplevel_ref_arg)]
2023-06-06 22:56:57 +02:00
#![allow(clippy::uninlined_format_args, unused, clippy::useless_vec)]
extern crate proc_macros;
use proc_macros::{external, inline_macros};
#[inline_macros]
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-26 01:53:39 +00:00
let _y: &(&_, u8) = &(&1, 2);
2019-09-26 01:53:39 +00:00
let _z = &(1 + 2);
2019-09-26 01:53:39 +00:00
let _z = &mut (1 + 2);
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];
// 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;
// ok
for ref _x in 0..10 {}
// lint in macro
inline!(let _y = &42;);
// do not lint in external macro
external!(let ref _y = 42;);
}