onig

Struct Region

Source
pub struct Region { /* private fields */ }
Expand description

Represents a set of capture groups found in a search or match.

Implementations§

Source§

impl Region

Source

pub fn new() -> Region

Create a new empty Region

Source

pub fn with_capacity(capacity: usize) -> Region

Create a new region with a given capacity. This function allocates a new region object as in Region::new and resizes it to contain at least capacity regions.

§Arguments
  • capacity - the number of captures this region should be capable of storing without allocation.
Source

pub unsafe fn clone_from_raw(ptr: *mut OnigRegion) -> Self

Clone From Raw

Construct a new region based on an existing raw *onig_sys::OnigRegion pointer by copying.

Source

pub fn clear(&mut self)

This can be used to clear out a region so it can be used again. See onig_sys::onig_region_clear

Source

pub fn capacity(&self) -> usize

Get the current capacity of the region.

Source

pub fn reserve(&mut self, new_capacity: usize)

Updates the region to contain new_capacity slots. See onig_sys::onig_region_resize for mor information.

§Arguments
  • new_capacity - The new number of groups in the region.
Source

pub fn len(&self) -> usize

Get the size of the region.

Returns the number of registers in the region.

Source

pub fn is_empty(&self) -> bool

Check if the region is empty.

Returns true if there are no registers in the region.

Source

pub fn pos(&self, pos: usize) -> Option<(usize, usize)>

Returns the start and end positions of the Nth capture group.

Returns None if pos is not a valid capture group or if the capture group did not match anything. The positions returned are always byte indices with respect to the original string matched.

Source

pub fn tree(&self) -> Option<&CaptureTreeNode>

Get Capture Tree

Returns the capture tree for this region, if there is one.

Source

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

Get an iterator over the captures in the region.

Source

pub fn tree_traverse<F>(&self, callback: F) -> i32
where F: Fn(u32, (usize, usize), u32) -> bool,

Walk the Tree of Captures

The given callback is invoked for each node in the capture tree. Each node is passed to the callback before any children.

Source

pub fn tree_traverse_at<F>(&self, at: TraverseCallbackAt, callback: F) -> i32
where F: Fn(u32, (usize, usize), u32) -> bool,

Walk the Tree of Captures in a Given Order

The given callback is invoked for each node in the capture tree. The order in which the callback is invoked can be chosen.

Trait Implementations§

Source§

impl Clone for Region

Source§

fn clone(&self) -> Self

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 Region

Source§

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

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

impl Default for Region

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Drop for Region

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<'a> IntoIterator for &'a Region

Source§

type Item = (usize, usize)

The type of the elements being iterated over.
Source§

type IntoIter = RegionIter<'a>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
Source§

impl PartialEq for Region

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for Region

Source§

impl StructuralPartialEq for Region

Auto Trait Implementations§

§

impl Freeze for Region

§

impl RefUnwindSafe for Region

§

impl !Send for Region

§

impl !Sync for Region

§

impl Unpin for Region

§

impl UnwindSafe for Region

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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,

Source§

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

Source§

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

Source§

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.