diff options
| author | bors <bors@rust-lang.org> | 2023-01-13 05:04:48 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2023-01-13 05:04:48 +0000 |
| commit | 279f1c9d8c26a8d227ae8ab806d262bb784b251b (patch) | |
| tree | 5df99150626d3bf61de660e12ab81cbc70bc009c /compiler/rustc_parse/src/parser/expr.rs | |
| parent | bfffe406fbcabb37b95779f2d252c4a277191e0d (diff) | |
| parent | 42a50bac319c0fc4fedf295fb1e606f015c48bb6 (diff) | |
| download | rust-279f1c9d8c26a8d227ae8ab806d262bb784b251b.tar.gz rust-279f1c9d8c26a8d227ae8ab806d262bb784b251b.zip | |
Auto merge of #106004 - fee1-dead-contrib:const-closures, r=oli-obk
Const closures cc https://github.com/rust-lang/rust/issues/106003
Diffstat (limited to 'compiler/rustc_parse/src/parser/expr.rs')
| -rw-r--r-- | compiler/rustc_parse/src/parser/expr.rs | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs index f5093fb02a8..dd2b03988c3 100644 --- a/compiler/rustc_parse/src/parser/expr.rs +++ b/compiler/rustc_parse/src/parser/expr.rs @@ -1325,7 +1325,10 @@ impl<'a> Parser<'a> { self.parse_array_or_repeat_expr(Delimiter::Bracket) } else if self.check_path() { self.parse_path_start_expr() - } else if self.check_keyword(kw::Move) || self.check_keyword(kw::Static) { + } else if self.check_keyword(kw::Move) + || self.check_keyword(kw::Static) + || self.check_const_closure() + { self.parse_closure_expr() } else if self.eat_keyword(kw::If) { self.parse_if_expr() @@ -2065,6 +2068,8 @@ impl<'a> Parser<'a> { ClosureBinder::NotPresent }; + let constness = self.parse_constness(Case::Sensitive); + let movability = if self.eat_keyword(kw::Static) { Movability::Static } else { Movability::Movable }; @@ -2111,6 +2116,7 @@ impl<'a> Parser<'a> { ExprKind::Closure(Box::new(ast::Closure { binder, capture_clause, + constness, asyncness, movability, fn_decl, |
