schala/src/main.rs

86 lines
2.0 KiB
Rust
Raw Normal View History

2015-07-16 02:55:03 -07:00
use std::io;
use std::io::Write;
use std::io::BufRead;
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};
use evaluate::{evaluate, Environment};
2015-07-22 03:02:55 -07:00
mod tokenizer;
2015-07-22 03:12:01 -07:00
mod parser;
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);
let mut env = Environment::new();
2015-07-16 02:55:03 -07:00
loop {
buf.clear();
2015-07-16 02:55:03 -07:00
print!(">> ");
stdout.flush().ok();
let line = stdin.lock().read_line(&mut buf);
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-31 01:38:35 -07:00
if handle_interpreter_directive(&buf, &env) {
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) {
ParseResult::Ok(ast) => {
println!("AST: {:?}", ast);
let (eval, new_env) = evaluate(ast, env);
println!("{}", eval);
env = new_env;
},
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-31 01:38:35 -07:00
fn handle_interpreter_directive(input: &str, env: &Environment) -> 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);
},
2015-07-31 01:38:35 -07:00
Some(s) if *s == ".env" => {
env.display();
},
Some(s) => {
println!("Unknown directive: {}", s);
},
None => () //should never happen
}
return true;
}