Struct icu::properties::CodePointSetDataBorrowed
source · pub struct CodePointSetDataBorrowed<'a> { /* private fields */ }
Expand description
A borrowed wrapper around code point set data, returned by
CodePointSetData::as_borrowed()
. More efficient to query.
Implementations§
source§impl CodePointSetDataBorrowed<'static>
impl CodePointSetDataBorrowed<'static>
sourcepub const fn static_to_owned(self) -> CodePointSetData
pub const fn static_to_owned(self) -> CodePointSetData
Cheaply converts a [CodePointSetDataBorrowed<'static>
] into a CodePointSetData
.
Note: Due to branching and indirection, using CodePointSetData
might inhibit some
compile-time optimizations that are possible with CodePointSetDataBorrowed
.
source§impl<'a> CodePointSetDataBorrowed<'a>
impl<'a> CodePointSetDataBorrowed<'a>
sourcepub fn contains(self, ch: char) -> bool
pub fn contains(self, ch: char) -> bool
Check if the set contains a character
use icu::properties::CodePointSetData;
use icu::properties::props::Alphabetic;
let alphabetic = CodePointSetData::new::<Alphabetic>();
assert!(!alphabetic.contains('3'));
assert!(!alphabetic.contains('੩')); // U+0A69 GURMUKHI DIGIT THREE
assert!(alphabetic.contains('A'));
assert!(alphabetic.contains('Ä')); // U+00C4 LATIN CAPITAL LETTER A WITH DIAERESIS
sourcepub fn contains32(self, ch: u32) -> bool
pub fn contains32(self, ch: u32) -> bool
See Self::contains
.
sourcepub fn iter_ranges(self) -> impl Iterator<Item = RangeInclusive<u32>> + 'a
pub fn iter_ranges(self) -> impl Iterator<Item = RangeInclusive<u32>> + 'a
included in the CodePointSetData
Ranges are returned as RangeInclusive
, which is inclusive of its
end
bound value. An end-inclusive behavior matches the ICU4C/J
behavior of ranges, ex: UnicodeSet::contains(UChar32 start, UChar32 end)
.
§Example
use icu::properties::props::Alphabetic;
use icu::properties::CodePointSetData;
let alphabetic = CodePointSetData::new::<Alphabetic>();
let mut ranges = alphabetic.iter_ranges();
assert_eq!(Some(0x0041..=0x005A), ranges.next()); // 'A'..'Z'
assert_eq!(Some(0x0061..=0x007A), ranges.next()); // 'a'..'z'
sourcepub fn iter_ranges_complemented(
self,
) -> impl Iterator<Item = RangeInclusive<u32>> + 'a
pub fn iter_ranges_complemented( self, ) -> impl Iterator<Item = RangeInclusive<u32>> + 'a
not included in the CodePointSetData
Ranges are returned as RangeInclusive
, which is inclusive of its
end
bound value. An end-inclusive behavior matches the ICU4C/J
behavior of ranges, ex: UnicodeSet::contains(UChar32 start, UChar32 end)
.
§Example
use icu::properties::props::Alphabetic;
use icu::properties::CodePointSetData;
let alphabetic = CodePointSetData::new::<Alphabetic>();
let mut ranges = alphabetic.iter_ranges();
assert_eq!(Some(0x0041..=0x005A), ranges.next()); // 'A'..'Z'
assert_eq!(Some(0x0061..=0x007A), ranges.next()); // 'a'..'z'
Trait Implementations§
source§impl<'a> Clone for CodePointSetDataBorrowed<'a>
impl<'a> Clone for CodePointSetDataBorrowed<'a>
source§fn clone(&self) -> CodePointSetDataBorrowed<'a>
fn clone(&self) -> CodePointSetDataBorrowed<'a>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<'a> Debug for CodePointSetDataBorrowed<'a>
impl<'a> Debug for CodePointSetDataBorrowed<'a>
impl<'a> Copy for CodePointSetDataBorrowed<'a>
Auto Trait Implementations§
impl<'a> Freeze for CodePointSetDataBorrowed<'a>
impl<'a> RefUnwindSafe for CodePointSetDataBorrowed<'a>
impl<'a> Send for CodePointSetDataBorrowed<'a>
impl<'a> Sync for CodePointSetDataBorrowed<'a>
impl<'a> Unpin for CodePointSetDataBorrowed<'a>
impl<'a> UnwindSafe for CodePointSetDataBorrowed<'a>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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