ToOwned

Trait ToOwned 

1.0.0
pub trait ToOwned {
    type Owned: Borrow<Self>;

    // Required method
    fn to_owned(&self) -> Self::Owned;

    // Provided method
    fn clone_into(&self, target: &mut Self::Owned) { ... }
}
Expand description

A generalization of Clone to borrowed data.

Some types make it possible to go from borrowed to owned, usually by implementing the Clone trait. But Clone works only for going from &T to T. The ToOwned trait generalizes Clone to construct owned data from any borrow of a given type.

Required Associated Types§

1.0.0

type Owned: Borrow<Self>

The resulting type after obtaining ownership.

Required Methods§

1.0.0

fn to_owned(&self) -> Self::Owned

Creates owned data from borrowed data, usually by cloning.

§Examples

Basic usage:

let s: &str = "a";
let ss: String = s.to_owned();

let v: &[i32] = &[1, 2];
let vv: Vec<i32> = v.to_owned();

Provided Methods§

1.63.0

fn clone_into(&self, target: &mut Self::Owned)

Uses borrowed data to replace owned data, usually by cloning.

This is borrow-generalized version of Clone::clone_from.

§Examples

Basic usage:

let mut s: String = String::new();
"hello".clone_into(&mut s);

let mut v: Vec<i32> = Vec::new();
[1, 2][..].clone_into(&mut v);

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

1.0.0§

impl ToOwned for str

§

impl ToOwned for ByteStr

1.3.0§

impl ToOwned for CStr

1.0.0 · Source§

impl ToOwned for OsStr

1.0.0 · Source§

impl ToOwned for Path

1.0.0§

impl<T> ToOwned for [T]
where T: Clone,

§

type Owned = Vec<T>

1.0.0§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T