combine::parser::byte

Function take_until_bytes

source
pub fn take_until_bytes<'a, Input>(
    needle: &'a [u8],
) -> take_until_bytes<'a, Input>
where <Input as StreamOnce>::Error: ParseError<<Input as StreamOnce>::Token, <Input as StreamOnce>::Range, <Input as StreamOnce>::Position>, Input: Stream + RangeStream, Input::Range: AsRef<[u8]> + Range,
Expand description

Zero-copy parser which reads a range of 0 or more tokens until needle is found.

If a, ‘b’ or c is not found, the parser will return an error.

Optimized variant of take_until_range

use combine::*;
use combine::parser::byte::take_until_bytes;
assert_eq!(
    take_until_bytes(&b"\r\n"[..]).easy_parse(&b"abc\r\n"[..]).map(|(x, _)| x),
    Ok((&b"abc"[..]))
);
// Also works on strings as long as `needle` is UTF-8
assert_eq!(
    take_until_bytes("\r\n".as_bytes()).easy_parse("abc\r\n").map(|(x, _)| x),
    Ok(("abc"))
);