Macro nom::separated_list1 [−][src]
macro_rules! separated_list1 {
($i : expr, $submac : ident! ($($args : tt) *), $submac2 : ident!
($($args2 : tt) *)) => { ... };
($i : expr, $submac : ident! ($($args : tt) *), $g : expr) => { ... };
($i : expr, $f : expr, $submac : ident! ($($args : tt) *)) => { ... };
($i : expr, $f : expr, $g : expr) => { ... };
}
Expand description
separated_list1!(I -> IResult<I,T>, I -> IResult<I,O>) => I -> IResult<I, Vec<O>>
separated_list1(sep, X)
returns a Vec<X>
.
It will return an error if there is no element in the list.
use nom::multi::separated_list1;
use nom::bytes::complete::tag;
named!(parser<&str, Vec<&str>>, separated_list1!(tag("|"), tag("abc")));
assert_eq!(parser("abc|abc|abc"), Ok(("", vec!["abc", "abc", "abc"])));
assert_eq!(parser("abc123abc"), Ok(("123abc", vec!["abc"])));
assert_eq!(parser("abc|def"), Ok(("|def", vec!["abc"])));
assert_eq!(parser(""), Err(Err::Error(Error::new("", ErrorKind::Tag))));
assert_eq!(parser("def|abc"), Err(Err::Error(Error::new("def|abc", ErrorKind::Tag))));