[−][src]Struct regex_syntax::CharClass
A character class.
A character class has a canonical format that the parser guarantees. Its canonical format is defined by the following invariants:
- Given any Unicode scalar value, it is matched by at most one character range in a canonical character class.
- Every adjacent character range is separated by at least one Unicode scalar value.
- Given any pair of character ranges
r1andr2, ifr1.end < r2.start, thenr1comes beforer2in a canonical character class.
In sum, any CharClass produced by this crate's parser is a sorted
sequence of non-overlapping ranges. This makes it possible to test whether
a character is matched by a class with a binary search.
If the case insensitive flag was set when parsing a character class, then
simple case folding is done automatically. For example, (?i)[a-c] is
automatically translated to [a-cA-C].
Methods
impl CharClass[src]
pub fn new(ranges: Vec<ClassRange>) -> CharClass[src]
Create a new class from an existing set of ranges.
pub fn matches(&self, c: char) -> bool[src]
Returns true if c is matched by this character class.
pub fn remove(&mut self, c: char)[src]
Removes the given character from the class if it exists.
Note that this takes O(n) time in the number of ranges.
pub fn negate(self) -> CharClass[src]
Negates the character class.
For all c where c is a Unicode scalar value, c matches self
if and only if c does not match self.negate().
pub fn case_fold(self) -> CharClass[src]
Apply case folding to this character class.
N.B. Applying case folding to a negated character class probably
won't produce the expected result. e.g., (?i)[^x] really should
match any character sans x and X, but if [^x] is negated
before being case folded, you'll end up matching any character.
Methods from Deref<Target = Vec<ClassRange>>
pub fn capacity(&self) -> usize1.0.0[src]
Returns the number of elements the vector can hold without reallocating.
Examples
let vec: Vec<i32> = Vec::with_capacity(10); assert_eq!(vec.capacity(), 10);
pub fn as_slice(&self) -> &[T]1.7.0[src]
Extracts a slice containing the entire vector.
Equivalent to &s[..].
Examples
use std::io::{self, Write}; let buffer = vec![1, 2, 3, 5, 8]; io::sink().write(buffer.as_slice()).unwrap();
pub fn len(&self) -> usize1.0.0[src]
Returns the number of elements in the vector, also referred to as its 'length'.
Examples
let a = vec![1, 2, 3]; assert_eq!(a.len(), 3);
pub fn is_empty(&self) -> bool1.0.0[src]
Returns true if the vector contains no elements.
Examples
let mut v = Vec::new(); assert!(v.is_empty()); v.push(1); assert!(!v.is_empty());
Trait Implementations
impl PartialEq<CharClass> for CharClass[src]
impl Clone for CharClass[src]
fn clone(&self) -> CharClass[src]
fn clone_from(&mut self, source: &Self)1.0.0[src]
Performs copy-assignment from source. Read more
impl IntoIterator for CharClass[src]
type Item = ClassRange
The type of the elements being iterated over.
type IntoIter = IntoIter<ClassRange>
Which kind of iterator are we turning this into?
fn into_iter(self) -> IntoIter<ClassRange>[src]
impl<'a> IntoIterator for &'a CharClass[src]
type Item = &'a ClassRange
The type of the elements being iterated over.
type IntoIter = Iter<'a, ClassRange>
Which kind of iterator are we turning this into?
fn into_iter(self) -> Iter<'a, ClassRange>[src]
impl Eq for CharClass[src]
impl Debug for CharClass[src]
impl Display for CharClass[src]
impl Deref for CharClass[src]
type Target = Vec<ClassRange>
The resulting type after dereferencing.
fn deref(&self) -> &Vec<ClassRange>[src]
Auto Trait Implementations
Blanket Implementations
impl<T> From for T[src]
impl<I> IntoIterator for I where
I: Iterator, [src]
I: Iterator,
type Item = <I as Iterator>::Item
The type of the elements being iterated over.
type IntoIter = I
Which kind of iterator are we turning this into?
fn into_iter(self) -> I[src]
impl<T, U> Into for T where
U: From<T>, [src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone, [src]
T: Clone,
impl<T> ToString for T where
T: Display + ?Sized, [src]
T: Display + ?Sized,
impl<T, U> TryFrom for T where
U: Into<T>, [src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
impl<T> Borrow for T where
T: ?Sized, [src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized, [src]
T: 'static + ?Sized,
impl<T> BorrowMut for T where
T: ?Sized, [src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T[src]
impl<T, U> TryInto for T where
U: TryFrom<T>, [src]
U: TryFrom<T>,