pub struct ClassBytes { /* private fields */ }
Expand description

A set of characters represented by arbitrary bytes.

Each byte corresponds to one character.

Implementations§

source§

impl ClassBytes

source

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

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. Ranges will automatically be sorted into a canonical non-overlapping order.

source

pub fn empty() -> ClassBytes

Create a new class with no ranges.

An empty class matches nothing. That is, it is equivalent to Hir::fail.

source

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

Add a new range to this set.

source

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

Return an iterator over all ranges in this class.

The iterator yields ranges in ascending order.

source

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

Return the underlying ranges as a slice.

source

pub fn case_fold_simple(&mut self)

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.

source

pub fn negate(&mut self)

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.

source

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

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

source

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

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

source

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

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

source

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

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.

source

pub fn is_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 byte.

source

pub fn minimum_len(&self) -> Option<usize>

Returns the length, in bytes, of the smallest string matched by this character class.

Returns None when the class is empty.

source

pub fn maximum_len(&self) -> Option<usize>

Returns the length, in bytes, of the longest string matched by this character class.

Returns None when the class is empty.

source

pub fn literal(&self) -> Option<Vec<u8>>

If this class consists of exactly one byte, then return it as a literal byte string.

If this class is empty or contains more than one byte, then None is returned.

source

pub fn to_unicode_class(&self) -> Option<ClassUnicode>

If this class consists of only ASCII ranges, then return its corresponding and equivalent Unicode class.

Trait Implementations§

source§

impl Clone for ClassBytes

source§

fn clone(&self) -> ClassBytes

Returns a copy 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 Debug for ClassBytes

source§

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

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

impl PartialEq for ClassBytes

source§

fn eq(&self, other: &ClassBytes) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for ClassBytes

source§

impl StructuralPartialEq for ClassBytes

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

§

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

§

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

§

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.