mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-01 07:48:45 +00:00
Auto merge of #14092 - Veykril:inlay-hint-panic, r=Veykril
fix: Don't panic on broken syntax trees in adjustment inlay hints These should be unreachable, but apparently with broken enough syntax trees (I assume mismatched parens), we do reach these unreachable calls. Haven't quite figured out when this happens though.
This commit is contained in:
commit
e9d0bfc799
1 changed files with 14 additions and 8 deletions
|
@ -6,6 +6,7 @@
|
|||
use hir::{Adjust, Adjustment, AutoBorrow, HirDisplay, Mutability, PointerCast, Safety, Semantics};
|
||||
use ide_db::RootDatabase;
|
||||
|
||||
use stdx::never;
|
||||
use syntax::{
|
||||
ast::{self, make, AstNode},
|
||||
ted,
|
||||
|
@ -210,16 +211,21 @@ fn needs_parens_for_adjustment_hints(expr: &ast::Expr, postfix: bool) -> (bool,
|
|||
ted::replace(expr.syntax(), dummy_expr.syntax());
|
||||
|
||||
let parent = dummy_expr.syntax().parent();
|
||||
let expr = if postfix {
|
||||
let ast::Expr::TryExpr(e) = &dummy_expr else { unreachable!() };
|
||||
let Some(ast::Expr::ParenExpr(e)) = e.expr() else { unreachable!() };
|
||||
let Some(expr) = (|| {
|
||||
if postfix {
|
||||
let ast::Expr::TryExpr(e) = &dummy_expr else { return None };
|
||||
let Some(ast::Expr::ParenExpr(e)) = e.expr() else { return None };
|
||||
|
||||
e.expr().unwrap()
|
||||
} else {
|
||||
let ast::Expr::RefExpr(e) = &dummy_expr else { unreachable!() };
|
||||
let Some(ast::Expr::ParenExpr(e)) = e.expr() else { unreachable!() };
|
||||
e.expr()
|
||||
} else {
|
||||
let ast::Expr::RefExpr(e) = &dummy_expr else { return None };
|
||||
let Some(ast::Expr::ParenExpr(e)) = e.expr() else { return None };
|
||||
|
||||
e.expr().unwrap()
|
||||
e.expr()
|
||||
}
|
||||
})() else {
|
||||
never!("broken syntax tree?\n{:?}\n{:?}", expr, dummy_expr);
|
||||
return (true, true)
|
||||
};
|
||||
|
||||
// At this point
|
||||
|
|
Loading…
Reference in a new issue