Updated REPL loop to print back string-ified AST. Parser Complete!

This commit is contained in:
Ishan Jain 2020-01-20 18:10:07 +05:30
parent 0833ba3448
commit f3f50eed47
4 changed files with 33 additions and 22 deletions

View File

@ -86,10 +86,10 @@ impl Display for TokenType {
TokenType::True => "true", TokenType::True => "true",
TokenType::False => "false", TokenType::False => "false",
TokenType::Return => "return", TokenType::Return => "return",
_ => { TokenType::EOF => "EOF",
eprintln!("{:?}", self); TokenType::Illegal => "illegal",
unreachable!() TokenType::Ident => "ident",
} TokenType::Int => "int",
}) })
} }
} }

View File

@ -601,11 +601,10 @@ impl FunctionLiteral {
impl Display for FunctionLiteral { impl Display for FunctionLiteral {
fn fmt(&self, f: &mut Formatter) -> FmtResult { fn fmt(&self, f: &mut Formatter) -> FmtResult {
f.write_fmt(format_args!( f.write_fmt(format_args!(
"{} {}({}) {}", "{}({}) {{ {} }}",
self.token.name.to_string(), self.token.name,
self.token.literal.as_ref().unwrap(), self.parameters.iter().join(", "),
self.parameters.iter().join(","), self.body
""
)) ))
} }
} }

View File

@ -33,7 +33,7 @@ lazy_static! {
pub struct Parser<'a> { pub struct Parser<'a> {
lexer: Peekable<Lexer<'a>>, lexer: Peekable<Lexer<'a>>,
errors: Vec<Error>, pub errors: Vec<Error>,
prefix_parse_fns: HashMap<TokenType, PrefixParseFn>, prefix_parse_fns: HashMap<TokenType, PrefixParseFn>,
infix_parse_fns: HashMap<TokenType, InfixParseFn>, infix_parse_fns: HashMap<TokenType, InfixParseFn>,
} }

View File

@ -1,5 +1,8 @@
use crate::{lexer::Lexer, parser::Parser}; use crate::{
use std::io::{self, BufRead, Write}; lexer::Lexer,
parser::{Error as ParserError, Parser},
};
use std::io::{self, BufRead, Result as IoResult, Write};
const PROMPT: &[u8] = b">> "; const PROMPT: &[u8] = b">> ";
@ -18,19 +21,28 @@ fn start<R: BufRead, W: Write>(mut ip: R, mut out: W) {
out.flush().unwrap(); out.flush().unwrap();
let mut s = String::new(); let mut s = String::new();
ip.read_line(&mut s).unwrap(); ip.read_line(&mut s).unwrap();
let tokens = Lexer::new(&s); let tokens = Lexer::new(&s);
for token in tokens.clone() {
println!("{:?}", token);
}
let mut parser = Parser::new(tokens); let mut parser = Parser::new(tokens);
let program = parser.parse_program(); let program = parser.parse_program();
if !parser.errors.is_empty() {
match program { print_parser_errors(&mut out, &parser.errors).unwrap();
Some(stmts) => println!("{}", stmts), continue;
None => (),
} }
match program {
Some(prg) => {
for stmt in &prg.statements {
out.write_fmt(format_args!("{}\n", stmt)).unwrap();
}
}
None => (),
};
} }
} }
fn print_parser_errors<W: Write>(mut out: W, errors: &[ParserError]) -> IoResult<()> {
for error in errors {
out.write_fmt(format_args!("\t{}\n", error)).unwrap();
}
out.flush()
}