-#![feature(plugin)]
-#![plugin(clippy)]
+// run-rustfix
+
+#![allow(clippy::needless_borrowed_reference)]
fn x(y: &i32) -> i32 {
*y
}
-#[deny(clippy)]
+#[warn(clippy::all, clippy::needless_borrow)]
#[allow(unused_variables)]
fn main() {
let a = 5;
let vec_val = g(&vec); // should not error, because `&Vec<T>` derefs to `&[T]`
h(&"foo"); // should not error, because the `&&str` is required, due to `&Trait`
if let Some(ref cake) = Some(&5) {}
+ let garbl = match 42 {
+ 44 => &a,
+ 45 => {
+ println!("foo");
+ &&a // FIXME: this should lint, too
+ },
+ 46 => &&a,
+ _ => panic!(),
+ };
}
-fn f<T:Copy>(y: &T) -> T {
+fn f<T: Copy>(y: &T) -> T {
*y
}
impl<'a> Trait for &'a str {}
-fn h(_: &Trait) {}
-
+fn h(_: &dyn Trait) {}
+#[warn(clippy::needless_borrow)]
#[allow(dead_code)]
fn issue_1432() {
let mut v = Vec::<String>::new();
let _ = v.iter().filter(|&a| a.is_empty());
}
+
+#[allow(dead_code)]
+#[warn(clippy::needless_borrow)]
+#[derive(Debug)]
+enum Foo<'a> {
+ Str(&'a str),
+}