// Copyright 2014-2018 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. #![warn(clippy::clone_on_ref_ptr)] #![allow(unused)] use std::cell::RefCell; use std::collections::HashSet; use std::collections::VecDeque; use std::rc::{self, Rc}; use std::sync::{self, Arc}; trait SomeTrait {} struct SomeImpl; impl SomeTrait for SomeImpl {} 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(); let rc = RefCell::new(0); rc.borrow().clone(); } 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); let x = Arc::new(SomeImpl); let _: Arc = x.clone(); } fn clone_on_copy_generic(t: T) { t.clone(); Some(t).clone(); } fn clone_on_double_ref() { let x = vec![1]; let y = &&x; let z: &Vec<_> = y.clone(); println!("{:p} {:p}", *y, z); } fn iter_clone_collect() { let v = [1, 2, 3, 4, 5]; let v2: Vec = v.iter().cloned().collect(); let v3: HashSet = v.iter().cloned().collect(); let v4: VecDeque = v.iter().cloned().collect(); } 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; fn deref(&self) -> &Self::Target { &$dst } } }; } impl_deref!(A, B); impl_deref!(B, C); impl_deref!(C, D); impl std::ops::Deref for D { type Target = &'static E; fn deref(&self) -> &Self::Target { &&E } } fn go1() { let a = A; let _: E = a.clone(); let _: E = *****a; } }