diff options
| author | GearsDatapacks <surya@seriousinfinitude.com> | 2023-12-12 15:20:29 +0000 |
|---|---|---|
| committer | GearsDatapacks <surya@seriousinfinitude.com> | 2023-12-14 18:11:18 +0000 |
| commit | 1fc6dbc32b0aba985af20e8eddfb05337f691dc5 (patch) | |
| tree | 4eed478d3591386c5d2593561b6fd346ceb94f6d /compiler | |
| parent | 2fdd9eda0ce4fa0ecbf3099783f4f505235ceb44 (diff) | |
| download | rust-1fc6dbc32b0aba985af20e8eddfb05337f691dc5.tar.gz rust-1fc6dbc32b0aba985af20e8eddfb05337f691dc5.zip | |
Change expr_trailing_brace to an exhaustive match to force new expression kinds to specify whether they contain a brace
Add inline const and other possible curly brace expressions to expr_trailing_brace Add tests for `}` before `else` in `let...else` error Change to explicit cases for expressions with optional values when being checked for trailing braces Add tests for more complex cases of `}` before `else` in `let..else` statement Move other possible `}` cases into separate arm and add FIXME for future reference
Diffstat (limited to 'compiler')
| -rw-r--r-- | compiler/rustc_ast/src/util/classify.rs | 35 |
1 files changed, 32 insertions, 3 deletions
diff --git a/compiler/rustc_ast/src/util/classify.rs b/compiler/rustc_ast/src/util/classify.rs index 821fca6656c..4dece079783 100644 --- a/compiler/rustc_ast/src/util/classify.rs +++ b/compiler/rustc_ast/src/util/classify.rs @@ -40,15 +40,44 @@ pub fn expr_trailing_brace(mut expr: &ast::Expr) -> Option<&ast::Expr> { | Range(_, Some(e), _) | Ret(Some(e)) | Unary(_, e) - | Yield(Some(e)) => { + | Yield(Some(e)) + | Yeet(Some(e)) + | Become(e) => { expr = e; } Closure(closure) => { expr = &closure.body; } Gen(..) | Block(..) | ForLoop(..) | If(..) | Loop(..) | Match(..) | Struct(..) - | TryBlock(..) | While(..) => break Some(expr), - _ => break None, + | TryBlock(..) | While(..) | ConstBlock(_) => break Some(expr), + + // FIXME: These can end in `}`, but changing these would break stable code. + InlineAsm(_) | OffsetOf(_, _) | MacCall(_) | IncludedBytes(_) | FormatArgs(_) => { + break None; + } + + Break(_, None) + | Range(_, None, _) + | Ret(None) + | Yield(None) + | Array(_) + | Call(_, _) + | MethodCall(_) + | Tup(_) + | Lit(_) + | Cast(_, _) + | Type(_, _) + | Await(_, _) + | Field(_, _) + | Index(_, _, _) + | Underscore + | Path(_, _) + | Continue(_) + | Repeat(_, _) + | Paren(_) + | Try(_) + | Yeet(None) + | Err => break None, } } } |
