pub enum HirKind {
    Empty,
    Literal(Literal),
    Class(Class),
    Anchor(Anchor),
    WordBoundary(WordBoundary),
    Repetition(Repetition),
    Group(Group),
    Concat(Vec<Hir>),
    Alternation(Vec<Hir>),
}
Expand description

The kind of an arbitrary Hir expression.

Variants§

§

Empty

The empty regular expression, which matches everything, including the empty string.

§

Literal(Literal)

A single literal character that matches exactly this character.

§

Class(Class)

A single character class that matches any of the characters in the class. A class can either consist of Unicode scalar values as characters, or it can use bytes.

§

Anchor(Anchor)

An anchor assertion. An anchor assertion match always has zero length.

§

WordBoundary(WordBoundary)

A word boundary assertion, which may or may not be Unicode aware. A word boundary assertion match always has zero length.

§

Repetition(Repetition)

A repetition operation applied to a child expression.

§

Group(Group)

A possibly capturing group, which contains a child expression.

§

Concat(Vec<Hir>)

A concatenation of expressions. A concatenation always has at least two child expressions.

A concatenation matches only if each of its child expression matches one after the other.

§

Alternation(Vec<Hir>)

An alternation of expressions. An alternation always has at least two child expressions.

An alternation matches only if at least one of its child expression matches. If multiple expressions match, then the leftmost is preferred.

Implementations§

source§

impl HirKind

source

pub fn is_empty(&self) -> bool

Return true if and only if this HIR is the empty regular expression.

Note that this is not defined inductively. That is, it only tests if this kind is the Empty variant. To get the inductive definition, use the is_match_empty method on Hir.

source

pub fn has_subexprs(&self) -> bool

Returns true if and only if this kind has any (including possibly empty) subexpressions.

Trait Implementations§

source§

impl Clone for HirKind

source§

fn clone(&self) -> HirKind

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 HirKind

source§

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

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

impl PartialEq for HirKind

source§

fn eq(&self, other: &HirKind) -> 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 HirKind

source§

impl StructuralPartialEq for HirKind

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.