Enum regex_syntax::Expr
[−]
[src]
pub enum Expr { Empty, Literal { chars: Vec<char>, casei: bool, }, LiteralBytes { bytes: Vec<u8>, casei: bool, }, AnyChar, AnyCharNoNL, AnyByte, AnyByteNoNL, Class(CharClass), ClassBytes(ByteClass), StartLine, EndLine, StartText, EndText, WordBoundary, NotWordBoundary, WordBoundaryAscii, NotWordBoundaryAscii, Group { e: Box<Expr>, i: Option<usize>, name: Option<String>, }, Repeat { e: Box<Expr>, r: Repeater, greedy: bool, }, Concat(Vec<Expr>), Alternate(Vec<Expr>), }
A regular expression abstract syntax tree.
An Expr
represents the abstract syntax of a regular expression.
Variants
Empty | An empty regex (which never matches any text). | ||||||
Literal | A sequence of one or more literal characters to be matched. Fields
| ||||||
LiteralBytes | A sequence of one or more literal bytes to be matched. Fields
| ||||||
AnyChar | Match any character. | ||||||
AnyCharNoNL | Match any character, excluding new line ( | ||||||
AnyByte | Match any byte. | ||||||
AnyByteNoNL | Match any byte, excluding new line ( | ||||||
Class | A character class. | ||||||
ClassBytes | A character class with byte ranges only. | ||||||
StartLine | Match the start of a line or beginning of input. | ||||||
EndLine | Match the end of a line or end of input. | ||||||
StartText | Match the beginning of input. | ||||||
EndText | Match the end of input. | ||||||
WordBoundary | Match a word boundary (word character on one side and a non-word character on the other). | ||||||
NotWordBoundary | Match a position that is not a word boundary (word or non-word characters on both sides). | ||||||
WordBoundaryAscii | Match an ASCII word boundary. | ||||||
NotWordBoundaryAscii | Match a position that is not an ASCII word boundary. | ||||||
Group | A group, possibly non-capturing. Fields
| ||||||
Repeat | A repeat operator ( Fields
| ||||||
Concat | A concatenation of expressions. Must be matched one after the other. N.B. A concat expression can only appear at the top-level or immediately inside a group expression. | ||||||
Alternate | An alternation of expressions. Only one must match. N.B. An alternate expression can only appear at the top-level or immediately inside a group expression. |
Methods
impl Expr
fn parse(s: &str) -> Result<Expr>
Parses a string in a regular expression syntax tree.
This is a convenience method for parsing an expression using the
default configuration. To tweak parsing options (such as which flags
are enabled by default), use the ExprBuilder
type.
fn is_anchored_start(&self) -> bool
Returns true if and only if the expression is required to match from the beginning of text.
fn is_anchored_end(&self) -> bool
Returns true if and only if the expression is required to match at the end of the text.
fn has_bytes(&self) -> bool
Returns true if and only if the expression contains sub-expressions that can match arbitrary bytes.
Trait Implementations
impl Display for Expr
This implementation of Display
will write a regular expression from the
syntax tree. It does not write the original string parsed.