#cryptocurrency #codec #base32 #bitcoin #encoding

no-std bech32

Encodes and decodes the Bech32 format and implements the bech32 and bech32m checksums

22 releases

0.11.0 Feb 23, 2024
0.10.0-beta2 Jan 16, 2024
0.10.0-beta Oct 9, 2023
0.9.1 Aug 12, 2022
0.2.1 May 17, 2017

#5 in #cryptocurrency

Download history 145378/week @ 2024-09-14 148230/week @ 2024-09-21 154913/week @ 2024-09-28 162771/week @ 2024-10-05 163690/week @ 2024-10-12 162648/week @ 2024-10-19 158205/week @ 2024-10-26 151128/week @ 2024-11-02 147655/week @ 2024-11-09 152593/week @ 2024-11-16 143798/week @ 2024-11-23 180731/week @ 2024-11-30 193590/week @ 2024-12-07 176581/week @ 2024-12-14 75473/week @ 2024-12-21 86986/week @ 2024-12-28

563,408 downloads per month
Used in 2,274 crates (225 directly)

MIT license

180KB
3K SLoC

Rust Bech32

Docs.rs badge Continuous Integration

Rust implementation of the Bech32 encoding format described in BIP-0173 and Bech32m encoding format described in BIP-0350.

You can find some usage examples in the documentation.

Bitcoin-specific address encoding is handled by the bitcoin-bech32 crate.

MSRV

This library should always compile with any combination of features on Rust 1.48.0.

Githooks

To assist devs in catching errors before running CI we provide some githooks. If you do not already have locally configured githooks you can use the ones in this repository by running, in the root directory of the repository:

git config --local core.hooksPath githooks/

Alternatively add symlinks in your .git/hooks directory to any of the githooks we provide.

Benchmarks

We use a custom Rust compiler configuration conditional to guard the benchmark code. To run the benchmarks use: RUSTFLAGS='--cfg=bench' cargo +nightly bench.

API changes

All PRs that change the public API of rust-bech32 must include a patch to the api/ text files. For PRs that include API changes, add a separate patch to the PR that is the diff created by running contrib/check-for-api-changes.sh.

No runtime deps

Features