diff options
| author | roife <roifewu@gmail.com> | 2024-03-18 13:19:24 +0800 |
|---|---|---|
| committer | roife <roifewu@gmail.com> | 2024-03-18 13:29:14 +0800 |
| commit | 109344cfb756cabbafccd201b0e658e6a7287f05 (patch) | |
| tree | d33898aeb6c450598fbceb48edd00d3be4988e79 | |
| parent | 5ecace48f693afaa6adf8cb23086b651db3aec96 (diff) | |
| download | rust-109344cfb756cabbafccd201b0e658e6a7287f05.tar.gz rust-109344cfb756cabbafccd201b0e658e6a7287f05.zip | |
fix: handle attributes when typing curly bracket
| -rw-r--r-- | crates/ide/src/typing.rs | 33 |
1 files changed, 30 insertions, 3 deletions
diff --git a/crates/ide/src/typing.rs b/crates/ide/src/typing.rs index e87fc89fea2..d3eee0e02e4 100644 --- a/crates/ide/src/typing.rs +++ b/crates/ide/src/typing.rs @@ -175,9 +175,21 @@ fn on_opening_bracket_typed( } } - // If it's a statement in a block, we don't know how many statements should be included - if ast::ExprStmt::can_cast(expr.syntax().parent()?.kind()) { - return None; + if let Some(parent) = expr.syntax().parent().and_then(ast::Expr::cast) { + let mut node = expr.syntax().clone(); + let all_prev_sib_attr = loop { + match node.prev_sibling() { + Some(sib) if sib.kind().is_trivia() || sib.kind() == SyntaxKind::ATTR => { + node = sib + } + Some(_) => break false, + None => break true, + }; + }; + + if all_prev_sib_attr { + expr = parent; + } } // Insert the closing bracket right after the expression. @@ -827,6 +839,21 @@ fn f() { } "#, ); + type_char( + '{', + r#" +fn main() { + #[allow(unreachable_code)] + $0g(); +} + "#, + r#" +fn main() { + #[allow(unreachable_code)] + {g()}; +} + "#, + ); } #[test] |
