pub struct ParserContext<T> { /* private fields */ }
Expand description

Container for input into parsers

All parsers accept a ParserContext as input and must return one if they succeed.

The structure contains whatever input is yet to be parsed as well as our absolute position within the original input, which is useful for reporting errors.

Note: if you are manually extracting the values from the input, you will need to update the position before returning the context. An example will clarify:

use parser_compose::{Parser, ParserContext, Res};

fn easy(ctx: ParserContext<&str>) -> Res<&str, (&str, &str)> {
    // Here, the sequence combinator will take care of updating the context
    // before returning if both parsers matched.
    ("A", "B").try_parse(ctx)
}

fn manual(mut ctx: ParserContext<&str>) -> Res<&str, &str> {
    let (offset, _) = ("A", "B").peek().try_parse(ctx)?;

    // In some cases, you might want to manually extract the value yourself.
    // In this contrived example, doing so lets you return a single string
    // slice instead of a tuple.
    let value = &ctx.input()[..offset];
    // But make sure you update the position in the context before passing it on
    ctx.advance_by(offset);

    Ok((value, ctx))
}

let msg = "AB";

let (value, rest) = easy.try_parse(msg.into()).unwrap();

assert_eq!(value, ("A", "B"));
assert_eq!(rest.input(), "");

let (value, rest) = manual.try_parse(msg.into()).unwrap();
assert_eq!(value, "AB");
assert_eq!(rest.input(), "");

Regular slices (i.e. &[T]) and string slices (i.e. &str) can be converted into this structure by using ParserContext::from(), or using .into() in contexts where the compiler can infer the type.

Implementations§

source§

impl<'a, T> ParserContext<&'a T>where T: Index<RangeFrom<usize>> + ?Sized,

source

pub fn input(&self) -> &'a <T as Index<RangeFrom<usize>>>::Output

Returns the input being parsed. The first parser will see the entire input. Subsequent parsers will only see whatever is left to parse

source§

impl<T> ParserContext<T>where T: Clone,

source

pub fn advance_by(&mut self, count: usize)

Increments the input position by count. If there is less than count elements left in the input, the position will be set to the length of the input.

Advancing the position affects what subsequent calls to .input() return

source§

impl<T> ParserContext<T>

source

pub fn end_of_input(&self) -> bool

Returns true if this instance’s position is at the end of the input

source

pub fn get_position(&self) -> usize

Returns the current input position

Trait Implementations§

source§

impl<T: Clone> Clone for ParserContext<T>

source§

fn clone(&self) -> ParserContext<T>

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<T: Debug> Debug for ParserContext<T>

source§

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

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

impl<'i, T> From<&'i [T]> for ParserContext<&'i [T]>

source§

fn from(value: &'i [T]) -> Self

Converts to this type from the input type.
source§

impl<'i> From<&'i str> for ParserContext<&'i str>

source§

fn from(value: &'i str) -> Self

Converts to this type from the input type.
source§

impl<T: PartialEq> PartialEq for ParserContext<T>

source§

fn eq(&self, other: &ParserContext<T>) -> 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<T: Copy> Copy for ParserContext<T>

source§

impl<T: Eq> Eq for ParserContext<T>

source§

impl<T> StructuralEq for ParserContext<T>

source§

impl<T> StructuralPartialEq for ParserContext<T>

Auto Trait Implementations§

§

impl<T> RefUnwindSafe for ParserContext<T>where T: RefUnwindSafe,

§

impl<T> Send for ParserContext<T>where T: Send,

§

impl<T> Sync for ParserContext<T>where T: Sync,

§

impl<T> Unpin for ParserContext<T>where T: Unpin,

§

impl<T> UnwindSafe for ParserContext<T>where T: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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 Twhere 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 Twhere 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 Twhere 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.