From de7b1887ae46c78c3c0abf6d264b2649b1b5cf0b Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Wed, 8 Aug 2018 18:13:30 +0300 Subject: Introduce param falvor --- src/grammar/params.rs | 56 ++++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 44 insertions(+), 12 deletions(-) (limited to 'src/grammar') diff --git a/src/grammar/params.rs b/src/grammar/params.rs index 034542df1..c7f17168b 100644 --- a/src/grammar/params.rs +++ b/src/grammar/params.rs @@ -6,35 +6,67 @@ use super::*; // fn c(x: i32, ) {} // fn d(x: i32, y: ()) {} pub(super) fn param_list(p: &mut Parser) { - list_(p, true) + list_(p, Flavor::Normal) +} + +// test param_list_opt_patterns +// fn foo)>(){} +pub(super) fn param_list_opt_patterns(p: &mut Parser) { + list_(p, Flavor::OptionalPattern) } pub(super) fn param_list_opt_types(p: &mut Parser) { - list_(p, false) + list_(p, Flavor::OptionalType) +} + +#[derive(Clone, Copy, Eq, PartialEq)] +enum Flavor { + OptionalType, + OptionalPattern, + Normal, } -fn list_(p: &mut Parser, require_types: bool) { - assert!(p.at(if require_types { L_PAREN } else { PIPE })); +impl Flavor { + fn type_required(self) -> bool { + match self { + Flavor::OptionalType => false, + _ => true, + } + } + fn pattern_required(self) -> bool { + match self { + Flavor::OptionalPattern => false, + _ => true, + } + } +} + +fn list_(p: &mut Parser, flavor: Flavor) { + let (bra, ket) = if flavor.type_required() { + (L_PAREN, R_PAREN) + } else { + (PIPE, PIPE) + }; + assert!(p.at(bra)); let m = p.start(); p.bump(); - if require_types { + if flavor.type_required() { self_param(p); } - let terminator = if require_types { R_PAREN } else { PIPE }; - while !p.at(EOF) && !p.at(terminator) { - value_parameter(p, require_types); - if !p.at(terminator) { + while !p.at(EOF) && !p.at(ket) { + value_parameter(p, flavor); + if !p.at(ket) { p.expect(COMMA); } } - p.expect(terminator); + p.expect(ket); m.complete(p, PARAM_LIST); } -fn value_parameter(p: &mut Parser, require_type: bool) { +fn value_parameter(p: &mut Parser, flavor: Flavor) { let m = p.start(); patterns::pattern(p); - if p.at(COLON) || require_type { + if p.at(COLON) || flavor.type_required() { types::ascription(p) } m.complete(p, PARAM); -- cgit v1.2.3