Macro nom::opt[][src]

macro_rules! opt {
    ($i:expr, $submac:ident!( $($args:tt)* )) => { ... };
    ($i:expr, $f:expr) => { ... };
}

opt!(I -> IResult<I,O>) => I -> IResult<I, Option<O>> make the underlying parser optional.

Returns an Option of the returned type. This parser returns Some(result) if the child parser succeeds, None if it fails, and Incomplete if it did not have enough data to decide.

Warning: if you are using opt for some kind of optional ending token (like an end of line), you should combine it with complete to make sure it works.

As an example, opt!(tag!("\r\n")) will return Incomplete if it receives an empty input, because tag does not have enough input to decide. On the contrary, opt!(complete!(tag!("\r\n"))) would return None as produced value, since complete! transforms an Incomplete in an Error.

 named!( o<&[u8], Option<&[u8]> >, opt!( tag!( "abcd" ) ) );

 let a = b"abcdef";
 let b = b"bcdefg";
 assert_eq!(o(&a[..]), Ok((&b"ef"[..], Some(&b"abcd"[..]))));
 assert_eq!(o(&b[..]), Ok((&b"bcdefg"[..], None)));