2023-07-27 11:40:22 +00:00
|
|
|
//@no-rustfix: overlapping suggestions
|
2022-06-10 18:28:31 +02:00
|
|
|
#![warn(clippy::suspicious_to_owned)]
|
|
|
|
#![warn(clippy::implicit_clone)]
|
|
|
|
#![allow(clippy::redundant_clone)]
|
|
|
|
use std::borrow::Cow;
|
2022-08-29 12:07:59 +00:00
|
|
|
use std::ffi::{c_char, CStr};
|
2022-06-10 18:28:31 +02:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let moo = "Moooo";
|
|
|
|
let c_moo = b"Moooo\0";
|
2022-08-29 12:07:59 +00:00
|
|
|
let c_moo_ptr = c_moo.as_ptr() as *const c_char;
|
2022-06-10 18:28:31 +02:00
|
|
|
let moos = ['M', 'o', 'o'];
|
|
|
|
let moos_vec = moos.to_vec();
|
|
|
|
|
|
|
|
// we expect this to be linted
|
|
|
|
let cow = Cow::Borrowed(moo);
|
|
|
|
let _ = cow.to_owned();
|
2023-07-28 21:35:48 +02:00
|
|
|
//~^ ERROR: this `to_owned` call clones the Cow<'_, str> itself and does not cause the
|
|
|
|
//~| NOTE: `-D clippy::suspicious-to-owned` implied by `-D warnings`
|
2022-06-10 18:28:31 +02:00
|
|
|
// we expect no lints for this
|
|
|
|
let cow = Cow::Borrowed(moo);
|
|
|
|
let _ = cow.into_owned();
|
|
|
|
// we expect no lints for this
|
|
|
|
let cow = Cow::Borrowed(moo);
|
|
|
|
let _ = cow.clone();
|
|
|
|
|
|
|
|
// we expect this to be linted
|
|
|
|
let cow = Cow::Borrowed(&moos);
|
|
|
|
let _ = cow.to_owned();
|
2023-07-28 21:35:48 +02:00
|
|
|
//~^ ERROR: this `to_owned` call clones the Cow<'_, [char; 3]> itself and does not cau
|
2022-06-10 18:28:31 +02:00
|
|
|
// we expect no lints for this
|
|
|
|
let cow = Cow::Borrowed(&moos);
|
|
|
|
let _ = cow.into_owned();
|
|
|
|
// we expect no lints for this
|
|
|
|
let cow = Cow::Borrowed(&moos);
|
|
|
|
let _ = cow.clone();
|
|
|
|
|
|
|
|
// we expect this to be linted
|
|
|
|
let cow = Cow::Borrowed(&moos_vec);
|
|
|
|
let _ = cow.to_owned();
|
2023-07-28 21:35:48 +02:00
|
|
|
//~^ ERROR: this `to_owned` call clones the Cow<'_, Vec<char>> itself and does not cau
|
2022-06-10 18:28:31 +02:00
|
|
|
// we expect no lints for this
|
|
|
|
let cow = Cow::Borrowed(&moos_vec);
|
|
|
|
let _ = cow.into_owned();
|
|
|
|
// we expect no lints for this
|
|
|
|
let cow = Cow::Borrowed(&moos_vec);
|
|
|
|
let _ = cow.clone();
|
|
|
|
|
|
|
|
// we expect this to be linted
|
|
|
|
let cow = unsafe { CStr::from_ptr(c_moo_ptr) }.to_string_lossy();
|
|
|
|
let _ = cow.to_owned();
|
2023-07-28 21:35:48 +02:00
|
|
|
//~^ ERROR: this `to_owned` call clones the Cow<'_, str> itself and does not cause the
|
2022-06-10 18:28:31 +02:00
|
|
|
// we expect no lints for this
|
|
|
|
let cow = unsafe { CStr::from_ptr(c_moo_ptr) }.to_string_lossy();
|
|
|
|
let _ = cow.into_owned();
|
|
|
|
// we expect no lints for this
|
|
|
|
let cow = unsafe { CStr::from_ptr(c_moo_ptr) }.to_string_lossy();
|
|
|
|
let _ = cow.clone();
|
|
|
|
|
|
|
|
// we expect no lints for these
|
|
|
|
let _ = moo.to_owned();
|
|
|
|
let _ = c_moo.to_owned();
|
|
|
|
let _ = moos.to_owned();
|
|
|
|
|
|
|
|
// we expect implicit_clone lints for these
|
|
|
|
let _ = String::from(moo).to_owned();
|
2023-07-28 21:35:48 +02:00
|
|
|
//~^ ERROR: implicitly cloning a `String` by calling `to_owned` on its dereferenced ty
|
|
|
|
//~| NOTE: `-D clippy::implicit-clone` implied by `-D warnings`
|
2022-06-10 18:28:31 +02:00
|
|
|
let _ = moos_vec.to_owned();
|
2023-07-28 21:35:48 +02:00
|
|
|
//~^ ERROR: implicitly cloning a `Vec` by calling `to_owned` on its dereferenced type
|
2022-06-10 18:28:31 +02:00
|
|
|
}
|