[][src]Struct uuid::adapter::Hyphenated

pub struct Hyphenated(_);

An adaptor for formatting an Uuid as a hyphenated string.

Takes an owned instance of the Uuid.

Implementations

impl Hyphenated[src]

pub const LENGTH: usize[src]

The length of a hyphenated Uuid string.

pub const fn from_uuid(uuid: Uuid) -> Self[src]

Creates a Hyphenated from a Uuid.

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

Writes the Uuid as a lower-case hyphenated 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_hyphenated()
            .encode_lower(&mut Uuid::encode_buffer()),
        "936da01f-9abd-4d9d-80c7-02af85c822a8"
    );

    // the buffer is mutated directly, and trailing contents remains
    let mut buf = [b'!'; 40];
    uuid.to_hyphenated().encode_lower(&mut buf);
    assert_eq!(
        &buf as &[_],
        b"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 hyphenated 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_hyphenated()
            .encode_upper(&mut Uuid::encode_buffer()),
        "936DA01F-9ABD-4D9D-80C7-02AF85C822A8"
    );

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

    Ok(())
}

*/

Trait Implementations

impl Clone for Hyphenated[src]

impl Copy for Hyphenated[src]

impl Debug for Hyphenated[src]

impl Default for Hyphenated[src]

impl Display for Hyphenated[src]

impl Eq for Hyphenated[src]

impl From<Uuid> for Hyphenated[src]

impl Hash for Hyphenated[src]

impl LowerHex for Hyphenated[src]

impl Ord for Hyphenated[src]

impl PartialEq<Hyphenated> for Hyphenated[src]

impl PartialOrd<Hyphenated> for Hyphenated[src]

impl StructuralEq for Hyphenated[src]

impl StructuralPartialEq for Hyphenated[src]

impl UpperHex for Hyphenated[src]

Auto Trait Implementations

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.