[−][src]Struct rcombinators::combinators::Alternative
Methods
impl<T> Alternative<T>
[src]
pub fn new(tuple: T) -> Alternative<T>
[src]
Trait Implementations
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>> Parser for Alternative<(P0, P1)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>> Parser for Alternative<(P0, P1, P2)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>, P3: Parser<Result = R>> Parser for Alternative<(P0, P1, P2, P3)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>, P3: Parser<Result = R>, P4: Parser<Result = R>> Parser for Alternative<(P0, P1, P2, P3, P4)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>, P3: Parser<Result = R>, P4: Parser<Result = R>, P5: Parser<Result = R>> Parser for Alternative<(P0, P1, P2, P3, P4, P5)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>, P3: Parser<Result = R>, P4: Parser<Result = R>, P5: Parser<Result = R>, P6: Parser<Result = R>> Parser for Alternative<(P0, P1, P2, P3, P4, P5, P6)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>, P3: Parser<Result = R>, P4: Parser<Result = R>, P5: Parser<Result = R>, P6: Parser<Result = R>, P7: Parser<Result = R>> Parser for Alternative<(P0, P1, P2, P3, P4, P5, P6, P7)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>, P3: Parser<Result = R>, P4: Parser<Result = R>, P5: Parser<Result = R>, P6: Parser<Result = R>, P7: Parser<Result = R>, P8: Parser<Result = R>> Parser for Alternative<(P0, P1, P2, P3, P4, P5, P6, P7, P8)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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
impl<R, P0: Parser<Result = R>, P1: Parser<Result = R>, P2: Parser<Result = R>, P3: Parser<Result = R>, P4: Parser<Result = R>, P5: Parser<Result = R>, P6: Parser<Result = R>, P7: Parser<Result = R>, P8: Parser<Result = R>, P9: Parser<Result = R>> Parser for Alternative<(P0, P1, P2, P3, P4, P5, P6, P7, P8, P9)>
[src]
type Result = R
fn parse(
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
[src]
&mut self,
st: &mut ParseState<impl Iterator<Item = char>>
) -> ParseResult<Self::Result>
fn apply<R2, F: Fn(Self::Result) -> ParseResult<R2>>(
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
[src]
self,
f: F
) -> Transform<Self::Result, R2, Self, F> where
Self: Sized,
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]
Self: Sized,
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<T> Send for Alternative<T> where
T: Send,
T: Send,
impl<T> Sync for Alternative<T> where
T: Sync,
T: Sync,
Blanket Implementations
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> From<T> for T
[src]
impl<T, U> TryFrom<U> 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, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,