diff options
| author | bors <bors@rust-lang.org> | 2016-02-03 00:58:37 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2016-02-03 00:58:37 +0000 |
| commit | a9922419cf84a12b2b9c69f8b261cdd7c287c1a5 (patch) | |
| tree | 892a71c2d529580445b468a47d1b627ee5b8fbca /src/libsyntax | |
| parent | dea183aa8461e8520b08864ec81ad2985be36d34 (diff) | |
| parent | 1a21dabf27232c5c9281a6bf7a8b83afb3efa201 (diff) | |
| download | rust-a9922419cf84a12b2b9c69f8b261cdd7c287c1a5.tar.gz rust-a9922419cf84a12b2b9c69f8b261cdd7c287c1a5.zip | |
Auto merge of #31370 - Manishearth:rollup, r=Manishearth
- Successful merges: #27499, #31220, #31329, #31332, #31347, #31351, #31352, #31366 - Failed merges:
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/ast.rs | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/libsyntax/ast.rs b/src/libsyntax/ast.rs index 19bedab9d30..088f911ed8c 100644 --- a/src/libsyntax/ast.rs +++ b/src/libsyntax/ast.rs @@ -1174,6 +1174,20 @@ impl TokenTree { } (&TokenTree::Token(sp, token::DocComment(name)), _) => { let stripped = strip_doc_comment_decoration(&name.as_str()); + + // Searches for the occurrences of `"#*` and returns the minimum number of `#`s + // required to wrap the text. + let num_of_hashes = stripped.chars().scan(0, |cnt, x| { + *cnt = if x == '"' { + 1 + } else if *cnt != 0 && x == '#' { + *cnt + 1 + } else { + 0 + }; + Some(*cnt) + }).max().unwrap_or(0); + TokenTree::Delimited(sp, Rc::new(Delimited { delim: token::Bracket, open_span: sp, @@ -1181,7 +1195,7 @@ impl TokenTree { token::Plain)), TokenTree::Token(sp, token::Eq), TokenTree::Token(sp, token::Literal( - token::StrRaw(token::intern(&stripped), 0), None))], + token::StrRaw(token::intern(&stripped), num_of_hashes), None))], close_span: sp, })) } |
