Crate bip21[−][src]
Expand description
Rust-idiomatic, compliant, flexible and performant BIP21 crate.
Important: while lot of work went into polishing the crate it’s still considered early-development!
- Rust-idiomatic: uses strong types, standard traits and other things
- Compliant: implements all requirements of BIP21, including protections to not forget about
req-
. (But see features.) - Flexible: enables parsing/serializing additional arguments not defined by BIP21
- Performant: uses zero-copy deserialization and lazy evaluation wherever possible.
Serialization and deserialization is inspired by serde
with these important differences:
- Deserialization signals if the field is known so that
req-
fields can be rejected. - Much simpler API - we don’t need all the features.
- Use of [
Param<'a>
] to enable lazy evaluation.
The crate is no_std
but does require alloc
.
Features
std
enables integration withstd
- mainlystd::error::Error
.non-compliant-bytes
- enables use of non-compliant API that can parse non-UTF-8 URI values.
MSRV
1.41.1
Re-exports
pub use de::DeserializeParams;
pub use de::DeserializationState;
pub use de::DeserializationError;
pub use ser::SerializeParams;
Modules
Types and traits related to deserialization (parsing) of BIP21
Types and traits related to serialization (displaying) of BIP21
Structs
This is a state used to deserialize NoExtras
- it doesn’t expect any parameters.
Empty extras.
Abstrated stringly parameter in the URI.
ParamBytes
non-compliant-bytes
Iterator over decoded bytes inside paramter.
ParamBytesOwned
non-compliant-bytes
Iterator over decoded bytes inside paramter.
Parsed BIP21 URI.