Macro nom::switch
[−]
[src]
macro_rules! switch { (__impl $i:expr, $submac:ident!( $($args:tt)* ), $($p:pat => $subrule:ident!( $($args2:tt)* ))|* ) => { ... }; ($i:expr, $submac:ident!( $($args:tt)*), $($rest:tt)*) => { ... }; ($i:expr, $e:ident, $($rest:tt)*) => { ... }; }
switch!(I -> IResult<I,P>, P => I -> IResult<I,O> | ... | P => I -> IResult<I,O> ) => I -> IResult<I, O>
choose the next parser depending on the result of the first one, if successful,
and returns the result of the second parser
named!(sw, switch!(take!(4), b"abcd" => tag!("XYZ") | b"efgh" => tag!("123") ) ); let a = b"abcdXYZ123"; let b = b"abcdef"; let c = b"efgh123"; let d = b"blah"; assert_eq!(sw(&a[..]), Done(&b"123"[..], &b"XYZ"[..])); assert_eq!(sw(&b[..]), Error(error_node_position!(ErrorKind::Switch, &b"abcdef"[..], error_position!(ErrorKind::Tag, &b"ef"[..])))); assert_eq!(sw(&c[..]), Done(&b""[..], &b"123"[..])); assert_eq!(sw(&d[..]), Error(error_position!(ErrorKind::Switch, &b"blah"[..])));
You can specify a default case like with a normal match, using _
named!(sw, switch!(take!(4), b"abcd" => tag!("XYZ") | _ => value!(&b"default"[..]) ) ); let a = b"abcdXYZ123"; let b = b"blah"; assert_eq!(sw(&a[..]), Done(&b"123"[..], &b"XYZ"[..])); assert_eq!(sw(&b[..]), Done(&b""[..], &b"default"[..]));
Due to limitations in Rust macros, it is not possible to have simple functions on the right hand side of pattern, like this:
named!(sw, switch!(take!(4), b"abcd" => tag!("XYZ") | b"efgh" => tag!("123") ) );
If you want to pass your own functions instead, you can use the call!
combinator as follows:
named!(xyz, tag!("XYZ")); named!(num, tag!("123")); named!(sw, switch!(take!(4), b"abcd" => call!(xyz) | b"efgh" => call!(num) ) );