BaseNC
Pronounced "Base-En-See".
Encoding and decoding hex, base64 and base32 with support for #[no_std].
🌟 Why BaseNC?
- ⚡ Optimized performance – SIMD-accelerated algorithms for blazing-fast encoding/decoding.
- 📦 Zero dependencies – Lightweight and reliable, no extra baggage.
- 🦀 Simple, ergonomic API – Encode/decode in just a few lines of code.
- 🔧 #[no_std] support – Works seamlessly in embedded and constrained environments.
🚀 Examples
Encoding:
let encoded = Base64Std.encode;
assert_eq!;
Decoding:
let decoded = Base64Std.decode.unwrap;
assert_eq!;
Features
-
std(default) - Enable support for the standard library, including convenient encoding/decoding toStringandVec<u8>. -
simd-off- Disable SIMD acceleration. (The SIMD paths are less tested and may contain bugs.) -
simd-runtime- Enable runtime detection of SIMD support. This is on by default, and will automatically use SIMD acceleration when available.
Tip: Build with RUSTFLAGS="-C target-cpu=native" (bash) or set RUSTFLAGS=-C target-cpu=native (cmd) to enable compiletime detection.
📜 License
Licensed under MIT License, see license.txt.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, shall be licensed as above, without any additional terms or conditions.