pub fn one_of<I, T, Error: ParserError<I>>(
list: T,
) -> impl Parser<I, <I as Stream>::Token, Error>where
I: StreamIsPartial + Stream,
<I as Stream>::Token: Clone,
T: ContainsToken<<I as Stream>::Token>,
Expand description
Recognize a token that matches the pattern
Note: Parser
is implemented as a convenience (complete
only) for
u8
char
Complete version: Will return an error if there’s not enough input data.
Partial version: Will return Err(winnow::error::ErrMode::Incomplete(_))
if there’s not enough input data.
§Example
assert_eq!(one_of::<_, _, InputError<_>>(['a', 'b', 'c']).parse_peek("b"), Ok(("", 'b')));
assert_eq!(one_of::<_, _, InputError<_>>('a').parse_peek("bc"), Err(ErrMode::Backtrack(InputError::new("bc", ErrorKind::Verify))));
assert_eq!(one_of::<_, _, InputError<_>>('a').parse_peek(""), Err(ErrMode::Backtrack(InputError::new("", ErrorKind::Token))));
fn parser_fn(i: &str) -> IResult<&str, char> {
one_of(|c| c == 'a' || c == 'b').parse_peek(i)
}
assert_eq!(parser_fn("abc"), Ok(("bc", 'a')));
assert_eq!(parser_fn("cd"), Err(ErrMode::Backtrack(InputError::new("cd", ErrorKind::Verify))));
assert_eq!(parser_fn(""), Err(ErrMode::Backtrack(InputError::new("", ErrorKind::Token))));
assert_eq!(one_of::<_, _, InputError<_>>(['a', 'b', 'c']).parse_peek(Partial::new("b")), Ok((Partial::new(""), 'b')));
assert_eq!(one_of::<_, _, InputError<_>>('a').parse_peek(Partial::new("bc")), Err(ErrMode::Backtrack(InputError::new(Partial::new("bc"), ErrorKind::Verify))));
assert_eq!(one_of::<_, _, InputError<_>>('a').parse_peek(Partial::new("")), Err(ErrMode::Incomplete(Needed::new(1))));
fn parser_fn(i: Partial<&str>) -> IResult<Partial<&str>, char> {
one_of(|c| c == 'a' || c == 'b').parse_peek(i)
}
assert_eq!(parser_fn(Partial::new("abc")), Ok((Partial::new("bc"), 'a')));
assert_eq!(parser_fn(Partial::new("cd")), Err(ErrMode::Backtrack(InputError::new(Partial::new("cd"), ErrorKind::Verify))));
assert_eq!(parser_fn(Partial::new("")), Err(ErrMode::Incomplete(Needed::new(1))));