From 7cdf990c40e932a466e8799ca3fa582467d32c91 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Fri, 2 Feb 2018 22:21:06 +0300 Subject: Move use item parsing to a separate file --- src/parser/event_parser/grammar/items/mod.rs | 73 +--------------------------- 1 file changed, 2 insertions(+), 71 deletions(-) (limited to 'src/parser/event_parser/grammar/items/mod.rs') diff --git a/src/parser/event_parser/grammar/items/mod.rs b/src/parser/event_parser/grammar/items/mod.rs index a6d8f375c..1c092779b 100644 --- a/src/parser/event_parser/grammar/items/mod.rs +++ b/src/parser/event_parser/grammar/items/mod.rs @@ -1,6 +1,7 @@ use super::*; mod structs; +mod use_item; pub(super) fn mod_contents(p: &mut Parser, stop_on_r_curly: bool) { attributes::inner_attributes(p); @@ -20,7 +21,7 @@ fn item(p: &mut Parser) { let la = p.nth(1); let item_kind = match p.current() { USE_KW => { - use_item(p); + use_item::use_item(p); USE_ITEM } EXTERN_KW if la == CRATE_KW => { @@ -179,76 +180,6 @@ fn extern_block(p: &mut Parser) { p.expect(R_CURLY); } -pub(super) fn is_use_tree_start(kind: SyntaxKind) -> bool { - kind == STAR || kind == L_CURLY -} - -fn use_item(p: &mut Parser) { - assert!(p.at(USE_KW)); - p.bump(); - - use_tree(p); - p.expect(SEMI); - - fn use_tree(p: &mut Parser) { - let la = p.nth(1); - let m = p.start(); - match (p.current(), la) { - (STAR, _) => p.bump(), - (COLONCOLON, STAR) => { - p.bump(); - p.bump(); - } - (L_CURLY, _) | (COLONCOLON, L_CURLY) => { - if p.at(COLONCOLON) { - p.bump(); - } - nested_trees(p); - } - _ if paths::is_path_start(p) => { - paths::use_path(p); - match p.current() { - AS_KW => { - alias(p); - } - COLONCOLON => { - p.bump(); - match p.current() { - STAR => { - p.bump(); - } - L_CURLY => nested_trees(p), - _ => { - // is this unreachable? - p.error().message("expected `{` or `*`").emit(); - } - } - } - _ => (), - } - } - _ => { - m.abandon(p); - p.err_and_bump("expected one of `*`, `::`, `{`, `self`, `super`, `indent`"); - return; - } - } - m.complete(p, USE_TREE); - } - - fn nested_trees(p: &mut Parser) { - assert!(p.at(L_CURLY)); - p.bump(); - while !p.at(EOF) && !p.at(R_CURLY) { - use_tree(p); - if !p.at(R_CURLY) { - p.expect(COMMA); - } - } - p.expect(R_CURLY); - } -} - fn abi(p: &mut Parser) { assert!(p.at(EXTERN_KW)); let abi = p.start(); -- cgit v1.2.3