From 6794d50a9bd516d1ba49416a57b04e619ecd7074 Mon Sep 17 00:00:00 2001 From: Edwin Cheng Date: Wed, 4 Mar 2020 23:38:58 +0800 Subject: Fixed whitespace bug --- crates/ra_mbe/src/syntax_bridge.rs | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'crates/ra_mbe/src/syntax_bridge.rs') diff --git a/crates/ra_mbe/src/syntax_bridge.rs b/crates/ra_mbe/src/syntax_bridge.rs index 2aaf0215f..d8ee74faa 100644 --- a/crates/ra_mbe/src/syntax_bridge.rs +++ b/crates/ra_mbe/src/syntax_bridge.rs @@ -388,11 +388,12 @@ impl<'a> TreeSink for TtTreeSink<'a> { return; } + let mut last = self.cursor; for _ in 0..n_tokens { if self.cursor.eof() { break; } - + last = self.cursor; let text: SmolStr = match self.cursor.token_tree() { Some(tt::TokenTree::Leaf(leaf)) => { // Mark the range if needed @@ -441,11 +442,11 @@ impl<'a> TreeSink for TtTreeSink<'a> { self.inner.token(kind, text); // Add whitespace between adjoint puncts - let next = self.cursor.bump(); + let next = last.bump(); if let ( Some(tt::TokenTree::Leaf(tt::Leaf::Punct(curr))), Some(tt::TokenTree::Leaf(tt::Leaf::Punct(_))), - ) = (self.cursor.token_tree(), next.token_tree()) + ) = (last.token_tree(), next.token_tree()) { if curr.spacing == tt::Spacing::Alone { self.inner.token(WHITESPACE, " ".into()); -- cgit v1.2.3