Function nom::character::streaming::satisfy [−][src]
pub fn satisfy<F, I, Error: ParseError<I>>(
cond: F
) -> impl Fn(I) -> IResult<I, char, Error> where
I: Slice<RangeFrom<usize>> + InputIter,
<I as InputIter>::Item: AsChar,
F: Fn(char) -> bool,
Recognizes one character and checks that it satisfies a predicate
Streaming version: Will return Err(nom::Err::Incomplete(_))
if there’s not enough input data.
Example
fn parser(i: &str) -> IResult<&str, char> { satisfy(|c| c == 'a' || c == 'b')(i) } assert_eq!(parser("abc"), Ok(("bc", 'a'))); assert_eq!(parser("cd"), Err(Err::Error(Error::new("cd", ErrorKind::Satisfy)))); assert_eq!(parser(""), Err(Err::Incomplete(Needed::Unknown)));