pub fn escaped<'a, Input, Error, F, G, O1, O2, const STREAMING: bool>(
normal: F,
control_char: char,
escapable: G
) -> impl FnMut(Input) -> IResult<Input, <Input as IntoOutput>::Output, Error>where
Input: Clone + Offset + InputLength + InputTake + InputTakeAtPosition + Slice<RangeFrom<usize>> + InputIter + InputIsStreaming<STREAMING> + IntoOutput + 'a,
<Input as InputIter>::Item: AsChar,
F: Parser<Input, O1, Error>,
G: Parser<Input, O2, Error>,
Error: ParseError<Input>,
Expand description
Matches a byte string with escaped characters.
- The first argument matches the normal characters (it must not accept the control character)
- The second argument is the control character (like
\
in most languages) - The third argument matches the escaped characters
Example
use nom8::bytes::escaped;
use nom8::bytes::one_of;
fn esc(s: &str) -> IResult<&str, &str> {
escaped(digit1, '\\', one_of(r#""n\"#))(s)
}
assert_eq!(esc("123;"), Ok((";", "123")));
assert_eq!(esc(r#"12\"34;"#), Ok((";", r#"12\"34"#)));
use nom8::bytes::escaped;
use nom8::bytes::one_of;
fn esc(s: Streaming<&str>) -> IResult<Streaming<&str>, &str> {
escaped(digit1, '\\', one_of("\"n\\"))(s)
}
assert_eq!(esc(Streaming("123;")), Ok((Streaming(";"), "123")));
assert_eq!(esc(Streaming("12\\\"34;")), Ok((Streaming(";"), "12\\\"34")));