This commit is contained in:
Aleksey Kladov 2020-04-03 15:44:06 +02:00
parent 795b8cf9c5
commit 0e46ed8420
2 changed files with 13 additions and 14 deletions

View file

@ -79,8 +79,6 @@ fn is_expr_stmt_attr_allowed(kind: SyntaxKind) -> bool {
} }
pub(super) fn stmt(p: &mut Parser, with_semi: StmtWithSemi) { pub(super) fn stmt(p: &mut Parser, with_semi: StmtWithSemi) {
// test block_items
// fn a() { fn b() {} }
let m = p.start(); let m = p.start();
// test attr_on_expr_stmt // test attr_on_expr_stmt
// fn foo() { // fn foo() {
@ -97,6 +95,8 @@ pub(super) fn stmt(p: &mut Parser, with_semi: StmtWithSemi) {
return; return;
} }
// test block_items
// fn a() { fn b() {} }
let m = match items::maybe_item(p, m, items::ItemFlavor::Mod) { let m = match items::maybe_item(p, m, items::ItemFlavor::Mod) {
Ok(()) => return, Ok(()) => return,
Err(m) => m, Err(m) => m,

View file

@ -70,15 +70,6 @@ fn pattern_single_r(p: &mut Parser, recovery_set: TokenSet) {
return; return;
} }
} }
// test marco_pat
// fn main() {
// let m!(x) = 0;
// }
if lhs.kind() == PATH_PAT && p.at(T![!]) {
let m = lhs.undo_completion(p);
items::macro_call_after_excl(p);
m.complete(p, MACRO_CALL);
}
} }
} }
@ -92,12 +83,12 @@ fn atom_pat(p: &mut Parser, recovery_set: TokenSet) -> Option<CompletedMarker> {
IDENT => match p.nth(1) { IDENT => match p.nth(1) {
// Checks the token after an IDENT to see if a pattern is a path (Struct { .. }) or macro // Checks the token after an IDENT to see if a pattern is a path (Struct { .. }) or macro
// (T![x]). // (T![x]).
T!['('] | T!['{'] | T![!] => path_pat(p), T!['('] | T!['{'] | T![!] => path_or_macro_pat(p),
T![:] if p.nth_at(1, T![::]) => path_pat(p), T![:] if p.nth_at(1, T![::]) => path_pat(p),
_ => bind_pat(p, true), _ => bind_pat(p, true),
}, },
_ if paths::is_use_path_start(p) => path_pat(p), _ if paths::is_use_path_start(p) => path_or_macro_pat(p),
_ if is_literal_pat_start(p) => literal_pat(p), _ if is_literal_pat_start(p) => literal_pat(p),
T![.] if p.at(T![..]) => dot_dot_pat(p), T![.] if p.at(T![..]) => dot_dot_pat(p),
@ -146,7 +137,7 @@ fn literal_pat(p: &mut Parser) -> CompletedMarker {
// let Bar { .. } = (); // let Bar { .. } = ();
// let Bar(..) = (); // let Bar(..) = ();
// } // }
fn path_pat(p: &mut Parser) -> CompletedMarker { fn path_or_macro_pat(p: &mut Parser) -> CompletedMarker {
assert!(paths::is_use_path_start(p)); assert!(paths::is_use_path_start(p));
let m = p.start(); let m = p.start();
paths::expr_path(p); paths::expr_path(p);
@ -159,6 +150,14 @@ fn path_pat(p: &mut Parser) -> CompletedMarker {
record_field_pat_list(p); record_field_pat_list(p);
RECORD_PAT RECORD_PAT
} }
// test marco_pat
// fn main() {
// let m!(x) = 0;
// }
T![!] => {
items::macro_call_after_excl(p);
MACRO_CALL
}
_ => PATH_PAT, _ => PATH_PAT,
}; };
m.complete(p, kind) m.complete(p, kind)