unicode_bidi::utf16

Struct InitialInfo

Source
pub struct InitialInfo<'text> {
    pub text: &'text [u16],
    pub original_classes: Vec<BidiClass>,
    pub paragraphs: Vec<ParagraphInfo>,
}
Expand description

Initial bidi information of the text (UTF-16 version).

Contains the text paragraphs and BidiClass of its characters.

Fields§

§text: &'text [u16]

The text

§original_classes: Vec<BidiClass>

The BidiClass of the character at each code unit in the text. If a character is multiple code units, its class will appear multiple times in the vector.

§paragraphs: Vec<ParagraphInfo>

The boundaries and level of each paragraph within the text.

Implementations§

Source§

impl<'text> InitialInfo<'text>

Source

pub fn new(text: &[u16], default_para_level: Option<Level>) -> InitialInfo<'_>

Find the paragraphs and BidiClasses in a string of text.

http://www.unicode.org/reports/tr9/#The_Paragraph_Level

Also sets the class for each First Strong Isolate initiator (FSI) to LRI or RLI if a strong character is found before the matching PDI. If no strong character is found, the class will remain FSI, and it’s up to later stages to treat these as LRI when needed.

The hardcoded-data Cargo feature (enabled by default) must be enabled to use this.

Source

pub fn new_with_data_source<'a, D: BidiDataSource>( data_source: &D, text: &'a [u16], default_para_level: Option<Level>, ) -> InitialInfo<'a>

Find the paragraphs and BidiClasses in a string of text, with a custom BidiDataSource for Bidi data. If you just wish to use the hardcoded Bidi data, please use InitialInfo::new() instead (enabled with tbe default hardcoded-data Cargo feature)

http://www.unicode.org/reports/tr9/#The_Paragraph_Level

Also sets the class for each First Strong Isolate initiator (FSI) to LRI or RLI if a strong character is found before the matching PDI. If no strong character is found, the class will remain FSI, and it’s up to later stages to treat these as LRI when needed.

Trait Implementations§

Source§

impl<'text> Debug for InitialInfo<'text>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'text> PartialEq for InitialInfo<'text>

Source§

fn eq(&self, other: &InitialInfo<'text>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<'text> StructuralPartialEq for InitialInfo<'text>

Auto Trait Implementations§

§

impl<'text> Freeze for InitialInfo<'text>

§

impl<'text> RefUnwindSafe for InitialInfo<'text>

§

impl<'text> Send for InitialInfo<'text>

§

impl<'text> Sync for InitialInfo<'text>

§

impl<'text> Unpin for InitialInfo<'text>

§

impl<'text> UnwindSafe for InitialInfo<'text>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.