Struct unc_fmt::StorageKey

source ·
pub struct StorageKey<'a>(pub &'a [u8]);
Expand description

A wrapper for bytes slice which tries to guess best way to format it.

If the slice is exactly 32-byte long, it’s assumed to be a hash and is converted into base58 and printed surrounded by backtics. Otherwise, behaves like Bytes representing the data as string if it contains ASCII printable bytes only or base64 otherwise.

The motivation for such choices is that we only ever use base58 to format hashes which are 32-byte long. It’s therefore not useful to use it for any other types of keys.

The intended usage for this type is when trying to format binary data whose structure isn’t known to the caller. For example, when generating debugging or tracing data at database layer where everything is just slices of bytes. At higher levels of abstractions, if the structure of the data is known, it’s usually better to format data in a way that makes sense for the given type.

The type can be used as with tracing::info! and similar calls. For example:

tracing::info!(target: "store",
               op = "set",
               col = %col,
               key = %unc_fmt::StorageKey(key),
               size = value.len())

Tuple Fields§

§0: &'a [u8]

Trait Implementations§

source§

impl<'a> Debug for StorageKey<'a>

source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'a> Display for StorageKey<'a>

source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for StorageKey<'a>

§

impl<'a> RefUnwindSafe for StorageKey<'a>

§

impl<'a> Send for StorageKey<'a>

§

impl<'a> Sync for StorageKey<'a>

§

impl<'a> Unpin for StorageKey<'a>

§

impl<'a> UnwindSafe for StorageKey<'a>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.