CodePointSetDataBorrowed

Struct 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>

Source

pub const fn new<P: BinaryProperty>() -> Self

Creates a new CodePointSetData for a BinaryProperty.

Enabled with the compiled_data Cargo feature.

📚 Help choosing a constructor

Source

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>

Source

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
Source

pub fn contains32(self, ch: u32) -> bool

Source

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'
Source

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>

Source§

fn clone(&self) -> CodePointSetDataBorrowed<'a>

Returns a duplicate 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<'a> Debug for CodePointSetDataBorrowed<'a>

Source§

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

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

impl<'a> Copy for CodePointSetDataBorrowed<'a>

Auto Trait Implementations§

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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> 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> ErasedDestructor for T
where T: 'static,

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 8 bytes