mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
parse empty statemet as statemetn
This commit is contained in:
parent
841cd30b45
commit
b5369927d7
4 changed files with 15 additions and 20 deletions
|
@ -85,17 +85,21 @@ fn stmt_boundaries() {
|
|||
check(
|
||||
r#"
|
||||
macro_rules! m {
|
||||
($($s:stmt)*) => (stringify!($($s |)*))
|
||||
($($s:stmt)*) => (stringify!($($s |)*);)
|
||||
}
|
||||
// +errors
|
||||
m!(;;92;let x = 92; loop {};);
|
||||
"#,
|
||||
expect![[r#"
|
||||
macro_rules! m {
|
||||
($($s:stmt)*) => (stringify!($($s |)*))
|
||||
($($s:stmt)*) => (stringify!($($s |)*);)
|
||||
}
|
||||
/* error: expected Stmt *//* parse error: expected SEMICOLON */
|
||||
stringify!()
|
||||
stringify!(;
|
||||
|;
|
||||
|92|;
|
||||
|let x = 92|;
|
||||
|loop {}
|
||||
|;
|
||||
|);
|
||||
"#]],
|
||||
);
|
||||
}
|
||||
|
|
|
@ -98,11 +98,6 @@ pub(crate) mod entry {
|
|||
let m = p.start();
|
||||
|
||||
while !p.at(EOF) {
|
||||
if p.at(T![;]) {
|
||||
p.bump(T![;]);
|
||||
continue;
|
||||
}
|
||||
|
||||
expressions::stmt(p, expressions::Semicolon::Optional);
|
||||
}
|
||||
|
||||
|
|
|
@ -30,6 +30,10 @@ fn expr_no_struct(p: &mut Parser) {
|
|||
}
|
||||
|
||||
pub(super) fn stmt(p: &mut Parser, semicolon: Semicolon) {
|
||||
if p.eat(T![;]) {
|
||||
return;
|
||||
}
|
||||
|
||||
let m = p.start();
|
||||
// test attr_on_expr_stmt
|
||||
// fn foo() {
|
||||
|
@ -143,12 +147,6 @@ pub(super) fn expr_block_contents(p: &mut Parser) {
|
|||
// fn f() {};
|
||||
// struct S {};
|
||||
// }
|
||||
|
||||
if p.at(T![;]) {
|
||||
p.bump(T![;]);
|
||||
continue;
|
||||
}
|
||||
|
||||
stmt(p, Semicolon::Required);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -76,8 +76,7 @@ impl<'a> LexedStr<'a> {
|
|||
builder.eat_trivias();
|
||||
(builder.sink)(StrStep::Exit);
|
||||
}
|
||||
State::PendingEnter => (),
|
||||
State::Normal => unreachable!(),
|
||||
State::PendingEnter | State::Normal => (),
|
||||
}
|
||||
|
||||
let is_eof = builder.pos == builder.lexed.len();
|
||||
|
@ -101,9 +100,8 @@ enum State {
|
|||
impl Builder<'_, '_> {
|
||||
fn token(&mut self, kind: SyntaxKind, n_tokens: u8) {
|
||||
match mem::replace(&mut self.state, State::Normal) {
|
||||
State::PendingEnter => unreachable!(),
|
||||
State::PendingExit => (self.sink)(StrStep::Exit),
|
||||
State::Normal => (),
|
||||
State::PendingEnter | State::Normal => (),
|
||||
}
|
||||
self.eat_trivias();
|
||||
self.do_token(kind, n_tokens as usize);
|
||||
|
|
Loading…
Reference in a new issue