Struct regex_syntax::hir::ClassBytes[][src]

pub struct ClassBytes { /* fields omitted */ }

A set of characters represented by arbitrary bytes (where one byte corresponds to one character).

Implementations

impl ClassBytes[src]

pub fn new<I>(ranges: I) -> ClassBytes where
    I: IntoIterator<Item = ClassBytesRange>, 
[src]

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.

pub fn empty() -> ClassBytes[src]

Create a new class with no ranges.

pub fn push(&mut self, range: ClassBytesRange)[src]

Add a new range to this set.

pub fn iter(&self) -> ClassBytesIter<'_>

Notable traits for ClassBytesIter<'a>

impl<'a> Iterator for ClassBytesIter<'a> type Item = &'a ClassBytesRange;
[src]

Return an iterator over all ranges in this class.

The iterator yields ranges in ascending order.

pub fn ranges(&self) -> &[ClassBytesRange][src]

Return the underlying ranges as a slice.

pub fn case_fold_simple(&mut self)[src]

Expand this character class such that it contains all case folded characters. 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.

Note that this only applies ASCII case folding, which is limited to the characters a-z and A-Z.

pub fn negate(&mut self)[src]

Negate this byte class.

For all b where b is a any byte, if b was in this set, then it will not be in this set after negation.

pub fn union(&mut self, other: &ClassBytes)[src]

Union this byte class with the given byte class, in place.

pub fn intersect(&mut self, other: &ClassBytes)[src]

Intersect this byte class with the given byte class, in place.

pub fn difference(&mut self, other: &ClassBytes)[src]

Subtract the given byte class from this byte class, in place.

pub fn symmetric_difference(&mut self, other: &ClassBytes)[src]

Compute the symmetric difference of the given byte classes, in place.

This computes the symmetric difference of two byte 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.

pub fn is_all_ascii(&self) -> bool[src]

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 byte.

Trait Implementations

impl Clone for ClassBytes[src]

impl Debug for ClassBytes[src]

impl Eq for ClassBytes[src]

impl PartialEq<ClassBytes> for ClassBytes[src]

impl StructuralEq for ClassBytes[src]

impl StructuralPartialEq for ClassBytes[src]

Auto Trait Implementations

impl RefUnwindSafe for ClassBytes

impl Send for ClassBytes

impl Sync for ClassBytes

impl Unpin for ClassBytes

impl UnwindSafe for ClassBytes

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.