diff options
| author | Vadim Petrochenkov <vadim.petrochenkov@gmail.com> | 2019-08-25 20:41:52 +0300 |
|---|---|---|
| committer | Vadim Petrochenkov <vadim.petrochenkov@gmail.com> | 2019-08-25 21:23:17 +0300 |
| commit | 5b7df0922ef15a8b105aceda8770faedc58ec67b (patch) | |
| tree | 0dd1c3e67ddea576a649e76e948a0c2570dc65cc /src/libsyntax | |
| parent | d760df5aea483aae041c9a241e7acacf48f75035 (diff) | |
| download | rust-5b7df0922ef15a8b105aceda8770faedc58ec67b.tar.gz rust-5b7df0922ef15a8b105aceda8770faedc58ec67b.zip | |
pprust: Do not print spaces before some tokens
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/print/pprust.rs | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/src/libsyntax/print/pprust.rs b/src/libsyntax/print/pprust.rs index 4dc00af4860..83a926a6217 100644 --- a/src/libsyntax/print/pprust.rs +++ b/src/libsyntax/print/pprust.rs @@ -152,6 +152,18 @@ pub fn to_string<F>(f: F) -> String where printer.s.eof() } +// This makes comma-separated lists look slightly nicer, +// and also addresses a specific regression described in issue #63896. +fn tt_prepend_space(tt: &TokenTree) -> bool { + match tt { + TokenTree::Token(token) => match token.kind { + token::Comma => false, + _ => true, + } + _ => true, + } +} + fn binop_to_string(op: BinOpToken) -> &'static str { match op { token::Plus => "+", @@ -696,7 +708,7 @@ pub trait PrintState<'a>: std::ops::Deref<Target=pp::Printer> + std::ops::DerefM fn print_tts(&mut self, tts: tokenstream::TokenStream, convert_dollar_crate: bool) { for (i, tt) in tts.into_trees().enumerate() { - if i != 0 { + if i != 0 && tt_prepend_space(&tt) { self.space(); } self.print_tt(tt, convert_dollar_crate); |
