fix curly braces parsing

This commit is contained in:
Aleksey Kladov 2018-08-26 19:04:44 +03:00
parent 71722c047f
commit 9b69c7df19
4 changed files with 248 additions and 3 deletions

View file

@ -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<CompletionItem>) {
sink.extend(items);
}
}
// fn compute_scopes(fn_def: ast::FnDef) -> FnScopes {
// let mut scopes = FnScopes::new();
// }
// type ScopeId = usize;
// struct FnScopes {
// scopes: Vec<ScopeData>,
// scope_for_expr: HashMap<SyntaxNode, ScopeId>,
// }
// 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<ScopeId>,
// entries: Vec<ScopeEntry>
// }
// 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()
// }
// }

View file

@ -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);
}

View file

@ -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
}

View file

@ -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)