[][src]Crate mown

This crate provides two simple wrappers Mown and MownMut for values that can be either owned or borrowed. The type Mown is an simple enum type with two constructors:

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

pub enum Mown<'a, T: ToOwned> {
	Owned(T::Owned),
	Borrowed(&'a T)
}

The mutable version MownMut follows the same definition with a mutable reference. This is very similar to the standard Cow type, except that it is not possible to transform a borrowed value into an owned one. This is also slightly different from the similar crate boow since the ToOwned trait allow for the use of Mown with unsized types (for instance Mown<str>) and with mutable references.

Basic Usage

One basic use case for the Mown type is the situation where one wants to reuse some input borrowed value under some condition, or then use a custom owned value.

use mown::Mown;

fn function(input_value: &String) -> Mown<String> {
	if condition {
		Mown::Borrowed(input_value)
	} else {
		let custom_value: String = "foo_".to_string() + input_value + "_bar";
		Mown::Owned(custom_value)
	}
}

One can also wrap unsized types for which the provided ToOwned trait has been implemented. This is the case for the unsized str type with the sized owned type String.

use mown::Mown;

fn function(input_value: &str) -> Mown<str> {
	if condition {
		Mown::Borrowed(input_value)
	} else {
		let custom_value: String = "foo_".to_string() + input_value + "_bar";
		Mown::Owned(custom_value)
	}
}

Enums

Mown

Container for borrowed or owned value.

MownMut

Container for mutabily borrowed or owned values.

Traits

ToOwned

Types that can be owned.