[][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.

Implementations

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;

fn main() -> Result<(), uuid::Error> {
    let uuid = Uuid::parse_str("936DA01f9abd4d9d80c702af85c822a8")?;

    // 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 &[_]
    );

    Ok(())
}

*/

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;

fn main() -> Result<(), uuid::Error> {
    let uuid = Uuid::parse_str("936da01f9abd4d9d80c702af85c822a8")?;

    // 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 &[_]
    );

    Ok(())
}

*/

Trait Implementations

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Auto Trait Implementations

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

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

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

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

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

Blanket Implementations

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

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

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

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

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

impl<T> SendSyncUnwindSafe for T where
    T: Send + Sync + UnwindSafe + ?Sized
[src]

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

type Owned = T

The resulting type after obtaining ownership.

impl<T> ToString for T where
    T: Display + ?Sized
[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> 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.