Struct hdpath::CustomHDPath

source ·
pub struct CustomHDPath(pub Vec<PathValue>);
Expand description

A custom HD Path, that can be any length and contain any Hardened and non-Hardened values in any order. Direct implementation for BIP-32

If you need just standard type of HD Path like m/44'/0'/0'/0/0 use StandardHDPath instead.

Usage

Parse string

use hdpath::CustomHDPath;

let hdpath = CustomHDPath::try_from("m/1'/2'/3/4/5'/6'/7").unwrap();
let hdpath = CustomHDPath::try_from("m/44'/0'/1'/0/0").unwrap();
//also support uppercase notation
let hdpath = CustomHDPath::try_from("M/44H/0H/1H/0/0").unwrap();

Direct create

use hdpath::{CustomHDPath, PathValue};

let hdpath = CustomHDPath::try_new(vec![
   PathValue::hardened(44), PathValue::hardened(0), PathValue::hardened(1),
   PathValue::normal(0), PathValue::normal(0)
]).unwrap();

Tuple Fields§

§0: Vec<PathValue>

Implementations§

source§

impl CustomHDPath

source

pub fn try_new(values: Vec<PathValue>) -> Result<CustomHDPath, Error>

Create a new HD Path.

Returns error only if provided vector is too large, i.e. more than 255 elements (since BIP-32 says about ability to encode depth in a single byte).

Trait Implementations§

source§

impl Clone for CustomHDPath

source§

fn clone(&self) -> CustomHDPath

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 CustomHDPath

source§

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

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

impl Display for CustomHDPath

source§

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

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

impl From<&dyn HDPath> for CustomHDPath

source§

fn from(value: &dyn HDPath) -> Self

Converts to this type from the input type.
source§

impl From<StandardHDPath> for CustomHDPath

source§

fn from(value: StandardHDPath) -> Self

Converts to this type from the input type.
source§

impl FromStr for CustomHDPath

§

type Err = Error

The associated error which can be returned from parsing.
source§

fn from_str(value: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
source§

impl HDPath for CustomHDPath

source§

fn len(&self) -> u8

Size of the HD Path
source§

fn get(&self, pos: u8) -> Option<PathValue>

Get element as the specified position. The implementation must return Some<PathValue> for all values up to len(). And return None if the position if out of bounds. Read more
source§

fn to_bytes(&self) -> Vec<u8>

Encode as bytes, where first byte is number of elements in path (always 5 for StandardHDPath) following by 4-byte BE values
source§

fn parent(&self) -> Option<CustomHDPath>

Get parent HD Path. Return None if the current path is empty (i.e. already at the top)
source§

fn as_custom(&self) -> CustomHDPath

Convert current to CustomHDPath structure
source§

impl Hash for CustomHDPath

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl PartialEq<CustomHDPath> for CustomHDPath

source§

fn eq(&self, other: &CustomHDPath) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl TryFrom<&str> for CustomHDPath

§

type Error = Error

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

fn try_from(value: &str) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<CustomHDPath> for AccountHDPath

§

type Error = Error

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

fn try_from(value: CustomHDPath) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<CustomHDPath> for StandardHDPath

§

type Error = Error

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

fn try_from(value: CustomHDPath) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl Eq for CustomHDPath

source§

impl StructuralEq for CustomHDPath

source§

impl StructuralPartialEq for CustomHDPath

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> ToString for Twhere 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 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.