#character-encoding #string #utf-8 #algorithm

no-std enrede

An easy-to-use string encoding library, providing an interface similar to str/String

4 releases

0.1.3 Aug 9, 2024
0.1.2 Aug 9, 2024
0.1.1 May 28, 2024
0.1.0 May 25, 2024

#742 in Encoding

MIT/Apache

400KB
11K SLoC

Enrede

Crates.io Version Crates.io License Actions Badge

An easy-to-use string encoding library, providing an interface similar to str/String, for working with strings in encodings beyond UTF-8. Due to the API being based on std, working with other encodings is as transparent and painless as possible.

The name, enrede, is a double wordplay - Encode/Recode/Decode, and Enrede means 'tangled' or 'caught' in Spanish.

Features

  • Str<E> and String<E> types, equivalent to str and std::string::String, but generic over encoding.
  • CStr<E> and CString<E> types, equivalent to std::ffi::CStr and std::ffi::CString, but generic over encoding.
  • Encoding trait with support for lower-level direct encoding/recoding into slices
  • no_std support
  • rand::Distribution impls for encodings, allowing easy generation of valid characters for an encoding

Planned Features

These features are not yet supported, but are planned for a future version:

  • Dynamically encoded strings
  • Extended methods for encodings following certain properties:
    • Constant length encodings
  • More encodings
    • Shift-JIS
    • Big5
    • ISO/IEC 8859-1
  • More methods on strings and C-strings

no_std Support

By default, the std and alloc features are enabled. By using default-features = false in your Cargo.toml, you can disable these features. When std is disabled, this crate is no_std. When the alloc feature is disabled, the crate won't use alloc, and any types or functions requiring allocation will be disabled (For example String<E>).

Limitations

Currently, it is assumed that all supported encodings are subsets of the Unicode character set.

Dependencies

~0.4–1MB
~22K SLoC