pub struct AliasesV1<'data> {
    pub language_variants: VarZeroVec<'data, StrStrPairVarULE>,
    pub sgn_region: ZeroMap<'data, TinyAsciiStr<3>, Language>,
    pub language_len2: ZeroMap<'data, TinyAsciiStr<2>, str>,
    pub language_len3: ZeroMap<'data, TinyAsciiStr<3>, str>,
    pub language: VarZeroVec<'data, StrStrPairVarULE>,
    pub script: ZeroMap<'data, TinyAsciiStr<4>, Script>,
    pub region_alpha: ZeroMap<'data, TinyAsciiStr<2>, Region>,
    pub region_num: ZeroMap<'data, TinyAsciiStr<3>, Region>,
    pub complex_region: ZeroMap<'data, TinyAsciiStr<3>, ZeroSlice<Region>>,
    pub variant: ZeroMap<'data, TinyAsciiStr<8>, Variant>,
    pub subdivision: ZeroMap<'data, TinyAsciiStr<7>, TinyAsciiStr<7>>,
}
Expand description

This alias data is used for locale canonicalization. Each field defines a mapping from an old identifier to a new identifier, based upon the rules in from http://unicode.org/reports/tr35/#LocaleId_Canonicalization. The data is stored in sorted order, allowing for binary search to identify rules to apply. It is broken down into smaller vectors based upon some characteristic of the data, to help avoid unnecessary searches. For example, the sgn_region field contains aliases for sign language and region, so that it is not necessary to search the data unless the input is a sign language.

The algorithm in tr35 is not guaranteed to terminate on data other than what is currently in CLDR. For this reason, it is not a good idea to attempt to add or modify aliases for use in this structure.

🚧 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§

§language_variants: VarZeroVec<'data, StrStrPairVarULE>

[language(-variant)+\] -> [langid] This is not a map as it’s searched linearly according to the canonicalization rules.

§sgn_region: ZeroMap<'data, TinyAsciiStr<3>, Language>

sgn-[region] -> [language]

§language_len2: ZeroMap<'data, TinyAsciiStr<2>, str>

[language{2}] -> [langid]

§language_len3: ZeroMap<'data, TinyAsciiStr<3>, str>

[language{3}] -> [langid]

§language: VarZeroVec<'data, StrStrPairVarULE>

[langid] -> [langid] This is not a map as it’s searched linearly according to the canonicalization rules.

§script: ZeroMap<'data, TinyAsciiStr<4>, Script>

[script] -> [script]

§region_alpha: ZeroMap<'data, TinyAsciiStr<2>, Region>

[region{2}] -> [region]

§region_num: ZeroMap<'data, TinyAsciiStr<3>, Region>

[region{3}] -> [region]

§complex_region: ZeroMap<'data, TinyAsciiStr<3>, ZeroSlice<Region>>

[region] -> [region]+

§variant: ZeroMap<'data, TinyAsciiStr<8>, Variant>

[variant] -> [variant]

§subdivision: ZeroMap<'data, TinyAsciiStr<7>, TinyAsciiStr<7>>

[value{7}] -> [value{7}]

Trait Implementations§

source§

impl<'data> Bake for AliasesV1<'data>

source§

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

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

impl<'data> Clone for AliasesV1<'data>

source§

fn clone(&self) -> AliasesV1<'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 AliasesV1<'data>

source§

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

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

impl<'data> Default for AliasesV1<'data>

source§

fn default() -> AliasesV1<'data>

Returns the “default value” for a type. Read more
source§

impl<'de: 'data, 'data> Deserialize<'de> for AliasesV1<'data>

source§

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

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

impl<'data> PartialEq<AliasesV1<'data>> for AliasesV1<'data>

source§

fn eq(&self, other: &AliasesV1<'data>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<'data> Serialize for AliasesV1<'data>

source§

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

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

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

§

type Output = AliasesV1<'a>

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

fn transform(&'a self) -> &'a Self::Output

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

fn transform_owned(self) -> Self::Output

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

unsafe fn make(this: Self::Output) -> Self

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 Self::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, AliasesV1<'zf_inner>> for AliasesV1<'zf>

source§

fn zero_from(this: &'zf AliasesV1<'zf_inner>) -> Self

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

impl<'data> StructuralPartialEq for AliasesV1<'data>

Auto Trait Implementations§

§

impl<'data> RefUnwindSafe for AliasesV1<'data>

§

impl<'data> Send for AliasesV1<'data>

§

impl<'data> Sync for AliasesV1<'data>

§

impl<'data> Unpin for AliasesV1<'data>

§

impl<'data> UnwindSafe for AliasesV1<'data>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

source§

impl<T> MaybeSendSync for T