fix: Don't escape \ and $ in "Extract format expressions" assist

This commit is contained in:
DropDemBits 2024-03-04 20:42:59 -05:00
parent 9f14343f9e
commit 1f37e5ac9a
No known key found for this signature in database
GPG key ID: 7FE02A6C1EDFA075
2 changed files with 23 additions and 17 deletions

View file

@ -270,6 +270,24 @@ fn main() {
fn main() { fn main() {
let var = 1 + 1; let var = 1 + 1;
print!("foobar {var} {var:?} {}"$0, x + x) print!("foobar {var} {var:?} {}"$0, x + x)
}
"#,
);
}
#[test]
fn escaped_literals() {
check_assist(
extract_expressions_from_format_string,
r#"
//- minicore: fmt
fn main() {
print!("\n$ {x + 1}$0");
}
"#,
r#"
fn main() {
print!("\n$ {}"$0, x + 1);
} }
"#, "#,
); );

View file

@ -79,9 +79,6 @@ pub fn parse_format_exprs(input: &str) -> Result<(String, Vec<Arg>), ()> {
state = State::MaybeIncorrect; state = State::MaybeIncorrect;
} }
(State::NotArg, _) => { (State::NotArg, _) => {
if matches!(chr, '\\' | '$') {
output.push('\\');
}
output.push(chr); output.push(chr);
} }
(State::MaybeIncorrect, '}') => { (State::MaybeIncorrect, '}') => {
@ -110,9 +107,6 @@ pub fn parse_format_exprs(input: &str) -> Result<(String, Vec<Arg>), ()> {
state = State::FormatOpts; state = State::FormatOpts;
} }
(State::MaybeArg, _) => { (State::MaybeArg, _) => {
if matches!(chr, '\\' | '$') {
current_expr.push('\\');
}
current_expr.push(chr); current_expr.push(chr);
// While Rust uses the unicode sets of XID_start and XID_continue for Identifiers // While Rust uses the unicode sets of XID_start and XID_continue for Identifiers
@ -172,9 +166,6 @@ pub fn parse_format_exprs(input: &str) -> Result<(String, Vec<Arg>), ()> {
state = State::Expr; state = State::Expr;
} }
if matches!(chr, '\\' | '$') {
current_expr.push('\\');
}
current_expr.push(chr); current_expr.push(chr);
} }
(State::FormatOpts, '}') => { (State::FormatOpts, '}') => {
@ -182,9 +173,6 @@ pub fn parse_format_exprs(input: &str) -> Result<(String, Vec<Arg>), ()> {
state = State::NotArg; state = State::NotArg;
} }
(State::FormatOpts, _) => { (State::FormatOpts, _) => {
if matches!(chr, '\\' | '$') {
output.push('\\');
}
output.push(chr); output.push(chr);
} }
} }
@ -217,15 +205,15 @@ mod tests {
fn format_str_parser() { fn format_str_parser() {
let test_vector = &[ let test_vector = &[
("no expressions", expect![["no expressions"]]), ("no expressions", expect![["no expressions"]]),
(r"no expressions with \$0$1", expect![r"no expressions with \\\$0\$1"]), (r"no expressions with \$0$1", expect![r"no expressions with \$0$1"]),
("{expr} is {2 + 2}", expect![["{expr} is {}; 2 + 2"]]), ("{expr} is {2 + 2}", expect![["{expr} is {}; 2 + 2"]]),
("{expr:?}", expect![["{expr:?}"]]), ("{expr:?}", expect![["{expr:?}"]]),
("{expr:1$}", expect![[r"{expr:1\$}"]]), ("{expr:1$}", expect![[r"{expr:1$}"]]),
("{:1$}", expect![[r"{:1\$}; $1"]]), ("{:1$}", expect![[r"{:1$}; $1"]]),
("{:>padding$}", expect![[r"{:>padding\$}; $1"]]), ("{:>padding$}", expect![[r"{:>padding$}; $1"]]),
("{}, {}, {0}", expect![[r"{}, {}, {0}; $1, $2"]]), ("{}, {}, {0}", expect![[r"{}, {}, {0}; $1, $2"]]),
("{}, {}, {0:b}", expect![[r"{}, {}, {0:b}; $1, $2"]]), ("{}, {}, {0:b}", expect![[r"{}, {}, {0:b}; $1, $2"]]),
("{$0}", expect![[r"{}; \$0"]]), ("{$0}", expect![[r"{}; $0"]]),
("{malformed", expect![["-"]]), ("{malformed", expect![["-"]]),
("malformed}", expect![["-"]]), ("malformed}", expect![["-"]]),
("{{correct", expect![["{{correct"]]), ("{{correct", expect![["{{correct"]]),