mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-26 11:55:04 +00:00
better pattern recovery
This commit is contained in:
parent
537ea620bb
commit
dea6ed73fa
6 changed files with 92 additions and 8 deletions
|
@ -13,6 +13,8 @@ impl ModuleScope {
|
||||||
ast::ModuleItem::StructDef(item) => Entry::new(item),
|
ast::ModuleItem::StructDef(item) => Entry::new(item),
|
||||||
ast::ModuleItem::EnumDef(item) => Entry::new(item),
|
ast::ModuleItem::EnumDef(item) => Entry::new(item),
|
||||||
ast::ModuleItem::FnDef(item) => Entry::new(item),
|
ast::ModuleItem::FnDef(item) => Entry::new(item),
|
||||||
|
ast::ModuleItem::ConstDef(item) => Entry::new(item),
|
||||||
|
ast::ModuleItem::StaticDef(item) => Entry::new(item),
|
||||||
ast::ModuleItem::TraitDef(item) => Entry::new(item),
|
ast::ModuleItem::TraitDef(item) => Entry::new(item),
|
||||||
ast::ModuleItem::ExternCrateItem(_) |
|
ast::ModuleItem::ExternCrateItem(_) |
|
||||||
ast::ModuleItem::ImplItem(_) |
|
ast::ModuleItem::ImplItem(_) |
|
||||||
|
|
|
@ -893,6 +893,8 @@ pub enum ModuleItem<'a> {
|
||||||
ImplItem(ImplItem<'a>),
|
ImplItem(ImplItem<'a>),
|
||||||
UseItem(UseItem<'a>),
|
UseItem(UseItem<'a>),
|
||||||
ExternCrateItem(ExternCrateItem<'a>),
|
ExternCrateItem(ExternCrateItem<'a>),
|
||||||
|
ConstDef(ConstDef<'a>),
|
||||||
|
StaticDef(StaticDef<'a>),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> AstNode<'a> for ModuleItem<'a> {
|
impl<'a> AstNode<'a> for ModuleItem<'a> {
|
||||||
|
@ -905,6 +907,8 @@ impl<'a> AstNode<'a> for ModuleItem<'a> {
|
||||||
IMPL_ITEM => Some(ModuleItem::ImplItem(ImplItem { syntax })),
|
IMPL_ITEM => Some(ModuleItem::ImplItem(ImplItem { syntax })),
|
||||||
USE_ITEM => Some(ModuleItem::UseItem(UseItem { syntax })),
|
USE_ITEM => Some(ModuleItem::UseItem(UseItem { syntax })),
|
||||||
EXTERN_CRATE_ITEM => Some(ModuleItem::ExternCrateItem(ExternCrateItem { syntax })),
|
EXTERN_CRATE_ITEM => Some(ModuleItem::ExternCrateItem(ExternCrateItem { syntax })),
|
||||||
|
CONST_DEF => Some(ModuleItem::ConstDef(ConstDef { syntax })),
|
||||||
|
STATIC_DEF => Some(ModuleItem::StaticDef(StaticDef { syntax })),
|
||||||
_ => None,
|
_ => None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -917,6 +921,8 @@ impl<'a> AstNode<'a> for ModuleItem<'a> {
|
||||||
ModuleItem::ImplItem(inner) => inner.syntax(),
|
ModuleItem::ImplItem(inner) => inner.syntax(),
|
||||||
ModuleItem::UseItem(inner) => inner.syntax(),
|
ModuleItem::UseItem(inner) => inner.syntax(),
|
||||||
ModuleItem::ExternCrateItem(inner) => inner.syntax(),
|
ModuleItem::ExternCrateItem(inner) => inner.syntax(),
|
||||||
|
ModuleItem::ConstDef(inner) => inner.syntax(),
|
||||||
|
ModuleItem::StaticDef(inner) => inner.syntax(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -334,7 +334,7 @@ Grammar(
|
||||||
),
|
),
|
||||||
"ModuleItem": (
|
"ModuleItem": (
|
||||||
enum: ["StructDef", "EnumDef", "FnDef", "TraitDef", "ImplItem",
|
enum: ["StructDef", "EnumDef", "FnDef", "TraitDef", "ImplItem",
|
||||||
"UseItem", "ExternCrateItem" ]
|
"UseItem", "ExternCrateItem", "ConstDef", "StaticDef" ]
|
||||||
),
|
),
|
||||||
|
|
||||||
"TupleExpr": (),
|
"TupleExpr": (),
|
||||||
|
|
|
@ -22,6 +22,10 @@ pub(super) fn pattern(p: &mut Parser) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const PAT_RECOVERY_SET: TokenSet =
|
||||||
|
token_set![LET_KW, IF_KW, WHILE_KW, LOOP_KW, MATCH_KW];
|
||||||
|
|
||||||
|
|
||||||
fn atom_pat(p: &mut Parser) -> Option<CompletedMarker> {
|
fn atom_pat(p: &mut Parser) -> Option<CompletedMarker> {
|
||||||
let la0 = p.nth(0);
|
let la0 = p.nth(0);
|
||||||
let la1 = p.nth(1);
|
let la1 = p.nth(1);
|
||||||
|
@ -52,7 +56,7 @@ fn atom_pat(p: &mut Parser) -> Option<CompletedMarker> {
|
||||||
L_PAREN => tuple_pat(p),
|
L_PAREN => tuple_pat(p),
|
||||||
L_BRACK => slice_pat(p),
|
L_BRACK => slice_pat(p),
|
||||||
_ => {
|
_ => {
|
||||||
p.err_and_bump("expected pattern");
|
p.err_recover("expected pattern", PAT_RECOVERY_SET);
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,4 +1,12 @@
|
||||||
fn foo() {
|
fn foo() {
|
||||||
let foo =
|
let foo =
|
||||||
let bar = 1;
|
let bar = 1;
|
||||||
|
let
|
||||||
|
let baz = 92;
|
||||||
|
let
|
||||||
|
if true {}
|
||||||
|
let
|
||||||
|
while true {}
|
||||||
|
let
|
||||||
|
loop {}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
ROOT@[0; 44)
|
ROOT@[0; 139)
|
||||||
FN_DEF@[0; 43)
|
FN_DEF@[0; 138)
|
||||||
FN_KW@[0; 2)
|
FN_KW@[0; 2)
|
||||||
WHITESPACE@[2; 3)
|
WHITESPACE@[2; 3)
|
||||||
NAME@[3; 6)
|
NAME@[3; 6)
|
||||||
|
@ -8,7 +8,7 @@ ROOT@[0; 44)
|
||||||
L_PAREN@[6; 7)
|
L_PAREN@[6; 7)
|
||||||
R_PAREN@[7; 8)
|
R_PAREN@[7; 8)
|
||||||
WHITESPACE@[8; 9)
|
WHITESPACE@[8; 9)
|
||||||
BLOCK@[9; 43)
|
BLOCK@[9; 138)
|
||||||
L_CURLY@[9; 10)
|
L_CURLY@[9; 10)
|
||||||
WHITESPACE@[10; 15)
|
WHITESPACE@[10; 15)
|
||||||
LET_STMT@[15; 24)
|
LET_STMT@[15; 24)
|
||||||
|
@ -34,6 +34,70 @@ ROOT@[0; 44)
|
||||||
LITERAL@[39; 40)
|
LITERAL@[39; 40)
|
||||||
INT_NUMBER@[39; 40) "1"
|
INT_NUMBER@[39; 40) "1"
|
||||||
SEMI@[40; 41)
|
SEMI@[40; 41)
|
||||||
WHITESPACE@[41; 42)
|
WHITESPACE@[41; 46)
|
||||||
R_CURLY@[42; 43)
|
LET_STMT@[46; 49)
|
||||||
WHITESPACE@[43; 44)
|
LET_KW@[46; 49)
|
||||||
|
err: `expected pattern`
|
||||||
|
err: `expected SEMI`
|
||||||
|
WHITESPACE@[49; 54)
|
||||||
|
LET_STMT@[54; 67)
|
||||||
|
LET_KW@[54; 57)
|
||||||
|
WHITESPACE@[57; 58)
|
||||||
|
BIND_PAT@[58; 61)
|
||||||
|
NAME@[58; 61)
|
||||||
|
IDENT@[58; 61) "baz"
|
||||||
|
WHITESPACE@[61; 62)
|
||||||
|
EQ@[62; 63)
|
||||||
|
WHITESPACE@[63; 64)
|
||||||
|
LITERAL@[64; 66)
|
||||||
|
INT_NUMBER@[64; 66) "92"
|
||||||
|
SEMI@[66; 67)
|
||||||
|
WHITESPACE@[67; 72)
|
||||||
|
LET_STMT@[72; 75)
|
||||||
|
LET_KW@[72; 75)
|
||||||
|
err: `expected pattern`
|
||||||
|
err: `expected SEMI`
|
||||||
|
WHITESPACE@[75; 80)
|
||||||
|
EXPR_STMT@[80; 90)
|
||||||
|
IF_EXPR@[80; 90)
|
||||||
|
IF_KW@[80; 82)
|
||||||
|
WHITESPACE@[82; 83)
|
||||||
|
CONDITION@[83; 87)
|
||||||
|
LITERAL@[83; 87)
|
||||||
|
TRUE_KW@[83; 87)
|
||||||
|
WHITESPACE@[87; 88)
|
||||||
|
BLOCK@[88; 90)
|
||||||
|
L_CURLY@[88; 89)
|
||||||
|
R_CURLY@[89; 90)
|
||||||
|
WHITESPACE@[90; 95)
|
||||||
|
LET_STMT@[95; 98)
|
||||||
|
LET_KW@[95; 98)
|
||||||
|
err: `expected pattern`
|
||||||
|
err: `expected SEMI`
|
||||||
|
WHITESPACE@[98; 103)
|
||||||
|
EXPR_STMT@[103; 116)
|
||||||
|
WHILE_EXPR@[103; 116)
|
||||||
|
WHILE_KW@[103; 108)
|
||||||
|
WHITESPACE@[108; 109)
|
||||||
|
CONDITION@[109; 113)
|
||||||
|
LITERAL@[109; 113)
|
||||||
|
TRUE_KW@[109; 113)
|
||||||
|
WHITESPACE@[113; 114)
|
||||||
|
BLOCK@[114; 116)
|
||||||
|
L_CURLY@[114; 115)
|
||||||
|
R_CURLY@[115; 116)
|
||||||
|
WHITESPACE@[116; 121)
|
||||||
|
LET_STMT@[121; 124)
|
||||||
|
LET_KW@[121; 124)
|
||||||
|
err: `expected pattern`
|
||||||
|
err: `expected SEMI`
|
||||||
|
WHITESPACE@[124; 129)
|
||||||
|
LOOP_EXPR@[129; 136)
|
||||||
|
LOOP_KW@[129; 133)
|
||||||
|
WHITESPACE@[133; 134)
|
||||||
|
BLOCK@[134; 136)
|
||||||
|
L_CURLY@[134; 135)
|
||||||
|
R_CURLY@[135; 136)
|
||||||
|
WHITESPACE@[136; 137)
|
||||||
|
R_CURLY@[137; 138)
|
||||||
|
WHITESPACE@[138; 139)
|
||||||
|
|
Loading…
Reference in a new issue