[][src]Struct rcombinators::combinators::Then

pub struct Then<A: Parser, B: Parser> { /* fields omitted */ }

Applies one parser, discards the result, and returns the second parser's results if the first one succeeded. To skip the input consumed by several parsers, use a Sequence combinators as A.

Methods

impl<A: Parser, B: Parser> Then<A, B>[src]

pub fn new(first: A, second: B) -> Then<A, B>[src]

Trait Implementations

impl<A: Parser, B: Parser> Parser for Then<A, B>[src]

type Result = B::Result

fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
    self,
    f: F
) -> Transform<Self::Result, R2, Self, F> where
    Self: Sized
[src]

apply transforms the result of this parser using a Transform combinator.

fn then<R2, P: Parser<Result = R2>>(self, p: P) -> Then<Self, P> where
    Self: Sized
[src]

then attempts to parse input, and if it succeeds, executes parser p, only returning p's result. This is useful for chaining parsers of which the results are not need. Read more

Auto Trait Implementations

impl<A, B> Send for Then<A, B> where
    A: Send,
    B: Send

impl<A, B> Sync for Then<A, B> where
    A: Sync,
    B: Sync

Blanket Implementations

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> From<T> for T[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]