pub struct Key(/* private fields */);Expand description
A key used in a list of Fields.
The key has to be a two ASCII characters long, with the first character being alphabetic, and the second being a number.
§Examples
use icu::locale::extensions::transform::Key;
let key1: Key = "k0".parse().expect("Failed to parse a Key.");
assert_eq!(key1.as_str(), "k0");Implementations§
Source§impl Key
impl Key
Sourcepub const fn try_from_str(s: &str) -> Result<Self, ParseError>
pub const fn try_from_str(s: &str) -> Result<Self, ParseError>
Sourcepub const fn try_from_utf8(code_units: &[u8]) -> Result<Self, ParseError>
pub const fn try_from_utf8(code_units: &[u8]) -> Result<Self, ParseError>
Sourcepub const fn try_from_raw(raw: [u8; 2]) -> Result<Self, ParseError>
pub const fn try_from_raw(raw: [u8; 2]) -> Result<Self, ParseError>
Safely creates a Key from its raw format
as returned by Self::into_raw. Unlike Self::try_from_utf8,
this constructor only takes normalized values.
Sourcepub const unsafe fn from_raw_unchecked(v: [u8; 2]) -> Self
pub const unsafe fn from_raw_unchecked(v: [u8; 2]) -> Self
Unsafely creates a Key from its raw format
as returned by Self::into_raw. Unlike Self::try_from_utf8,
this constructor only takes normalized values.
§Safety
This function is safe iff Self::try_from_raw returns an Ok. This is the case
for inputs that are correctly normalized.
Sourcepub const fn into_raw(self) -> [u8; 2]
pub const fn into_raw(self) -> [u8; 2]
Deconstructs into a raw format to be consumed by
from_raw_unchecked or
try_from_raw.
Sourcepub fn strict_cmp(self, other: &[u8]) -> Ordering
pub fn strict_cmp(self, other: &[u8]) -> Ordering
Compare with BCP-47 bytes.
The return value is equivalent to what would happen if you first converted
self to a BCP-47 string and then performed a byte comparison.
This function is case-sensitive and results in a total order, so it is appropriate for
binary search. The only argument producing Ordering::Equal
is self.as_str().as_bytes().
Sourcepub fn normalizing_eq(self, other: &str) -> bool
pub fn normalizing_eq(self, other: &str) -> bool
Compare with a potentially unnormalized BCP-47 string.
The return value is equivalent to what would happen if you first parsed the BCP-47 string and then performed a structural comparison.
Trait Implementations§
Source§impl Display for Key
This trait is implemented for compatibility with fmt!.
To create a string, [Writeable::write_to_string] is usually more efficient.
impl Display for Key
This trait is implemented for compatibility with fmt!.
To create a string, [Writeable::write_to_string] is usually more efficient.
Source§impl From<Key> for TinyAsciiStr<2>
impl From<Key> for TinyAsciiStr<2>
Source§impl NicheBytes<2> for Key
Available on crate feature zerovec only.
impl NicheBytes<2> for Key
zerovec only.const NICHE_BIT_PATTERN: [u8; 2] = tinystr::TinyAsciiStr<2>::NICHE_BIT_PATTERN
Source§impl Ord for Key
impl Ord for Key
Source§impl PartialOrd for Key
impl PartialOrd for Key
Source§impl ULE for Key
Available on crate feature zerovec only.
impl ULE for Key
zerovec only.Source§fn validate_bytes(bytes: &[u8]) -> Result<(), UleError>
fn validate_bytes(bytes: &[u8]) -> Result<(), UleError>
&[u8]. Read moreSource§unsafe fn slice_from_bytes_unchecked(bytes: &[u8]) -> &[Self]
unsafe fn slice_from_bytes_unchecked(bytes: &[u8]) -> &[Self]
&[u8], and return it as &[Self] with the same lifetime, assuming
that this byte slice has previously been run through Self::parse_bytes_to_slice() with
success. Read moreSource§impl Writeable for Key
impl Writeable for Key
Source§fn write_to<W: Write + ?Sized>(&self, sink: &mut W) -> Result
fn write_to<W: Write + ?Sized>(&self, sink: &mut W) -> Result
write_to_parts, and discards any
Part annotations.Source§fn writeable_length_hint(&self) -> LengthHint
fn writeable_length_hint(&self) -> LengthHint
Source§fn write_to_parts<S>(&self, sink: &mut S) -> Result<(), Error>where
S: PartsWrite + ?Sized,
fn write_to_parts<S>(&self, sink: &mut S) -> Result<(), Error>where
S: PartsWrite + ?Sized,
Part annotations to the given sink. Errors from the
sink are bubbled up. The default implementation delegates to write_to,
and doesn’t produce any Part annotations.Source§impl<'a> ZeroMapKV<'a> for Key
Available on crate feature zerovec only.
impl<'a> ZeroMapKV<'a> for Key
zerovec only.