Rollup merge of #114913 - beetrees:escape-double-quote, r=davidtwco
Fix suggestion for attempting to define a string with single quotes Currently attempting to compile `fn main() { let _ = '\\"'; }` will result in the following error message: ``` error: character literal may only contain one codepoint --> src/main.rs:1:21 | 1 | fn main() { let _ = '\\"'; } | ^^^^^ | help: if you meant to write a `str` literal, use double quotes | 1 | fn main() { let _ = "\\""; } | ~~~~~ ``` The suggestion is invalid as it fails to escape the `"`. This PR fixes the suggestion so that it now reads: ``` help: if you meant to write a `str` literal, use double quotes | 1 | fn main() { let _ = "\\\""; } | ~~~~~~ ``` The relevant test is also updated to ensure that this does not regress in future.
This commit is contained in:
commit
7ea4de9632
4 changed files with 22 additions and 15 deletions
|
@ -80,20 +80,14 @@ pub(crate) fn emit_unescape_error(
|
|||
let sugg = sugg.unwrap_or_else(|| {
|
||||
let prefix = mode.prefix_noraw();
|
||||
let mut escaped = String::with_capacity(lit.len());
|
||||
let mut chrs = lit.chars().peekable();
|
||||
while let Some(first) = chrs.next() {
|
||||
match (first, chrs.peek()) {
|
||||
('\\', Some('"')) => {
|
||||
escaped.push('\\');
|
||||
escaped.push('"');
|
||||
chrs.next();
|
||||
}
|
||||
('"', _) => {
|
||||
escaped.push('\\');
|
||||
escaped.push('"')
|
||||
}
|
||||
(c, _) => escaped.push(c),
|
||||
};
|
||||
let mut in_escape = false;
|
||||
for c in lit.chars() {
|
||||
match c {
|
||||
'\\' => in_escape = !in_escape,
|
||||
'"' if !in_escape => escaped.push('\\'),
|
||||
_ => in_escape = false,
|
||||
}
|
||||
escaped.push(c);
|
||||
}
|
||||
let sugg = format!("{prefix}\"{escaped}\"");
|
||||
MoreThanOneCharSugg::Quotes {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue