#codec #hex #decode #encode

no-std base16

base16 (hex) encoding and decoding

5 releases

0.2.1 Jul 8, 2019
0.2.0 Jul 7, 2019
0.1.2 Apr 11, 2019
0.1.1 May 2, 2018
0.1.0 May 2, 2018

#832 in Encoding

Download history 19420/week @ 2024-06-08 21257/week @ 2024-06-15 23475/week @ 2024-06-22 17941/week @ 2024-06-29 25853/week @ 2024-07-06 21030/week @ 2024-07-13 25017/week @ 2024-07-20 16421/week @ 2024-07-27 17757/week @ 2024-08-03 15090/week @ 2024-08-10 17575/week @ 2024-08-17 18011/week @ 2024-08-24 16097/week @ 2024-08-31 18658/week @ 2024-09-07 15585/week @ 2024-09-14 15231/week @ 2024-09-21

68,717 downloads per month
Used in 140 crates (50 directly)

CC0 license

28KB
300 lines

base16 (hex) encoding for Rust.

Docs CircleCI codecov

This is a base16 (e.g. hexadecimal) encoding and decoding library which was initially written with an emphasis on performance.

This was before Rust added SIMD, and I haven't gotten around to adding that. It's still probably the fastest non-SIMD impl.

Usage

Add base16 = "0.2" to Cargo.toml, then:

fn main() {
    let original_msg = "Foobar";
    let hex_string = base16::encode_lower(original_msg);
    assert_eq!(hex_string, "466f6f626172");
    let decoded = base16::decode(&hex_string).unwrap();
    assert_eq!(String::from_utf8(decoded).unwrap(), original_msg);
}

More usage examples in the docs.

no_std Usage

This crate supports use in no_std configurations using the following knobs.

  • The "alloc" feature, which is on by default, adds a number of helpful functions that require use of the alloc crate, but not the rest of std. This is no_std compatible.
    • Each function documents if it requires use of the alloc feature.
  • The "std" feature, which is on by default, enables the "alloc" feature, and additionally makes base16::DecodeError implement the std::error::Error trait. (Frustratingly, this trait is in std and not in core or alloc...)

For clarity, this means that by default, we assume you are okay with use of std.

If you'd like to disable the use of std, but are in an environment where you have an allocator (e.g. use of the alloc crate is acceptable), then you require this as alloc-only as follows:

[dependencies]
# Turn of use of `std` (but leave use of `alloc`).
base16 = { version = "0.2", default-features = false, features = ["alloc"] }

If you just want the core base16 functionality and none of the helpers, then you should turn off all features.

[dependencies]
# Turn of use of `std` and `alloc`.
base16 = { version = "0.2", default-features = false }

Both of these configurations are no_std compatible.

License

Public domain, as explained here

No runtime deps