31 releases
| 0.3.18 | Dec 16, 2024 |
|---|---|
| 0.3.17 | Oct 2, 2024 |
| 0.3.15 | Jan 17, 2024 |
| 0.3.14 | Dec 6, 2023 |
| 0.2.0 | Jul 23, 2015 |
#32 in Encoding
7,912,749 downloads per month
Used in 8,937 crates
(40 directly)
250KB
4K
SLoC
unicode-bidi
This crate implements the Unicode Bidirectional Algorithm for display of mixed right-to-left and left-to-right text. It is written in safe Rust, compatible with the current stable release.
lib.rs:
This crate implements the Unicode Bidirectional Algorithm for display of mixed right-to-left and left-to-right text. It is written in safe Rust, compatible with the current stable release.
Example
use unicode_bidi::BidiInfo;
// This example text is defined using `concat!` because some browsers
// and text editors have trouble displaying bidi strings.
let text = concat![
"א",
"ב",
"ג",
"a",
"b",
"c",
];
// Resolve embedding levels within the text. Pass `None` to detect the
// paragraph level automatically.
let bidi_info = BidiInfo::new(&text, None);
// This paragraph has embedding level 1 because its first strong character is RTL.
assert_eq!(bidi_info.paragraphs.len(), 1);
let para = &bidi_info.paragraphs[0];
assert_eq!(para.level.number(), 1);
assert_eq!(para.level.is_rtl(), true);
// Re-ordering is done after wrapping each paragraph into a sequence of
// lines. For this example, I'll just use a single line that spans the
// entire paragraph.
let line = para.range.clone();
let display = bidi_info.reorder_line(para, line);
assert_eq!(display, concat![
"a",
"b",
"c",
"ג",
"ב",
"א",
]);
Features
std: Enabled by default, but can be disabled to makeunicode_bidi#![no_std]+alloccompatible.hardcoded-data: Enabled by default. Includes hardcoded Unicode bidi data and more convenient APIs.serde: Addsserde::Serializeandserde::Deserializeimplementations to relevant types.
Dependencies
~0–740KB
~12K SLoC