Implements the the Bubble Babble binary data encoding.
The Bubble Babble Encoding encodes arbitrary binary data into pseudowords that are more natural to humans and that can be pronounced relatively easily.
Bubble Babble encodes 6 characters in 16 bits and includes a checksum embedded in the encoded data. See the Bubble Babble spec.
This crate depends on [bstr
].
Add this to your Cargo.toml
:
toml
[dependencies]
boba = "4"
Then encode and decode data like:
rust
assert_eq!(boba::encode("Pineapple"), "xigak-nyryk-humil-bosek-sonax");
assert_eq!(boba::decode(b"xexax"), Ok(vec![]));
Boba is no_std
compatible with a required dependency on the [alloc
] crate.
Boba has several Cargo features, all of which are enabled by default:
std
], the Rust Standard Library. This
feature enables [std::error::Error
] implementations on error types in this
crate. Enabling the std feature also enables the alloc feature.alloc
], the Rust allocation and
collections library. Currently, Boba requires this feature to build, but may
relax this requirement in the future.boba
is fuzzed with [cargo-fuzz].
This crate's minimum supported rustc
version (MSRV) is 1.42.0
.
MSRV may be bumped in minor version releases.
boba
is licensed under the MIT License (c) Ryan Lopopolo.
boba
is derived from bubble-babble-ts
@
v1.0.1.
bubble-babble-ts
is licensed under the
MIT License
Copyright (c) 2018 Jonathan M. Wilbur \