2022-06-25 07:16:28 -05:00
|
|
|
#![feature(lint_reasons)]
|
2023-06-24 03:03:05 -05:00
|
|
|
#![allow(
|
|
|
|
unused,
|
|
|
|
clippy::many_single_char_names,
|
|
|
|
clippy::needless_lifetimes,
|
2023-06-15 10:24:39 -05:00
|
|
|
clippy::redundant_clone,
|
|
|
|
clippy::needless_pass_by_ref_mut
|
2023-06-24 03:03:05 -05:00
|
|
|
)]
|
2018-07-28 10:34:52 -05:00
|
|
|
#![warn(clippy::ptr_arg)]
|
2015-05-04 01:15:24 -05:00
|
|
|
|
2018-04-05 10:59:35 -05:00
|
|
|
use std::borrow::Cow;
|
2022-10-14 12:21:59 -05:00
|
|
|
use std::path::{Path, PathBuf};
|
2018-04-05 10:59:35 -05:00
|
|
|
|
2017-02-08 07:58:07 -06:00
|
|
|
fn do_vec(x: &Vec<i64>) {
|
2015-08-11 13:22:20 -05:00
|
|
|
//Nothing here
|
2015-05-04 01:15:24 -05:00
|
|
|
}
|
|
|
|
|
2018-12-09 16:26:16 -06:00
|
|
|
fn do_vec_mut(x: &mut Vec<i64>) {
|
2015-08-21 11:28:17 -05:00
|
|
|
//Nothing here
|
|
|
|
}
|
|
|
|
|
2017-02-08 07:58:07 -06:00
|
|
|
fn do_str(x: &String) {
|
2015-08-11 13:22:20 -05:00
|
|
|
//Nothing here either
|
2015-05-04 01:15:24 -05:00
|
|
|
}
|
|
|
|
|
2018-12-09 16:26:16 -06:00
|
|
|
fn do_str_mut(x: &mut String) {
|
2015-08-21 11:28:17 -05:00
|
|
|
//Nothing here either
|
|
|
|
}
|
|
|
|
|
2020-12-25 05:45:04 -06:00
|
|
|
fn do_path(x: &PathBuf) {
|
|
|
|
//Nothing here either
|
|
|
|
}
|
|
|
|
|
|
|
|
fn do_path_mut(x: &mut PathBuf) {
|
|
|
|
//Nothing here either
|
|
|
|
}
|
|
|
|
|
2018-12-09 16:26:16 -06:00
|
|
|
fn main() {}
|
2015-10-30 18:48:05 -05:00
|
|
|
|
|
|
|
trait Foo {
|
|
|
|
type Item;
|
2017-02-08 07:58:07 -06:00
|
|
|
fn do_vec(x: &Vec<i64>);
|
2015-10-30 18:48:05 -05:00
|
|
|
fn do_item(x: &Self::Item);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Bar;
|
|
|
|
|
|
|
|
// no error, in trait impl (#425)
|
|
|
|
impl Foo for Bar {
|
|
|
|
type Item = Vec<u8>;
|
|
|
|
fn do_vec(x: &Vec<i64>) {}
|
2017-09-16 02:10:26 -05:00
|
|
|
fn do_item(x: &Vec<u8>) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn cloned(x: &Vec<u8>) -> Vec<u8> {
|
|
|
|
let e = x.clone();
|
|
|
|
let f = e.clone(); // OK
|
|
|
|
let g = x;
|
2022-01-09 08:35:55 -06:00
|
|
|
let h = g.clone();
|
2017-09-16 02:10:26 -05:00
|
|
|
let i = (e).clone();
|
|
|
|
x.clone()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn str_cloned(x: &String) -> String {
|
|
|
|
let a = x.clone();
|
|
|
|
let b = x.clone();
|
|
|
|
let c = b.clone();
|
2018-12-09 16:26:16 -06:00
|
|
|
let d = a.clone().clone().clone();
|
2017-09-16 02:10:26 -05:00
|
|
|
x.clone()
|
2015-10-30 18:48:05 -05:00
|
|
|
}
|
2017-09-20 16:59:23 -05:00
|
|
|
|
2020-12-25 05:45:04 -06:00
|
|
|
fn path_cloned(x: &PathBuf) -> PathBuf {
|
|
|
|
let a = x.clone();
|
|
|
|
let b = x.clone();
|
|
|
|
let c = b.clone();
|
|
|
|
let d = a.clone().clone().clone();
|
|
|
|
x.clone()
|
|
|
|
}
|
|
|
|
|
2017-09-20 16:59:23 -05:00
|
|
|
fn false_positive_capacity(x: &Vec<u8>, y: &String) {
|
|
|
|
let a = x.capacity();
|
|
|
|
let b = y.clone();
|
|
|
|
let c = y.as_str();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn false_positive_capacity_too(x: &String) -> String {
|
2018-12-09 16:26:16 -06:00
|
|
|
if x.capacity() > 1024 {
|
|
|
|
panic!("Too large!");
|
|
|
|
}
|
2017-09-20 16:59:23 -05:00
|
|
|
x.clone()
|
|
|
|
}
|
|
|
|
|
2018-04-05 10:59:35 -05:00
|
|
|
#[allow(dead_code)]
|
2018-12-09 16:26:16 -06:00
|
|
|
fn test_cow_with_ref(c: &Cow<[i32]>) {}
|
2018-04-05 10:59:35 -05:00
|
|
|
|
|
|
|
fn test_cow(c: Cow<[i32]>) {
|
|
|
|
let _c = c;
|
|
|
|
}
|
2018-09-05 07:59:07 -05:00
|
|
|
|
|
|
|
trait Foo2 {
|
|
|
|
fn do_string(&self);
|
|
|
|
}
|
|
|
|
|
|
|
|
// no error for &self references where self is of type String (#2293)
|
2018-12-09 16:26:16 -06:00
|
|
|
impl Foo2 for String {
|
|
|
|
fn do_string(&self) {}
|
|
|
|
}
|
2020-05-25 16:09:06 -05:00
|
|
|
|
|
|
|
// Check that the allow attribute on parameters is honored
|
|
|
|
mod issue_5644 {
|
|
|
|
use std::borrow::Cow;
|
2020-12-25 05:45:04 -06:00
|
|
|
use std::path::PathBuf;
|
2020-05-25 16:09:06 -05:00
|
|
|
|
|
|
|
fn allowed(
|
|
|
|
#[allow(clippy::ptr_arg)] _v: &Vec<u32>,
|
|
|
|
#[allow(clippy::ptr_arg)] _s: &String,
|
2020-12-25 05:45:04 -06:00
|
|
|
#[allow(clippy::ptr_arg)] _p: &PathBuf,
|
2020-05-25 16:09:06 -05:00
|
|
|
#[allow(clippy::ptr_arg)] _c: &Cow<[i32]>,
|
2022-06-25 07:16:28 -05:00
|
|
|
#[expect(clippy::ptr_arg)] _expect: &Cow<[i32]>,
|
2020-05-25 16:09:06 -05:00
|
|
|
) {
|
|
|
|
}
|
|
|
|
|
2022-06-25 07:16:28 -05:00
|
|
|
fn some_allowed(#[allow(clippy::ptr_arg)] _v: &Vec<u32>, _s: &String) {}
|
|
|
|
|
2022-03-27 07:41:09 -05:00
|
|
|
struct S;
|
2020-05-25 16:09:06 -05:00
|
|
|
impl S {
|
|
|
|
fn allowed(
|
|
|
|
#[allow(clippy::ptr_arg)] _v: &Vec<u32>,
|
|
|
|
#[allow(clippy::ptr_arg)] _s: &String,
|
2020-12-25 05:45:04 -06:00
|
|
|
#[allow(clippy::ptr_arg)] _p: &PathBuf,
|
2020-05-25 16:09:06 -05:00
|
|
|
#[allow(clippy::ptr_arg)] _c: &Cow<[i32]>,
|
2022-06-25 07:16:28 -05:00
|
|
|
#[expect(clippy::ptr_arg)] _expect: &Cow<[i32]>,
|
2020-05-25 16:09:06 -05:00
|
|
|
) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
trait T {
|
|
|
|
fn allowed(
|
|
|
|
#[allow(clippy::ptr_arg)] _v: &Vec<u32>,
|
|
|
|
#[allow(clippy::ptr_arg)] _s: &String,
|
2020-12-25 05:45:04 -06:00
|
|
|
#[allow(clippy::ptr_arg)] _p: &PathBuf,
|
2020-05-25 16:09:06 -05:00
|
|
|
#[allow(clippy::ptr_arg)] _c: &Cow<[i32]>,
|
2022-06-25 07:16:28 -05:00
|
|
|
#[expect(clippy::ptr_arg)] _expect: &Cow<[i32]>,
|
2020-05-25 16:09:06 -05:00
|
|
|
) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-12-27 16:09:04 -06:00
|
|
|
|
|
|
|
mod issue6509 {
|
|
|
|
use std::path::PathBuf;
|
|
|
|
|
|
|
|
fn foo_vec(vec: &Vec<u8>) {
|
|
|
|
let _ = vec.clone().pop();
|
|
|
|
let _ = vec.clone().clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn foo_path(path: &PathBuf) {
|
|
|
|
let _ = path.clone().pop();
|
|
|
|
let _ = path.clone().clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn foo_str(str: &PathBuf) {
|
|
|
|
let _ = str.clone().pop();
|
|
|
|
let _ = str.clone().clone();
|
|
|
|
}
|
|
|
|
}
|
2021-10-27 10:24:00 -05:00
|
|
|
|
2022-01-09 08:35:55 -06:00
|
|
|
fn mut_vec_slice_methods(v: &mut Vec<u32>) {
|
|
|
|
v.copy_within(1..5, 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
fn mut_vec_vec_methods(v: &mut Vec<u32>) {
|
|
|
|
v.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn vec_contains(v: &Vec<u32>) -> bool {
|
|
|
|
[vec![], vec![0]].as_slice().contains(v)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fn_requires_vec(v: &Vec<u32>) -> bool {
|
|
|
|
vec_contains(v)
|
|
|
|
}
|
|
|
|
|
2022-01-21 08:43:41 -06:00
|
|
|
fn impl_fn_requires_vec(v: &Vec<u32>, f: impl Fn(&Vec<u32>)) {
|
|
|
|
f(v);
|
|
|
|
}
|
2022-01-09 08:35:55 -06:00
|
|
|
|
2022-01-21 08:43:41 -06:00
|
|
|
fn dyn_fn_requires_vec(v: &Vec<u32>, f: &dyn Fn(&Vec<u32>)) {
|
|
|
|
f(v);
|
|
|
|
}
|
2022-01-09 08:35:55 -06:00
|
|
|
|
2021-10-27 10:24:00 -05:00
|
|
|
// No error for types behind an alias (#7699)
|
|
|
|
type A = Vec<u8>;
|
|
|
|
fn aliased(a: &A) {}
|
2022-01-29 08:45:47 -06:00
|
|
|
|
|
|
|
// Issue #8366
|
|
|
|
pub trait Trait {
|
|
|
|
fn f(v: &mut Vec<i32>);
|
|
|
|
fn f2(v: &mut Vec<i32>) {}
|
|
|
|
}
|
2022-02-23 00:04:49 -06:00
|
|
|
|
|
|
|
// Issue #8463
|
|
|
|
fn two_vecs(a: &mut Vec<u32>, b: &mut Vec<u32>) {
|
|
|
|
a.push(0);
|
|
|
|
a.push(0);
|
|
|
|
a.push(0);
|
|
|
|
b.push(1);
|
|
|
|
}
|
2022-03-16 11:00:27 -05:00
|
|
|
|
|
|
|
// Issue #8495
|
|
|
|
fn cow_conditional_to_mut(a: &mut Cow<str>) {
|
|
|
|
if a.is_empty() {
|
|
|
|
a.to_mut().push_str("foo");
|
|
|
|
}
|
|
|
|
}
|
2022-10-14 12:21:59 -05:00
|
|
|
|
|
|
|
// Issue #9542
|
|
|
|
fn dyn_trait_ok(a: &mut Vec<u32>, b: &mut String, c: &mut PathBuf) {
|
|
|
|
trait T {}
|
|
|
|
impl<U> T for Vec<U> {}
|
|
|
|
impl T for String {}
|
|
|
|
impl T for PathBuf {}
|
|
|
|
fn takes_dyn(_: &mut dyn T) {}
|
|
|
|
|
|
|
|
takes_dyn(a);
|
|
|
|
takes_dyn(b);
|
|
|
|
takes_dyn(c);
|
|
|
|
}
|
|
|
|
|
|
|
|
fn dyn_trait(a: &mut Vec<u32>, b: &mut String, c: &mut PathBuf) {
|
|
|
|
trait T {}
|
|
|
|
impl<U> T for Vec<U> {}
|
|
|
|
impl<U> T for [U] {}
|
|
|
|
impl T for String {}
|
|
|
|
impl T for str {}
|
|
|
|
impl T for PathBuf {}
|
|
|
|
impl T for Path {}
|
|
|
|
fn takes_dyn(_: &mut dyn T) {}
|
|
|
|
|
|
|
|
takes_dyn(a);
|
|
|
|
takes_dyn(b);
|
|
|
|
takes_dyn(c);
|
|
|
|
}
|
2023-06-24 03:03:05 -05:00
|
|
|
|
|
|
|
mod issue_9218 {
|
|
|
|
use std::borrow::Cow;
|
|
|
|
|
|
|
|
fn cow_non_elided_lifetime<'a>(input: &Cow<'a, str>) -> &'a str {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
|
|
|
|
// This one has an anonymous lifetime so it's not okay
|
|
|
|
fn cow_elided_lifetime<'a>(input: &'a Cow<str>) -> &'a str {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
|
|
|
|
// These two's return types don't use use 'a so it's not okay
|
|
|
|
fn cow_bad_ret_ty_1<'a>(input: &'a Cow<'a, str>) -> &'static str {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
fn cow_bad_ret_ty_2<'a, 'b>(input: &'a Cow<'a, str>) -> &'b str {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Inferred to be `&'a str`, afaik.
|
|
|
|
fn cow_good_ret_ty<'a>(input: &'a Cow<'a, str>) -> &str {
|
|
|
|
todo!()
|
|
|
|
}
|
|
|
|
}
|