diff options
Diffstat (limited to 'crates/ra_mbe')
-rw-r--r-- | crates/ra_mbe/src/lib.rs | 19 | ||||
-rw-r--r-- | crates/ra_mbe/src/mbe_expander.rs | 5 | ||||
-rw-r--r-- | crates/ra_mbe/src/subtree_parser.rs | 4 | ||||
-rw-r--r-- | crates/ra_mbe/src/tt_cursor.rs | 5 |
4 files changed, 33 insertions, 0 deletions
diff --git a/crates/ra_mbe/src/lib.rs b/crates/ra_mbe/src/lib.rs index 8e3167e55..d7462d09d 100644 --- a/crates/ra_mbe/src/lib.rs +++ b/crates/ra_mbe/src/lib.rs | |||
@@ -743,4 +743,23 @@ MACRO_ITEMS@[0; 40) | |||
743 | ); | 743 | ); |
744 | assert_expansion(&rules, "foo! { { 1; } }", "fn foo () {1 ;}"); | 744 | assert_expansion(&rules, "foo! { { 1; } }", "fn foo () {1 ;}"); |
745 | } | 745 | } |
746 | |||
747 | #[test] | ||
748 | fn test_meta() { | ||
749 | let rules = create_rules( | ||
750 | r#" | ||
751 | macro_rules! foo { | ||
752 | ($ i:meta) => ( | ||
753 | #[$ i] | ||
754 | fn bar() {} | ||
755 | ) | ||
756 | } | ||
757 | "#, | ||
758 | ); | ||
759 | assert_expansion( | ||
760 | &rules, | ||
761 | r#"foo! { cfg(target_os = "windows") }"#, | ||
762 | r#"# [cfg (target_os = "windows")] fn bar () {}"#, | ||
763 | ); | ||
764 | } | ||
746 | } | 765 | } |
diff --git a/crates/ra_mbe/src/mbe_expander.rs b/crates/ra_mbe/src/mbe_expander.rs index a74e477d6..6ada580cc 100644 --- a/crates/ra_mbe/src/mbe_expander.rs +++ b/crates/ra_mbe/src/mbe_expander.rs | |||
@@ -166,6 +166,11 @@ fn match_lhs(pattern: &crate::Subtree, input: &mut TtCursor) -> Result<Bindings, | |||
166 | input.eat_block().ok_or(ExpandError::UnexpectedToken)?.clone(); | 166 | input.eat_block().ok_or(ExpandError::UnexpectedToken)?.clone(); |
167 | res.inner.insert(text.clone(), Binding::Simple(block.into())); | 167 | res.inner.insert(text.clone(), Binding::Simple(block.into())); |
168 | } | 168 | } |
169 | "meta" => { | ||
170 | let meta = | ||
171 | input.eat_meta().ok_or(ExpandError::UnexpectedToken)?.clone(); | ||
172 | res.inner.insert(text.clone(), Binding::Simple(meta.into())); | ||
173 | } | ||
169 | "item" => { | 174 | "item" => { |
170 | let item = | 175 | let item = |
171 | input.eat_item().ok_or(ExpandError::UnexpectedToken)?.clone(); | 176 | input.eat_item().ok_or(ExpandError::UnexpectedToken)?.clone(); |
diff --git a/crates/ra_mbe/src/subtree_parser.rs b/crates/ra_mbe/src/subtree_parser.rs index 2b11186c4..5d5557113 100644 --- a/crates/ra_mbe/src/subtree_parser.rs +++ b/crates/ra_mbe/src/subtree_parser.rs | |||
@@ -50,6 +50,10 @@ impl<'a> Parser<'a> { | |||
50 | self.parse(ra_parser::parse_block) | 50 | self.parse(ra_parser::parse_block) |
51 | } | 51 | } |
52 | 52 | ||
53 | pub fn parse_meta(self) -> Option<tt::TokenTree> { | ||
54 | self.parse(ra_parser::parse_meta) | ||
55 | } | ||
56 | |||
53 | pub fn parse_item(self) -> Option<tt::TokenTree> { | 57 | pub fn parse_item(self) -> Option<tt::TokenTree> { |
54 | self.parse(ra_parser::parse_item) | 58 | self.parse(ra_parser::parse_item) |
55 | } | 59 | } |
diff --git a/crates/ra_mbe/src/tt_cursor.rs b/crates/ra_mbe/src/tt_cursor.rs index d700aad69..04bb6b563 100644 --- a/crates/ra_mbe/src/tt_cursor.rs +++ b/crates/ra_mbe/src/tt_cursor.rs | |||
@@ -109,6 +109,11 @@ impl<'a> TtCursor<'a> { | |||
109 | parser.parse_block() | 109 | parser.parse_block() |
110 | } | 110 | } |
111 | 111 | ||
112 | pub(crate) fn eat_meta(&mut self) -> Option<tt::TokenTree> { | ||
113 | let parser = Parser::new(&mut self.pos, self.subtree); | ||
114 | parser.parse_meta() | ||
115 | } | ||
116 | |||
112 | pub(crate) fn eat_item(&mut self) -> Option<tt::TokenTree> { | 117 | pub(crate) fn eat_item(&mut self) -> Option<tt::TokenTree> { |
113 | let parser = Parser::new(&mut self.pos, self.subtree); | 118 | let parser = Parser::new(&mut self.pos, self.subtree); |
114 | parser.parse_item() | 119 | parser.parse_item() |