Fix inline_const with interpolated block
This commit is contained in:
parent
11da267fdb
commit
719797949a
@ -1210,7 +1210,8 @@ fn parse_closure_constness(&mut self) -> Const {
|
||||
fn parse_constness_(&mut self, case: Case, is_closure: bool) -> Const {
|
||||
// Avoid const blocks and const closures to be parsed as const items
|
||||
if (self.check_const_closure() == is_closure)
|
||||
&& self.look_ahead(1, |t| t != &token::OpenDelim(Delimiter::Brace))
|
||||
&& !self
|
||||
.look_ahead(1, |t| *t == token::OpenDelim(Delimiter::Brace) || t.is_whole_block())
|
||||
&& self.eat_keyword_case(kw::Const, case)
|
||||
{
|
||||
Const::Yes(self.prev_token.uninterpolated_span())
|
||||
|
32
tests/ui/inline-const/interpolated.rs
Normal file
32
tests/ui/inline-const/interpolated.rs
Normal file
@ -0,0 +1,32 @@
|
||||
// check-pass
|
||||
|
||||
#![feature(inline_const)]
|
||||
|
||||
// This used to be unsupported since the parser first tries to check if we have
|
||||
// any nested items, and then checks for statements (and expressions). The heuristic
|
||||
// that we were using to detect the beginning of a const item was incorrect, so
|
||||
// this used to fail.
|
||||
macro_rules! m {
|
||||
($b:block) => {
|
||||
fn foo() {
|
||||
const $b
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// This has worked since inline-consts were implemented, since the position that
|
||||
// the const block is located at doesn't support nested items (e.g. because
|
||||
// `let x = const X: u32 = 1;` is invalid), so there's no ambiguity parsing the
|
||||
// inline const.
|
||||
macro_rules! m2 {
|
||||
($b:block) => {
|
||||
fn foo2() {
|
||||
let _ = const $b;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
m!({});
|
||||
m2!({});
|
||||
|
||||
fn main() {}
|
Loading…
Reference in New Issue
Block a user