This library provides the following common encodings:
HEXLOWER
: lowercase hexadecimalHEXLOWER_PERMISSIVE
: lowercase hexadecimal with case-insensitive decodingHEXUPPER
: uppercase hexadecimalHEXUPPER_PERMISSIVE
: uppercase hexadecimal with case-insensitive decodingBASE32
: RFC4648 base32BASE32_NOPAD
: RFC4648 base32 without paddingBASE32_DNSSEC
: RFC5155 base32BASE32_DNSCURVE
: DNSCurve base32BASE32HEX
: RFC4648 base32hexBASE32HEX_NOPAD
: RFC4648 base32hex without paddingBASE64
: RFC4648 base64BASE64_NOPAD
: RFC4648 base64 without paddingBASE64_MIME
: RFC2045-like base64BASE64URL
: RFC4648 base64urlBASE64URL_NOPAD
: RFC4648 base64url without paddingTypical usage looks like:
rust
// allocating functions
BASE64.encode(&input_to_encode)
HEXLOWER.decode(&input_to_decode)
// in-place functions
BASE32.encode_mut(&input_to_encode, &mut encoded_output)
BASE64_URL.decode_mut(&input_to_decode, &mut decoded_output)
See the [documentation] or the [changelog] for more details.
This library also provides the possibility to define custom little-endian ASCII base-conversion encodings for bases of size 2, 4, 8, 16, 32, and 64 (for which all above use-cases are particular instances). It supports:
The typical definition of a custom encoding looks like:
rust
lazy_static! {
static ref HEX: Encoding = {
let mut spec = Specification::new();
spec.symbols.push_str("0123456789abcdef");
spec.translate.from.push_str("ABCDEF");
spec.translate.to.push_str("abcdef");
spec.encoding().unwrap()
};
static ref BASE64: Encoding = {
let mut spec = Specification::new();
spec.symbols.push_str(
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/");
spec.padding = Some('=');
spec.encoding().unwrap()
};
}
If you use a nightly compiler, you may use the [macro] library to define a compile-time custom encoding:
rust
const HEX: Encoding = new_encoding!{
symbols: "0123456789abcdef",
translate_from: "ABCDEF",
translate_to: "abcdef",
};
const BASE64: Encoding = new_encoding!{
symbols: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",
padding: '=',
};
See the [documentation] or the [changelog] for more details.
The performance of the encoding and decoding functions (for both common and custom encodings) are similar to existing implementations in C, Rust, and other high-performance languages (see how to run the benchmarks on [github]).
This crate is a library. If you are looking for the [binary] using this library, see the installation instructions on [github].