2018-07-28 17:34:52 +02:00
|
|
|
#![warn(clippy::clone_on_ref_ptr)]
|
2017-10-09 23:07:12 -05:00
|
|
|
#![allow(unused)]
|
|
|
|
|
2018-10-19 00:03:56 -04:00
|
|
|
use std::cell::RefCell;
|
2017-10-09 23:07:12 -05:00
|
|
|
use std::collections::HashSet;
|
|
|
|
use std::collections::VecDeque;
|
|
|
|
use std::rc::{self, Rc};
|
|
|
|
use std::sync::{self, Arc};
|
|
|
|
|
2018-01-14 19:58:09 -08:00
|
|
|
trait SomeTrait {}
|
|
|
|
struct SomeImpl;
|
|
|
|
impl SomeTrait for SomeImpl {}
|
|
|
|
|
2017-10-09 23:07:12 -05:00
|
|
|
fn main() {}
|
|
|
|
|
|
|
|
fn clone_on_copy() {
|
|
|
|
42.clone();
|
|
|
|
|
|
|
|
vec![1].clone(); // ok, not a Copy type
|
|
|
|
Some(vec![1]).clone(); // ok, not a Copy type
|
|
|
|
(&42).clone();
|
2018-10-19 00:03:56 -04:00
|
|
|
|
|
|
|
let rc = RefCell::new(0);
|
|
|
|
rc.borrow().clone();
|
2019-08-19 08:17:53 +02:00
|
|
|
|
|
|
|
// Issue #4348
|
|
|
|
let mut x = 43;
|
|
|
|
let _ = &x.clone(); // ok, getting a ref
|
|
|
|
'a'.clone().make_ascii_uppercase(); // ok, clone and then mutate
|
2017-10-09 23:07:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn clone_on_ref_ptr() {
|
|
|
|
let rc = Rc::new(true);
|
|
|
|
let arc = Arc::new(true);
|
|
|
|
|
|
|
|
let rcweak = Rc::downgrade(&rc);
|
|
|
|
let arc_weak = Arc::downgrade(&arc);
|
|
|
|
|
|
|
|
rc.clone();
|
|
|
|
Rc::clone(&rc);
|
|
|
|
|
|
|
|
arc.clone();
|
|
|
|
Arc::clone(&arc);
|
|
|
|
|
|
|
|
rcweak.clone();
|
|
|
|
rc::Weak::clone(&rcweak);
|
|
|
|
|
|
|
|
arc_weak.clone();
|
|
|
|
sync::Weak::clone(&arc_weak);
|
|
|
|
|
2018-01-14 19:58:09 -08:00
|
|
|
let x = Arc::new(SomeImpl);
|
2019-05-30 08:23:47 +02:00
|
|
|
let _: Arc<dyn SomeTrait> = x.clone();
|
2017-10-09 23:07:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn clone_on_copy_generic<T: Copy>(t: T) {
|
|
|
|
t.clone();
|
|
|
|
|
|
|
|
Some(t).clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn clone_on_double_ref() {
|
|
|
|
let x = vec![1];
|
|
|
|
let y = &&x;
|
|
|
|
let z: &Vec<_> = y.clone();
|
|
|
|
|
2018-12-09 23:26:16 +01:00
|
|
|
println!("{:p} {:p}", *y, z);
|
2017-10-09 23:07:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn iter_clone_collect() {
|
2018-12-09 23:26:16 +01:00
|
|
|
let v = [1, 2, 3, 4, 5];
|
|
|
|
let v2: Vec<isize> = v.iter().cloned().collect();
|
|
|
|
let v3: HashSet<isize> = v.iter().cloned().collect();
|
|
|
|
let v4: VecDeque<isize> = v.iter().cloned().collect();
|
2019-02-18 07:30:50 +02:00
|
|
|
|
|
|
|
// Handle macro expansion in suggestion
|
2019-02-19 06:39:22 +02:00
|
|
|
let _: Vec<isize> = vec![1, 2, 3].iter().cloned().collect();
|
2019-02-18 07:30:50 +02:00
|
|
|
|
|
|
|
// Issue #3704
|
|
|
|
unsafe {
|
|
|
|
let _: Vec<u8> = std::ffi::CStr::from_ptr(std::ptr::null())
|
|
|
|
.to_bytes()
|
|
|
|
.iter()
|
|
|
|
.cloned()
|
|
|
|
.collect();
|
|
|
|
}
|
2017-10-09 23:07:12 -05:00
|
|
|
}
|
2018-10-19 14:51:25 -04:00
|
|
|
|
|
|
|
mod many_derefs {
|
|
|
|
struct A;
|
|
|
|
struct B;
|
|
|
|
struct C;
|
|
|
|
struct D;
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
struct E;
|
|
|
|
|
|
|
|
macro_rules! impl_deref {
|
|
|
|
($src:ident, $dst:ident) => {
|
|
|
|
impl std::ops::Deref for $src {
|
|
|
|
type Target = $dst;
|
2018-12-09 23:26:16 +01:00
|
|
|
fn deref(&self) -> &Self::Target {
|
|
|
|
&$dst
|
|
|
|
}
|
2018-10-19 14:51:25 -04:00
|
|
|
}
|
2018-12-09 23:26:16 +01:00
|
|
|
};
|
2018-10-19 14:51:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
impl_deref!(A, B);
|
|
|
|
impl_deref!(B, C);
|
|
|
|
impl_deref!(C, D);
|
|
|
|
impl std::ops::Deref for D {
|
|
|
|
type Target = &'static E;
|
2018-12-09 23:26:16 +01:00
|
|
|
fn deref(&self) -> &Self::Target {
|
|
|
|
&&E
|
|
|
|
}
|
2018-10-19 14:51:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
fn go1() {
|
|
|
|
let a = A;
|
|
|
|
let _: E = a.clone();
|
|
|
|
let _: E = *****a;
|
|
|
|
}
|
|
|
|
}
|