From d42cf5c7d0c1607f5676762c05c494b7250e76ae Mon Sep 17 00:00:00 2001 From: Erik Vesteraas Date: Sat, 19 Mar 2016 18:21:06 +0100 Subject: [PATCH] Don't consume list separator prematurely --- src/macros.rs | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/src/macros.rs b/src/macros.rs index cbe7d9f96..97de0a36a 100644 --- a/src/macros.rs +++ b/src/macros.rs @@ -1887,11 +1887,10 @@ macro_rules! separated_list( if i2.len() == input.len() { break; } - input = i2; // get the element next - if let $crate::IResult::Done(i3,o3) = $submac!(input, $($args2)*) { - if i3.len() == input.len() { + if let $crate::IResult::Done(i3,o3) = $submac!(i2, $($args2)*) { + if i3.len() == i2.len() { break; } res.push(o3); @@ -1945,10 +1944,9 @@ macro_rules! separated_nonempty_list( if i2.len() == input.len() { break; } - input = i2; - if let $crate::IResult::Done(i3,o3) = $submac!(input, $($args2)*) { - if i3.len() == input.len() { + if let $crate::IResult::Done(i3,o3) = $submac!(i2, $($args2)*) { + if i3.len() == i2.len() { break; } res.push(o3); @@ -2299,7 +2297,7 @@ macro_rules! count_fixed ( if cnt == $count { ret = $crate::IResult::Done(input, res); break; } - + match $submac!(input, $($args)*) { $crate::IResult::Done(i,o) => { res[cnt] = o; @@ -3206,6 +3204,7 @@ mod tests { let b = &b"abcd,abcdef"[..]; let c = &b"azerty"[..]; let d = &b",,abc"[..]; + let e = &b"abcd,abcd,ef"[..]; let res1 = vec![&b"abcd"[..]]; assert_eq!(multi(a), Done(&b"ef"[..], res1)); @@ -3213,6 +3212,10 @@ mod tests { assert_eq!(multi(b), Done(&b"ef"[..], res2)); assert_eq!(multi(c), Done(&b"azerty"[..], Vec::new())); assert_eq!(multi_empty(d), Error(Position(ErrorKind::SeparatedList, d))); + let res3 = vec![&b""[..], &b""[..], &b""[..]]; + //assert_eq!(multi_empty(d), Done(&b"abc"[..], res3)); + let res4 = vec![&b"abcd"[..], &b"abcd"[..]]; + assert_eq!(multi(e), Done(&b",ef"[..], res4)); } #[test] @@ -3222,12 +3225,15 @@ mod tests { let a = &b"abcdef"[..]; let b = &b"abcd,abcdef"[..]; let c = &b"azerty"[..]; + let d = &b"abcd,abcd,ef"[..]; let res1 = vec![&b"abcd"[..]]; assert_eq!(multi(a), Done(&b"ef"[..], res1)); let res2 = vec![&b"abcd"[..], &b"abcd"[..]]; assert_eq!(multi(b), Done(&b"ef"[..], res2)); assert_eq!(multi(c), Error(Position(ErrorKind::Tag,c))); + let res3 = vec![&b"abcd"[..], &b"abcd"[..]]; + assert_eq!(multi(d), Done(&b",ef"[..], res3)); } #[test]