pub fn take<C, Input, Error: ParseError<Input>>(
count: C
) -> impl Fn(Input) -> IResult<Input, <Input as IntoOutput>::Output, Error>where
Input: InputIter + InputTake + InputLength + IntoOutput,
C: ToUsize,
👎Deprecated since 8.0.0: Replaced with
nom8::bytes::take
with input wrapped in nom8::input::Streaming
Expand description
Returns an input slice containing the first N input elements (Input[..N]).
Streaming Specific
Streaming version if the input has less than N elements, take
will
return a Err::Incomplete(Needed::new(M))
where M is the number of
additional bytes the parser would need to succeed.
It is well defined for &[u8]
as the number of elements is the byte size,
but for types like &str
, we cannot know how many bytes correspond for
the next few chars, so the result will be Err::Incomplete(Needed::Unknown)
Example
use nom8::bytes::streaming::take;
fn take6(s: &str) -> IResult<&str, &str> {
take(6usize)(s)
}
assert_eq!(take6("1234567"), Ok(("7", "123456")));
assert_eq!(take6("things"), Ok(("", "things")));
assert_eq!(take6("short"), Err(Err::Incomplete(Needed::Unknown)));
WARNING: Deprecated, replaced with nom8::bytes::take
with input wrapped in nom8::input::Streaming