[][src]Struct uuid::adapter::UrnRef

pub struct UrnRef<'a>(_);

An adaptor for formatting an Uuid as a URN string.

Takes a reference of the Uuid.

Methods

impl<'a> UrnRef<'a>[src]

pub const LENGTH: usize[src]

The length of a URN Uuid string.

pub const fn from_uuid_ref(uuid: &'a Uuid) -> Self[src]

Creates a UrnRef from a Uuid reference.

pub fn encode_lower<'buf>(&self, buffer: &'buf mut [u8]) -> &'buf mut str[src]

Writes the Uuid as a lower-case URN string to buffer, and returns the subslice of the buffer that contains the encoded UUID.

This is slightly more efficient than using the formatting infrastructure as it avoids virtual calls, and may avoid double buffering.

Panics

Panics if the buffer is not large enough: it must have length at least LENGTH. Uuid::encode_buffer can be used to get a sufficiently-large temporary buffer.

Examples

use uuid::Uuid;

let uuid = Uuid::parse_str("936DA01f9abd4d9d80c702af85c822a8").unwrap();

// the encoded portion is returned
assert_eq!(
    uuid.to_urn().encode_lower(&mut Uuid::encode_buffer()),
    "urn:uuid:936da01f-9abd-4d9d-80c7-02af85c822a8"
);

// the buffer is mutated directly, and trailing contents remains
let mut buf = [b'!'; 49];
uuid.to_urn().encode_lower(&mut buf);
assert_eq!(
    uuid.to_urn().encode_lower(&mut buf),
    "urn:uuid:936da01f-9abd-4d9d-80c7-02af85c822a8"
);
assert_eq!(
    &buf as &[_],
    b"urn:uuid:936da01f-9abd-4d9d-80c7-02af85c822a8!!!!" as &[_]
);

*/

pub fn encode_upper<'buf>(&self, buffer: &'buf mut [u8]) -> &'buf mut str[src]

Writes the Uuid as an upper-case URN string to buffer, and returns the subslice of the buffer that contains the encoded UUID.

This is slightly more efficient than using the formatting infrastructure as it avoids virtual calls, and may avoid double buffering.

Panics

Panics if the buffer is not large enough: it must have length at least LENGTH. Uuid::encode_buffer can be used to get a sufficiently-large temporary buffer.

Examples

use uuid::Uuid;

let uuid = Uuid::parse_str("936da01f9abd4d9d80c702af85c822a8").unwrap();

// the encoded portion is returned
assert_eq!(
    uuid.to_urn().encode_upper(&mut Uuid::encode_buffer()),
    "urn:uuid:936DA01F-9ABD-4D9D-80C7-02AF85C822A8"
);

// the buffer is mutated directly, and trailing contents remains
let mut buf = [b'!'; 49];
assert_eq!(
    uuid.to_urn().encode_upper(&mut buf),
    "urn:uuid:936DA01F-9ABD-4D9D-80C7-02AF85C822A8"
);
assert_eq!(
    &buf as &[_],
    b"urn:uuid:936DA01F-9ABD-4D9D-80C7-02AF85C822A8!!!!" as &[_]
);

*/

Trait Implementations

impl<'a> From<&'a Uuid> for UrnRef<'a>[src]

impl<'a> PartialEq<UrnRef<'a>> for UrnRef<'a>[src]

impl<'a> Eq for UrnRef<'a>[src]

impl<'a> Ord for UrnRef<'a>[src]

impl<'a> PartialOrd<UrnRef<'a>> for UrnRef<'a>[src]

impl<'a> Hash for UrnRef<'a>[src]

impl<'a> Display for UrnRef<'a>[src]

impl<'a> Debug for UrnRef<'a>[src]

impl<'a> LowerHex for UrnRef<'a>[src]

impl<'a> UpperHex for UrnRef<'a>[src]

impl<'a> Copy for UrnRef<'a>[src]

impl<'a> Clone for UrnRef<'a>[src]

Auto Trait Implementations

impl<'a> Unpin for UrnRef<'a>

impl<'a> Send for UrnRef<'a>

impl<'a> Sync for UrnRef<'a>

impl<'a> UnwindSafe for UrnRef<'a>

impl<'a> RefUnwindSafe for UrnRef<'a>

Blanket Implementations

impl<T> From<T> for T[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> ToString for T where
    T: Display + ?Sized
[src]

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

type Owned = T

The resulting type after obtaining ownership.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 
[src]