Struct icu::collator::provider::CollationReorderingV1

source ·
pub struct CollationReorderingV1<'data> {
    pub min_high_no_reorder: u32,
    pub reorder_table: ZeroVec<'data, u8>,
    pub reorder_ranges: ZeroVec<'data, u32>,
}
Expand description

Script reordering data

🚧 This code is considered unstable; it may change at any time, in breaking or non-breaking ways, including in SemVer minor releases. While the serde representation of data structs is guaranteed to be stable, their Rust representation might not be. Use with caution.

Fields§

§min_high_no_reorder: u32

Limit of last reordered range. 0 if no reordering or no split bytes.

Comment from ICU4C’s collationsettings.h

§reorder_table: ZeroVec<'data, u8>

256-byte table for reordering permutation of primary lead bytes; NULL if no reordering. A 0 entry at a non-zero index means that the primary lead byte is “split” (there are different offsets for primaries that share that lead byte) and the reordering offset must be determined via the reorderRanges.

Comment from ICU4C’s collationsettings.h

§reorder_ranges: ZeroVec<'data, u32>

Primary-weight ranges for script reordering, to be used by reorder(p) for split-reordered primary lead bytes.

Each entry is a (limit, offset) pair. The upper 16 bits of the entry are the upper 16 bits of the exclusive primary limit of a range. Primaries between the previous limit and this one have their lead bytes modified by the signed offset (-0xff..+0xff) stored in the lower 16 bits.

CollationData::makeReorderRanges() writes a full list where the first range (at least for terminators and separators) has a 0 offset. The last range has a non-zero offset. minHighNoReorder is set to the limit of that last range.

In the settings object, the initial ranges before the first split lead byte are omitted for efficiency; they are handled by reorder(p) via the reorderTable. If there are no split-reordered lead bytes, then no ranges are needed.

Comment from ICU4C’s collationsettings.h; names refer to ICU4C.

Trait Implementations§

source§

impl<'data> Bake for CollationReorderingV1<'data>

source§

fn bake(&self, env: &CrateEnv) -> TokenStream

Returns a TokenStream that would evaluate to self. Read more
source§

impl<'data> BakeSize for CollationReorderingV1<'data>

source§

fn borrows_size(&self) -> usize

Returns the size
source§

impl<'data> Clone for CollationReorderingV1<'data>

source§

fn clone(&self) -> CollationReorderingV1<'data>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<'data> Debug for CollationReorderingV1<'data>

source§

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

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

impl<'de, 'data> Deserialize<'de> for CollationReorderingV1<'data>
where 'de: 'data,

source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<CollationReorderingV1<'data>, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl<'data> PartialEq for CollationReorderingV1<'data>

source§

fn eq(&self, other: &CollationReorderingV1<'data>) -> 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<'data> Serialize for CollationReorderingV1<'data>

source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl<'a> Yokeable<'a> for CollationReorderingV1<'static>

source§

type Output = CollationReorderingV1<'a>

This type MUST be Self with the 'static replaced with 'a, i.e. Self<'a>
source§

fn transform( &'a self, ) -> &'a <CollationReorderingV1<'static> as Yokeable<'a>>::Output

This method must cast self between &'a Self<'static> and &'a Self<'a>. Read more
source§

fn transform_owned( self, ) -> <CollationReorderingV1<'static> as Yokeable<'a>>::Output

This method must cast self between Self<'static> and Self<'a>. Read more
source§

unsafe fn make( this: <CollationReorderingV1<'static> as Yokeable<'a>>::Output, ) -> CollationReorderingV1<'static>

This method can be used to cast away Self<'a>’s lifetime. Read more
source§

fn transform_mut<F>(&'a mut self, f: F)
where F: 'static + for<'b> FnOnce(&'b mut <CollationReorderingV1<'static> as Yokeable<'a>>::Output),

This method must cast self between &'a mut Self<'static> and &'a mut Self<'a>, and pass it to f. Read more
source§

impl<'zf, 'zf_inner> ZeroFrom<'zf, CollationReorderingV1<'zf_inner>> for CollationReorderingV1<'zf>

source§

fn zero_from( this: &'zf CollationReorderingV1<'zf_inner>, ) -> CollationReorderingV1<'zf>

Clone the other C into a struct that may retain references into C.
source§

impl<'data> StructuralPartialEq for CollationReorderingV1<'data>

Auto Trait Implementations§

§

impl<'data> Freeze for CollationReorderingV1<'data>

§

impl<'data> RefUnwindSafe for CollationReorderingV1<'data>

§

impl<'data> Send for CollationReorderingV1<'data>

§

impl<'data> Sync for CollationReorderingV1<'data>

§

impl<'data> Unpin for CollationReorderingV1<'data>

§

impl<'data> UnwindSafe for CollationReorderingV1<'data>

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> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

impl<T> Serialize for T
where T: Serialize + ?Sized,

source§

fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<Ok, Error>

source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

source§

impl<T> ErasedDestructor for T
where T: 'static,

source§

impl<T> MaybeSendSync for T
where T: Send + Sync,