]> git.lizzy.rs Git - rust.git/commitdiff
Merge empty delim subtree in proc-macro
authorEdwin Cheng <edwin0cheng@gmail.com>
Sat, 18 Apr 2020 11:29:04 +0000 (19:29 +0800)
committerEdwin Cheng <edwin0cheng@gmail.com>
Sat, 18 Apr 2020 11:29:04 +0000 (19:29 +0800)
crates/ra_proc_macro_srv/src/rustc_server.rs
crates/ra_proc_macro_srv/src/tests/fixtures/test_serialize_proc_macro.txt

index ec0d356922d0191cfbf436ea6e897a1f6248bc5f..9fcfdc4504c9fbec86e8f455db878338081da478 100644 (file)
@@ -76,7 +76,16 @@ fn extend<I: IntoIterator<Item = TokenTree>>(&mut self, trees: I) {
 impl Extend<TokenStream> for TokenStream {
     fn extend<I: IntoIterator<Item = TokenStream>>(&mut self, streams: I) {
         for item in streams {
-            self.subtree.token_trees.extend(&mut item.into_iter())
+            for tkn in item {
+                match tkn {
+                    tt::TokenTree::Subtree(subtree) if subtree.delimiter.is_none() => {
+                        self.subtree.token_trees.extend(subtree.token_trees);
+                    }
+                    _ => {
+                        self.subtree.token_trees.push(tkn);
+                    }
+                }
+            }
         }
     }
 }
index 24507d98d76f686b9372383c5bafec0eca2e4a32..1f5d940fa0bcfc844de88bb845626d43948bb94d 100644 (file)
@@ -25,8 +25,7 @@ SUBTREE $
       SUBTREE () 4294967295
         IDENT   feature 4294967295
         PUNCH   = [alone] 4294967295
-        SUBTREE $
-          LITERAL "cargo-clippy" 0
+        LITERAL "cargo-clippy" 0
         PUNCH   , [alone] 4294967295
         IDENT   allow 4294967295
         SUBTREE () 4294967295