diff options
Diffstat (limited to 'dhall/src')
-rw-r--r-- | dhall/src/parser.rs | 97 |
1 files changed, 55 insertions, 42 deletions
diff --git a/dhall/src/parser.rs b/dhall/src/parser.rs index 32923e4..47c520e 100644 --- a/dhall/src/parser.rs +++ b/dhall/src/parser.rs @@ -1,17 +1,19 @@ use std::collections::BTreeMap; // use itertools::*; use lalrpop_util; -use pest::Parser; use pest::iterators::Pair; +use pest::Parser; use dhall_parser::{DhallParser, Rule}; +use crate::core::{bx, Builtin, Const, Expr, V}; use crate::grammar; use crate::grammar_util::{BoxExpr, ParsedExpr}; use crate::lexer::{Lexer, LexicalError, Tok}; -use crate::core::{bx, Expr, Builtin, Const, V}; -pub fn parse_expr_lalrpop(s: &str) -> Result<BoxExpr, lalrpop_util::ParseError<usize, Tok, LexicalError>> { +pub fn parse_expr_lalrpop( + s: &str, +) -> Result<BoxExpr, lalrpop_util::ParseError<usize, Tok, LexicalError>> { grammar::ExprParser::new().parse(Lexer::new(s)) // Ok(bx(Expr::BoolLit(false))) } @@ -21,7 +23,7 @@ pub type ParseError = pest::error::Error<Rule>; pub type ParseResult<T> = Result<T, ParseError>; pub fn custom_parse_error(pair: &Pair<Rule>, msg: String) -> ParseError { - let e = pest::error::ErrorVariant::CustomError{ message: msg }; + let e = pest::error::ErrorVariant::CustomError { message: msg }; pest::error::Error::new_from_span(e, pair.as_span()) } @@ -43,13 +45,23 @@ fn debug_pair(pair: Pair<Rule>) -> String { aux(s, indent, prefix, p); continue; } else { - writeln!(s, r#"{}{}{:?}: "{}""#, indent_str, prefix, rule, contents).unwrap(); + writeln!( + s, + r#"{}{}{:?}: "{}""#, + indent_str, prefix, rule, contents + ) + .unwrap(); } } - aux(s, indent+1, "".into(), p); + aux(s, indent + 1, "".into(), p); } if first { - writeln!(s, r#"{}{}{:?}: "{}""#, indent_str, prefix, rule, contents).unwrap(); + writeln!( + s, + r#"{}{}{:?}: "{}""#, + indent_str, prefix, rule, contents + ) + .unwrap(); } } aux(&mut s, 0, "".into(), pair); @@ -148,8 +160,6 @@ macro_rules! match_iter { }; } - - macro_rules! named { ($name:ident<$o:ty>; $submac:ident!( $($args:tt)* )) => ( #[allow(unused_variables)] @@ -236,32 +246,26 @@ macro_rules! match_children { } macro_rules! with_captured_str { - ($pair:expr; $x:ident; $body:expr) => { - { - #[allow(unused_mut)] - let mut $x = $pair.as_str(); - Ok($body) - } - }; + ($pair:expr; $x:ident; $body:expr) => {{ + #[allow(unused_mut)] + let mut $x = $pair.as_str(); + Ok($body) + }}; } macro_rules! with_raw_pair { - ($pair:expr; $x:ident; $body:expr) => { - { - #[allow(unused_mut)] - let mut $x = $pair; - Ok($body) - } - }; + ($pair:expr; $x:ident; $body:expr) => {{ + #[allow(unused_mut)] + let mut $x = $pair; + Ok($body) + }}; } macro_rules! map { - ($pair:expr; $ty:ident; $f:expr) => { - { - let x = $ty($pair)?; - Ok($f(x)) - } - }; + ($pair:expr; $ty:ident; $f:expr) => {{ + let x = $ty($pair)?; + Ok($f(x)) + }}; } macro_rules! plain_value { @@ -305,7 +309,6 @@ macro_rules! match_rule { }; } - named!(eoi<()>; plain_value!(())); named!(str<&'a str>; with_captured_str!(s; { s.trim() })); @@ -509,13 +512,11 @@ named!(final_expression<BoxExpr<'a>>; match_children!((e: expression, _eoi: eoi) => e) ); - -pub fn parse_expr_pest(s: &str) -> ParseResult<BoxExpr> { +pub fn parse_expr_pest(s: &str) -> ParseResult<BoxExpr> { let pairs = DhallParser::parse(Rule::final_expression, s)?; match_iter!(pairs; (e) => final_expression(e)) } - #[test] fn test_parse() { use crate::core::Expr::*; @@ -527,7 +528,7 @@ fn test_parse() { Err(e) => { println!("{:?}", e); println!("{}", e); - }, + } ok => println!("{:?}", ok), } // assert_eq!(parse_expr_pest(expr).unwrap(), parse_expr_lalrpop(expr).unwrap()); @@ -536,15 +537,27 @@ fn test_parse() { println!("test {:?}", parse_expr_lalrpop("3 + 5 * 10")); assert!(parse_expr_lalrpop("22").is_ok()); assert!(parse_expr_lalrpop("(22)").is_ok()); - assert_eq!(parse_expr_lalrpop("3 + 5 * 10").ok(), - Some(Box::new(NaturalPlus(Box::new(NaturalLit(3)), - Box::new(NaturalTimes(Box::new(NaturalLit(5)), - Box::new(NaturalLit(10)))))))); + assert_eq!( + parse_expr_lalrpop("3 + 5 * 10").ok(), + Some(Box::new(NaturalPlus( + Box::new(NaturalLit(3)), + Box::new(NaturalTimes( + Box::new(NaturalLit(5)), + Box::new(NaturalLit(10)) + )) + ))) + ); // The original parser is apparently right-associative - assert_eq!(parse_expr_lalrpop("2 * 3 * 4").ok(), - Some(Box::new(NaturalTimes(Box::new(NaturalLit(2)), - Box::new(NaturalTimes(Box::new(NaturalLit(3)), - Box::new(NaturalLit(4)))))))); + assert_eq!( + parse_expr_lalrpop("2 * 3 * 4").ok(), + Some(Box::new(NaturalTimes( + Box::new(NaturalLit(2)), + Box::new(NaturalTimes( + Box::new(NaturalLit(3)), + Box::new(NaturalLit(4)) + )) + ))) + ); assert!(parse_expr_lalrpop("((((22))))").is_ok()); assert!(parse_expr_lalrpop("((22)").is_err()); println!("{:?}", parse_expr_lalrpop("\\(b : Bool) -> b == False")); |