use std::iter::Peekable; use std::slice::Iter; use std::vec::IntoIter; use tokenizer::Token; #[derive(Debug)] pub enum AST { BinOp(Box, Box, Box), Number(f64), Name(String), } #[derive(Debug)] pub struct ParseError { err: String } pub type ParseResult = Result; /* grammar expr : term ((PLUS|MIMUS) term)* term : factor ((MUL | DIV) factor)* factor : NUM | LPAREN expr RPAREN */ struct Parser { tokens: Peekable> } impl Parser { fn next(&mut self) -> Option { self.tokens.next() } fn lookahead(&mut self) -> Option<&Token> { self.tokens.peek() } } impl Parser { fn expect(&mut self, expected: Token) -> ParseResult<()> { match self.next() { Some(ref next) if *next == expected => Ok(()), Some(next) => { let err = format!("Expected {:?} but got {:?}", expected, next); return Err(ParseError { err: err }); }, None => { let err = format!("Expected {:?} but got end of input", expected); return Err(ParseError { err: err }); } } } fn parse(&mut self) -> ParseResult { let r = self.expr(); try!(self.expect(Token::Separator)); try!(self.expect(Token::EOF)); r } fn expr(&mut self) -> ParseResult { self.next(); return Ok(AST::Number(5.0)); } } pub fn parse(input: Vec) -> ParseResult { let mut iter = input.into_iter().peekable(); let mut parser = Parser { tokens: iter }; return parser.parse(); }