2019-03-07 00:21:41 -06:00
|
|
|
// run-rustfix
|
|
|
|
|
|
|
|
// The output for humans should just highlight the whole span without showing
|
|
|
|
// the suggested replacement, but we also want to test that suggested
|
|
|
|
// replacement only removes one set of parentheses, rather than naïvely
|
|
|
|
// stripping away any starting or ending parenthesis characters—hence this
|
|
|
|
// test of the JSON error format.
|
|
|
|
|
|
|
|
#![feature(custom_inner_attributes)]
|
|
|
|
#![rustfmt::skip]
|
|
|
|
|
|
|
|
#![deny(clippy::unused_unit)]
|
2019-08-24 14:42:39 -05:00
|
|
|
#![allow(dead_code)]
|
2019-03-07 00:21:41 -06:00
|
|
|
|
|
|
|
struct Unitter;
|
|
|
|
impl Unitter {
|
|
|
|
// try to disorient the lint with multiple unit returns and newlines
|
|
|
|
#[allow(clippy::no_effect)]
|
|
|
|
pub fn get_unit<F: Fn() -> (), G>(&self, f: F, _g: G)
|
|
|
|
where G: Fn() -> () {
|
2019-05-30 01:23:47 -05:00
|
|
|
let _y: &dyn Fn() -> () = &f;
|
2019-03-07 00:21:41 -06:00
|
|
|
(); // this should not lint, as it's not in return type position
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Into<()> for Unitter {
|
|
|
|
#[rustfmt::skip]
|
|
|
|
fn into(self) {
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn return_unit() { }
|
|
|
|
|
|
|
|
#[allow(clippy::needless_return)]
|
|
|
|
#[allow(clippy::never_loop)]
|
2019-10-02 15:48:19 -05:00
|
|
|
#[allow(clippy::unit_cmp)]
|
2019-03-07 00:21:41 -06:00
|
|
|
fn main() {
|
|
|
|
let u = Unitter;
|
|
|
|
assert_eq!(u.get_unit(|| {}, return_unit), u.into());
|
|
|
|
return_unit();
|
|
|
|
loop {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
2019-08-24 14:42:39 -05:00
|
|
|
|
|
|
|
// https://github.com/rust-lang/rust-clippy/issues/4076
|
|
|
|
fn foo() {
|
|
|
|
macro_rules! foo {
|
|
|
|
(recv($r:expr) -> $res:pat => $body:expr) => {
|
|
|
|
$body
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
foo! {
|
|
|
|
recv(rx) -> _x => ()
|
|
|
|
}
|
|
|
|
}
|