Struct regex_syntax::hir::ClassUnicode
source · [−]pub struct ClassUnicode { /* private fields */ }
Expand description
A set of characters represented by Unicode scalar values.
Implementations
sourceimpl ClassUnicode
impl ClassUnicode
sourcepub fn new<I>(ranges: I) -> ClassUnicode where
I: IntoIterator<Item = ClassUnicodeRange>,
pub fn new<I>(ranges: I) -> ClassUnicode where
I: IntoIterator<Item = ClassUnicodeRange>,
Create a new class from a sequence of ranges.
The given ranges do not need to be in any specific order, and ranges may overlap.
sourcepub fn empty() -> ClassUnicode
pub fn empty() -> ClassUnicode
Create a new class with no ranges.
sourcepub fn push(&mut self, range: ClassUnicodeRange)
pub fn push(&mut self, range: ClassUnicodeRange)
Add a new range to this set.
sourcepub fn iter(&self) -> ClassUnicodeIter<'_>ⓘNotable traits for ClassUnicodeIter<'a>impl<'a> Iterator for ClassUnicodeIter<'a> type Item = &'a ClassUnicodeRange;
pub fn iter(&self) -> ClassUnicodeIter<'_>ⓘNotable traits for ClassUnicodeIter<'a>impl<'a> Iterator for ClassUnicodeIter<'a> type Item = &'a ClassUnicodeRange;
Return an iterator over all ranges in this class.
The iterator yields ranges in ascending order.
sourcepub fn ranges(&self) -> &[ClassUnicodeRange]
pub fn ranges(&self) -> &[ClassUnicodeRange]
Return the underlying ranges as a slice.
sourcepub fn case_fold_simple(&mut self)
pub fn case_fold_simple(&mut self)
Expand this character class such that it contains all case folded
characters, according to Unicode’s “simple” mapping. For example, if
this class consists of the range a-z
, then applying case folding will
result in the class containing both the ranges a-z
and A-Z
.
Panics
This routine panics when the case mapping data necessary for this
routine to complete is unavailable. This occurs when the unicode-case
feature is not enabled.
Callers should prefer using try_case_fold_simple
instead, which will
return an error instead of panicking.
sourcepub fn try_case_fold_simple(&mut self) -> Result<(), CaseFoldError>
pub fn try_case_fold_simple(&mut self) -> Result<(), CaseFoldError>
Expand this character class such that it contains all case folded
characters, according to Unicode’s “simple” mapping. For example, if
this class consists of the range a-z
, then applying case folding will
result in the class containing both the ranges a-z
and A-Z
.
Error
This routine returns an error when the case mapping data necessary
for this routine to complete is unavailable. This occurs when the
unicode-case
feature is not enabled.
sourcepub fn negate(&mut self)
pub fn negate(&mut self)
Negate this character class.
For all c
where c
is a Unicode scalar value, if c
was in this
set, then it will not be in this set after negation.
sourcepub fn union(&mut self, other: &ClassUnicode)
pub fn union(&mut self, other: &ClassUnicode)
Union this character class with the given character class, in place.
sourcepub fn intersect(&mut self, other: &ClassUnicode)
pub fn intersect(&mut self, other: &ClassUnicode)
Intersect this character class with the given character class, in place.
sourcepub fn difference(&mut self, other: &ClassUnicode)
pub fn difference(&mut self, other: &ClassUnicode)
Subtract the given character class from this character class, in place.
sourcepub fn symmetric_difference(&mut self, other: &ClassUnicode)
pub fn symmetric_difference(&mut self, other: &ClassUnicode)
Compute the symmetric difference of the given character classes, in place.
This computes the symmetric difference of two character classes. This removes all elements in this class that are also in the given class, but all adds all elements from the given class that aren’t in this class. That is, the class will contain all elements in either class, but will not contain any elements that are in both classes.
sourcepub fn is_all_ascii(&self) -> bool
pub fn is_all_ascii(&self) -> bool
Returns true if and only if this character class will either match nothing or only ASCII bytes. Stated differently, this returns false if and only if this class contains a non-ASCII codepoint.
Trait Implementations
sourceimpl Clone for ClassUnicode
impl Clone for ClassUnicode
sourcefn clone(&self) -> ClassUnicode
fn clone(&self) -> ClassUnicode
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl Debug for ClassUnicode
impl Debug for ClassUnicode
sourceimpl PartialEq<ClassUnicode> for ClassUnicode
impl PartialEq<ClassUnicode> for ClassUnicode
sourcefn eq(&self, other: &ClassUnicode) -> bool
fn eq(&self, other: &ClassUnicode) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &ClassUnicode) -> bool
fn ne(&self, other: &ClassUnicode) -> bool
This method tests for !=
.
impl Eq for ClassUnicode
impl StructuralEq for ClassUnicode
impl StructuralPartialEq for ClassUnicode
Auto Trait Implementations
impl RefUnwindSafe for ClassUnicode
impl Send for ClassUnicode
impl Sync for ClassUnicode
impl Unpin for ClassUnicode
impl UnwindSafe for ClassUnicode
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more