Struct hash40::label_map::LabelMap

source ·
pub struct LabelMap {
    pub map: BiHashMap<Hash40, String>,
    pub strict: bool,
}

Fields§

§map: BiHashMap<Hash40, String>

A bidirectional map to associate hashes and their labels

§strict: bool

Controls whether the default hash40 method is used instead of returning None when you try to find the hash of a label which is not present in the map.

By default, set to false

Implementations§

source§

impl LabelMap

source

pub fn clear(&mut self)

Convenience method to clear the labels within the map

source

pub fn add_labels<I: IntoIterator<Item = String>>(&mut self, labels: I)

Inserts labels into the map, using the default hash40 method for the hash

source

pub fn add_custom_labels<I: Iterator<Item = (Hash40, String)>>( &mut self, labels: I )

Inserts labels into the map, providing both the hash and the associated label.

Users can insert a label for a hash, even if the hash of the label inserted doesn’t match the paired hash. This allows custom descriptive labels when the true label is not known for the hash.

source

pub fn read_labels<P: AsRef<Path>>(path: P) -> Result<Vec<String>, Error>

Opens a file and returns a list of newline-separated labels

source

pub fn read_custom_labels<P: AsRef<Path>>( path: P ) -> Result<Vec<(Hash40, String)>, CustomLabelError>

Opens a file and returns a list of line-separated pairs of hashes and labels. Each hash-label pair is separated by a comma, and the hash must be formatted in hexadecimal, beginning with “0x”

source

pub fn add_labels_from_path<P: AsRef<Path>>( &mut self, path: P ) -> Result<(), Error>

A combination of the two functions Self::add_labels and Self::read_labels

source

pub fn add_custom_labels_from_path<P: AsRef<Path>>( &mut self, path: P ) -> Result<(), CustomLabelError>

A combination of the two functions Self::add_custom_labels and Self::read_custom_labels

source

pub fn label_of(&self, hash: Hash40) -> Option<String>

source

pub fn hash_of(&self, label: &str) -> Option<Hash40>

Trait Implementations§

source§

impl Clone for LabelMap

source§

fn clone(&self) -> LabelMap

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for LabelMap

source§

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

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

impl Default for LabelMap

source§

fn default() -> LabelMap

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere 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 Twhere 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.