diff --git a/crates/libeditor/src/completion.rs b/crates/libeditor/src/completion.rs index aeed195593..351781ec49 100644 --- a/crates/libeditor/src/completion.rs +++ b/crates/libeditor/src/completion.rs @@ -1,5 +1,7 @@ +use std::collections::HashMap; + use libsyntax2::{ - File, TextUnit, AstNode, SyntaxNodeRef, + File, TextUnit, AstNode, SyntaxNodeRef, SyntaxNode, SmolStr, ast::{self, NameOwner}, algo::{ ancestors, @@ -59,3 +61,52 @@ fn process_scope(node: SyntaxNodeRef, sink: &mut Vec) { sink.extend(items); } } + +// fn compute_scopes(fn_def: ast::FnDef) -> FnScopes { +// let mut scopes = FnScopes::new(); +// } + +// type ScopeId = usize; + +// struct FnScopes { +// scopes: Vec, +// scope_for_expr: HashMap, +// } + +// impl FnScopes { +// fn new() -> FnScopes { +// FnScopes { +// scopes: vec![], +// scope_for_expr: HashMap::new(), +// } +// } + +// fn new_scope(&mut Self) -> ScopeId { +// let res = self.scopes.len(); +// self.scopes.push(ScopeData { parent: None, entries: vec![] }) +// } + +// fn set_parent +// } + +// struct ScopeData { +// parent: Option, +// entries: Vec +// } + +// struct ScopeEntry { +// syntax: SyntaxNode +// } + +// impl ScopeEntry { +// fn name(&self) -> SmolStr { +// self.ast().name() +// .unwrap() +// .text() +// } + +// fn ast(&self) -> ast::BindPat { +// ast::BindPat::cast(self.syntax.borrowed()) +// .unwrap() +// } +// } diff --git a/crates/libsyntax2/src/grammar/patterns.rs b/crates/libsyntax2/src/grammar/patterns.rs index 11852e0d30..1149646518 100644 --- a/crates/libsyntax2/src/grammar/patterns.rs +++ b/crates/libsyntax2/src/grammar/patterns.rs @@ -2,7 +2,7 @@ use super::*; pub(super) const PATTERN_FIRST: TokenSet = token_set_union![ - token_set![REF_KW, MUT_KW, L_PAREN, L_BRACK, AMP], + token_set![REF_KW, MUT_KW, L_PAREN, L_BRACK, AMP, UNDERSCORE], expressions::LITERAL_FIRST, paths::PATH_FIRST, ]; @@ -97,7 +97,13 @@ fn tuple_pat_fields(p: &mut Parser) { while !p.at(EOF) && !p.at(R_PAREN) { match p.current() { DOTDOT => p.bump(), - _ => pattern(p), + _ => { + if !PATTERN_FIRST.contains(p.current()) { + p.error("expected a pattern"); + break; + } + pattern(p) + } } if !p.at(R_PAREN) { p.expect(COMMA); @@ -125,6 +131,7 @@ fn field_pat_list(p: &mut Parser) { p.bump(); pattern(p); } + L_CURLY => error_block(p, "expected ident"), _ => { bind_pat(p, false); } diff --git a/crates/libsyntax2/tests/data/parser/err/0018_incomplete_fn.rs b/crates/libsyntax2/tests/data/parser/err/0018_incomplete_fn.rs new file mode 100644 index 0000000000..fe604006c9 --- /dev/null +++ b/crates/libsyntax2/tests/data/parser/err/0018_incomplete_fn.rs @@ -0,0 +1,8 @@ +impl FnScopes { + fn new_scope(&) -> ScopeId { + let res = self.scopes.len(); + self.scopes.push(ScopeData { parent: None, entries: vec![] }) + } + + fn set_parent +} diff --git a/crates/libsyntax2/tests/data/parser/err/0018_incomplete_fn.txt b/crates/libsyntax2/tests/data/parser/err/0018_incomplete_fn.txt new file mode 100644 index 0000000000..3f3a7784b0 --- /dev/null +++ b/crates/libsyntax2/tests/data/parser/err/0018_incomplete_fn.txt @@ -0,0 +1,179 @@ +ROOT@[0; 183) + IMPL_ITEM@[0; 182) + IMPL_KW@[0; 4) + WHITESPACE@[4; 5) + PATH_TYPE@[5; 13) + PATH@[5; 13) + PATH_SEGMENT@[5; 13) + NAME_REF@[5; 13) + IDENT@[5; 13) "FnScopes" + WHITESPACE@[13; 14) + ITEM_LIST@[14; 182) + L_CURLY@[14; 15) + WHITESPACE@[15; 20) + FN_DEF@[20; 181) + FN_KW@[20; 22) + WHITESPACE@[22; 23) + NAME@[23; 32) + IDENT@[23; 32) "new_scope" + PARAM_LIST@[32; 181) + L_PAREN@[32; 33) + PARAM@[33; 38) + REF_PAT@[33; 35) + AMP@[33; 34) + err: `expected pattern` + ERROR@[34; 35) + R_PAREN@[34; 35) + err: `expected COLON` + WHITESPACE@[35; 36) + err: `expected type` + ERROR@[36; 38) + THIN_ARROW@[36; 38) + err: `expected COMMA` + WHITESPACE@[38; 39) + PARAM@[39; 169) + STRUCT_PAT@[39; 161) + PATH@[39; 46) + PATH_SEGMENT@[39; 46) + NAME_REF@[39; 46) + IDENT@[39; 46) "ScopeId" + WHITESPACE@[46; 47) + FIELD_PAT_LIST@[47; 161) + L_CURLY@[47; 48) + WHITESPACE@[48; 57) + err: `expected a name` + BIND_PAT@[57; 60) + ERROR@[57; 60) + LET_KW@[57; 60) + err: `expected COMMA` + WHITESPACE@[60; 61) + BIND_PAT@[61; 64) + NAME@[61; 64) + IDENT@[61; 64) "res" + err: `expected COMMA` + WHITESPACE@[64; 65) + err: `expected a name` + BIND_PAT@[65; 66) + ERROR@[65; 66) + EQ@[65; 66) + err: `expected COMMA` + WHITESPACE@[66; 67) + err: `expected a name` + BIND_PAT@[67; 71) + ERROR@[67; 71) + SELF_KW@[67; 71) + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[71; 72) + ERROR@[71; 72) + DOT@[71; 72) + err: `expected COMMA` + BIND_PAT@[72; 78) + NAME@[72; 78) + IDENT@[72; 78) "scopes" + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[78; 79) + ERROR@[78; 79) + DOT@[78; 79) + err: `expected COMMA` + BIND_PAT@[79; 82) + NAME@[79; 82) + IDENT@[79; 82) "len" + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[82; 83) + ERROR@[82; 83) + L_PAREN@[82; 83) + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[83; 84) + ERROR@[83; 84) + R_PAREN@[83; 84) + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[84; 85) + ERROR@[84; 85) + SEMI@[84; 85) + err: `expected COMMA` + WHITESPACE@[85; 94) + err: `expected a name` + BIND_PAT@[94; 98) + ERROR@[94; 98) + SELF_KW@[94; 98) + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[98; 99) + ERROR@[98; 99) + DOT@[98; 99) + err: `expected COMMA` + BIND_PAT@[99; 105) + NAME@[99; 105) + IDENT@[99; 105) "scopes" + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[105; 106) + ERROR@[105; 106) + DOT@[105; 106) + err: `expected COMMA` + BIND_PAT@[106; 110) + NAME@[106; 110) + IDENT@[106; 110) "push" + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[110; 111) + ERROR@[110; 111) + L_PAREN@[110; 111) + err: `expected COMMA` + BIND_PAT@[111; 120) + NAME@[111; 120) + IDENT@[111; 120) "ScopeData" + err: `expected COMMA` + WHITESPACE@[120; 121) + err: `expected ident` + ERROR@[121; 154) + L_CURLY@[121; 122) + WHITESPACE@[122; 123) + IDENT@[123; 129) "parent" + COLON@[129; 130) + WHITESPACE@[130; 131) + IDENT@[131; 135) "None" + COMMA@[135; 136) + WHITESPACE@[136; 137) + IDENT@[137; 144) "entries" + COLON@[144; 145) + WHITESPACE@[145; 146) + IDENT@[146; 149) "vec" + EXCL@[149; 150) + L_BRACK@[150; 151) + R_BRACK@[151; 152) + WHITESPACE@[152; 153) + R_CURLY@[153; 154) + err: `expected COMMA` + err: `expected a name` + BIND_PAT@[154; 155) + ERROR@[154; 155) + R_PAREN@[154; 155) + WHITESPACE@[155; 160) + R_CURLY@[160; 161) + err: `expected COLON` + WHITESPACE@[161; 167) + FN_POINTER_TYPE@[167; 169) + FN_KW@[167; 169) + err: `expected parameters` + err: `expected COMMA` + WHITESPACE@[169; 170) + PARAM@[170; 181) + BIND_PAT@[170; 180) + NAME@[170; 180) + IDENT@[170; 180) "set_parent" + err: `expected COLON` + WHITESPACE@[180; 181) + err: `expected type` + err: `expected COMMA` + err: `expected value parameter` + err: `expected R_PAREN` + err: `expected a block` + ERROR@[181; 181) + R_CURLY@[181; 182) + WHITESPACE@[182; 183)