mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-01 07:48:45 +00:00
v2
This commit is contained in:
parent
35e0d800f0
commit
6f7460484a
1 changed files with 15 additions and 17 deletions
|
@ -1726,8 +1726,9 @@ fn make_body(
|
||||||
|
|
||||||
let block = match &fun.body {
|
let block = match &fun.body {
|
||||||
FunctionBody::Expr(expr) => {
|
FunctionBody::Expr(expr) => {
|
||||||
let expr = rewrite_body_segment(ctx, &fun.params, &handler, expr.syntax())?;
|
let expr = rewrite_body_segment(ctx, &fun.params, &handler, expr.syntax())
|
||||||
let expr = ast::Expr::cast(expr)?;
|
.expect("rewrite_body_segment failed.");
|
||||||
|
let expr = ast::Expr::cast(expr).expect("error while casting body segment to an expr.");
|
||||||
match expr {
|
match expr {
|
||||||
ast::Expr::BlockExpr(block) => {
|
ast::Expr::BlockExpr(block) => {
|
||||||
// If the extracted expression is itself a block, there is no need to wrap it inside another block.
|
// If the extracted expression is itself a block, there is no need to wrap it inside another block.
|
||||||
|
@ -1934,27 +1935,24 @@ fn fix_param_usages(
|
||||||
|
|
||||||
for (param, usages) in usages_for_param {
|
for (param, usages) in usages_for_param {
|
||||||
for usage in usages {
|
for usage in usages {
|
||||||
match usage.syntax().ancestors().skip(1).find_map(ast::Expr::cast) {
|
let expr = usage.syntax().ancestors().skip(1).find_map(ast::Expr::cast);
|
||||||
Some(ast::Expr::MethodCallExpr(_) | ast::Expr::FieldExpr(_)) => {
|
if let Some(ast::Expr::MethodCallExpr(_) | ast::Expr::FieldExpr(_)) = expr {
|
||||||
// do nothing
|
continue;
|
||||||
}
|
}
|
||||||
Some(ast::Expr::RefExpr(node))
|
|
||||||
if param.kind() == ParamKind::MutRef && node.mut_token().is_some() =>
|
if let Some(ast::Expr::RefExpr(node)) = expr {
|
||||||
|
if (param.kind() == ParamKind::MutRef && node.mut_token().is_some())
|
||||||
|
|| (param.kind() == ParamKind::SharedRef && node.mut_token().is_none())
|
||||||
{
|
{
|
||||||
ted::replace(node.syntax(), node.expr()?.syntax());
|
ted::replace(node.syntax(), node.expr()?.syntax());
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
Some(ast::Expr::RefExpr(node))
|
|
||||||
if param.kind() == ParamKind::SharedRef && node.mut_token().is_none() =>
|
|
||||||
{
|
|
||||||
ted::replace(node.syntax(), node.expr()?.syntax());
|
|
||||||
}
|
}
|
||||||
Some(_) | None => {
|
|
||||||
let p = &make::expr_prefix(T![*], usage.clone()).clone_for_update();
|
let p = &make::expr_prefix(T![*], usage.clone()).clone_for_update();
|
||||||
ted::replace(usage.syntax(), p.syntax())
|
ted::replace(usage.syntax(), p.syntax())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Some(res)
|
Some(res)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue