2015-07-16 02:55:03 -07:00
|
|
|
use std::io;
|
|
|
|
use std::io::Write;
|
|
|
|
use std::io::BufRead;
|
2015-07-24 03:08:54 -07:00
|
|
|
use std::process;
|
2015-07-22 02:26:46 -07:00
|
|
|
|
2015-07-22 03:12:01 -07:00
|
|
|
use tokenizer::tokenize;
|
|
|
|
use parser::{parse, ParseResult};
|
2015-07-29 00:52:17 -07:00
|
|
|
use evaluate::evaluate;
|
2015-07-22 03:02:55 -07:00
|
|
|
|
|
|
|
mod tokenizer;
|
2015-07-22 03:12:01 -07:00
|
|
|
mod parser;
|
2015-07-29 00:52:17 -07:00
|
|
|
mod evaluate;
|
2015-07-22 02:26:46 -07:00
|
|
|
|
2015-07-16 02:55:03 -07:00
|
|
|
|
2015-07-16 01:40:37 -07:00
|
|
|
fn main() {
|
2015-07-16 02:55:03 -07:00
|
|
|
println!("Unnamed language 0.01");
|
|
|
|
repl();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn repl() {
|
2015-07-19 16:53:37 -07:00
|
|
|
let stdin = io::stdin();
|
2015-07-16 02:55:03 -07:00
|
|
|
let mut stdout = io::stdout();
|
|
|
|
let mut buf = String::with_capacity(20);
|
|
|
|
loop {
|
2015-07-24 03:08:54 -07:00
|
|
|
buf.clear();
|
2015-07-16 02:55:03 -07:00
|
|
|
print!(">> ");
|
|
|
|
stdout.flush().ok();
|
|
|
|
let line = stdin.lock().read_line(&mut buf);
|
2015-07-24 03:08:54 -07:00
|
|
|
|
2015-07-16 02:55:03 -07:00
|
|
|
match line {
|
2015-07-19 16:53:37 -07:00
|
|
|
Ok(_) => {
|
2015-07-19 17:11:22 -07:00
|
|
|
if buf.is_empty() {
|
|
|
|
break;
|
|
|
|
}
|
2015-07-24 03:08:54 -07:00
|
|
|
|
|
|
|
if handle_interpreter_directive(&buf) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2015-07-18 14:50:26 -07:00
|
|
|
let tokens = tokenize(&buf);
|
|
|
|
println!("Tokens: {:?}", tokens);
|
|
|
|
|
2015-07-20 01:46:02 -07:00
|
|
|
match parse(tokens) {
|
2015-07-29 00:52:17 -07:00
|
|
|
ParseResult::Ok(ast) => {
|
|
|
|
println!("AST: {:?}", ast);
|
|
|
|
let eval = evaluate(ast);
|
|
|
|
println!("{}", eval);
|
|
|
|
},
|
2015-07-22 02:48:27 -07:00
|
|
|
ParseResult::Err(err) => println!("Error: {}", err)
|
2015-07-20 01:46:02 -07:00
|
|
|
}
|
2015-07-16 02:55:03 -07:00
|
|
|
},
|
|
|
|
Err(err) => {
|
|
|
|
println!("Error: {}", err);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-07-24 03:08:54 -07:00
|
|
|
|
|
|
|
fn handle_interpreter_directive(input: &str) -> bool {
|
|
|
|
|
|
|
|
match input.chars().nth(0) {
|
|
|
|
Some('.') => (),
|
|
|
|
_ => return false
|
|
|
|
}
|
|
|
|
|
|
|
|
let commands: Vec<&str> = input.split(|c: char| c.is_whitespace()).collect();
|
|
|
|
match commands.get(0) {
|
|
|
|
Some(s) if *s == ".quit" => {
|
|
|
|
println!("Siturei simasu");
|
|
|
|
process::exit(0);
|
|
|
|
},
|
|
|
|
Some(s) => {
|
|
|
|
println!("Unknown directive: {}", s);
|
|
|
|
},
|
|
|
|
None => () //should never happen
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|