mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-16 07:03:57 +00:00
fix: Don't escape \
and $
in "Extract format expressions" assist
This commit is contained in:
parent
9f14343f9e
commit
1f37e5ac9a
2 changed files with 23 additions and 17 deletions
|
@ -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);
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
);
|
);
|
||||||
|
|
|
@ -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"]]),
|
||||||
|
|
Loading…
Reference in a new issue