From a4b473226bd185e6a016b175bdee22901fafd7ce Mon Sep 17 00:00:00 2001 From: Jeff Muizelaar Date: Mon, 4 Feb 2019 20:18:53 -0500 Subject: [PATCH] mbe: Ensure repetition separator matches --- crates/ra_mbe/src/lib.rs | 24 ++++++++++++++++++++++++ crates/ra_mbe/src/mbe_expander.rs | 8 ++++++-- 2 files changed, 30 insertions(+), 2 deletions(-) diff --git a/crates/ra_mbe/src/lib.rs b/crates/ra_mbe/src/lib.rs index 6f719acbfb..2c8ad4429d 100644 --- a/crates/ra_mbe/src/lib.rs +++ b/crates/ra_mbe/src/lib.rs @@ -256,4 +256,28 @@ impl_froms!(TokenTree: Leaf, Subtree); assert_expansion(&rules, "foo! { eggs Baz }", "struct Baz ;"); } + #[test] + fn test_match_group_pattern_by_separator_token() { + let rules = create_rules( + r#" + macro_rules! foo { + ($ ($ i:ident),*) => ($ ( + mod $ i {} + )*); + ($ ($ i:ident)#*) => ($ ( + fn $ i() {} + )*); + ($ i:ident ,# $ j:ident) => ( + struct $ i; + struct $ j; + ) + } +"#, + ); + + assert_expansion(&rules, "foo! { foo, bar }", "mod foo {} mod bar {}"); + assert_expansion(&rules, "foo! { foo# bar }", "fn foo () {} fn bar () {}"); + assert_expansion(&rules, "foo! { Foo,# Bar }", "struct Foo ; struct Bar ;"); + } + } diff --git a/crates/ra_mbe/src/mbe_expander.rs b/crates/ra_mbe/src/mbe_expander.rs index 212e2ea92f..04b5a40352 100644 --- a/crates/ra_mbe/src/mbe_expander.rs +++ b/crates/ra_mbe/src/mbe_expander.rs @@ -140,8 +140,12 @@ fn match_lhs(pattern: &crate::Subtree, input: &mut TtCursor) -> Option }) => { while let Some(nested) = match_lhs(subtree, input) { res.push_nested(nested)?; - if separator.is_some() && !input.is_eof() { - input.eat_punct()?; + if let Some(separator) = *separator { + if !input.is_eof() { + if input.eat_punct()?.char != separator { + return None; + } + } } } }