mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-16 15:14:02 +00:00
Auto merge of #17471 - davidsemakula:fix-remove-parenthesis, r=Veykril
fix: don't remove parentheses for calls of function-like pointers that are members of a struct or union Fixes #17111
This commit is contained in:
commit
e0a400edd4
2 changed files with 37 additions and 0 deletions
|
@ -239,4 +239,33 @@ mod tests {
|
||||||
|
|
||||||
check_assist_not_applicable(remove_parentheses, r#"fn f() { $0(return 2) + 2 }"#);
|
check_assist_not_applicable(remove_parentheses, r#"fn f() { $0(return 2) + 2 }"#);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn remove_parens_indirect_calls() {
|
||||||
|
check_assist(
|
||||||
|
remove_parentheses,
|
||||||
|
r#"fn f(call: fn(usize), arg: usize) { $0(call)(arg); }"#,
|
||||||
|
r#"fn f(call: fn(usize), arg: usize) { call(arg); }"#,
|
||||||
|
);
|
||||||
|
check_assist(
|
||||||
|
remove_parentheses,
|
||||||
|
r#"fn f<F>(call: F, arg: usize) where F: Fn(usize) { $0(call)(arg); }"#,
|
||||||
|
r#"fn f<F>(call: F, arg: usize) where F: Fn(usize) { call(arg); }"#,
|
||||||
|
);
|
||||||
|
|
||||||
|
// Parentheses are necessary when calling a function-like pointer that is a member of a struct or union.
|
||||||
|
check_assist_not_applicable(
|
||||||
|
remove_parentheses,
|
||||||
|
r#"
|
||||||
|
struct Foo<T> {
|
||||||
|
t: T,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Foo<fn(usize)> {
|
||||||
|
fn foo(&self, arg: usize) {
|
||||||
|
$0(self.t)(arg);
|
||||||
|
}
|
||||||
|
}"#,
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,14 @@ impl Expr {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn needs_parens_in_expr(&self, parent: &Expr) -> bool {
|
fn needs_parens_in_expr(&self, parent: &Expr) -> bool {
|
||||||
|
// Parentheses are necessary when calling a function-like pointer that is a member of a struct or union
|
||||||
|
// (e.g. `(a.f)()`).
|
||||||
|
let is_parent_call_expr = matches!(parent, ast::Expr::CallExpr(_));
|
||||||
|
let is_field_expr = matches!(self, ast::Expr::FieldExpr(_));
|
||||||
|
if is_parent_call_expr && is_field_expr {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// Special-case block weirdness
|
// Special-case block weirdness
|
||||||
if parent.child_is_followed_by_a_block() {
|
if parent.child_is_followed_by_a_block() {
|
||||||
use Expr::*;
|
use Expr::*;
|
||||||
|
|
Loading…
Reference in a new issue