From 892168833423a084a06f2be535080e61aa8ca134 Mon Sep 17 00:00:00 2001 From: Vincent Ambo Date: Thu, 4 Aug 2022 16:43:51 +0300 Subject: chore(tvix/eval): bootstrap some evaluator boilerplate Change-Id: I7770a20948d18a8506c2418dea21202aa21a6ddc Reviewed-on: https://cl.tvl.fyi/c/depot/+/6064 Tested-by: BuildkiteCI Reviewed-by: grfn --- tvix/eval/src/errors.rs | 12 ++++++++++++ tvix/eval/src/eval.rs | 5 +++++ tvix/eval/src/main.rs | 48 +++++++++++++++++++++++++++++++++++++++++++++++- 3 files changed, 64 insertions(+), 1 deletion(-) create mode 100644 tvix/eval/src/errors.rs create mode 100644 tvix/eval/src/eval.rs diff --git a/tvix/eval/src/errors.rs b/tvix/eval/src/errors.rs new file mode 100644 index 0000000000..14f6819862 --- /dev/null +++ b/tvix/eval/src/errors.rs @@ -0,0 +1,12 @@ +use std::fmt::Display; + +#[derive(Debug)] +pub struct Error {} + +impl Display for Error { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + writeln!(f, "error") + } +} + +pub type EvalResult = Result; diff --git a/tvix/eval/src/eval.rs b/tvix/eval/src/eval.rs new file mode 100644 index 0000000000..89a375b69a --- /dev/null +++ b/tvix/eval/src/eval.rs @@ -0,0 +1,5 @@ +use crate::errors::{Error, EvalResult}; + +pub fn interpret(code: String) -> EvalResult<()> { + Ok(()) +} diff --git a/tvix/eval/src/main.rs b/tvix/eval/src/main.rs index e7a11a969c..8192965a8b 100644 --- a/tvix/eval/src/main.rs +++ b/tvix/eval/src/main.rs @@ -1,3 +1,49 @@ +use std::{ + env, fs, + io::{self, Write}, + mem, process, +}; + +mod errors; +mod eval; + fn main() { - println!("Hello, world!"); + let mut args = env::args(); + if args.len() > 2 { + println!("Usage: tvix-eval [script]"); + process::exit(1); + } + + if let Some(file) = args.nth(1) { + run_file(&file); + } else { + run_prompt(); + } +} + +fn run_file(file: &str) { + let contents = fs::read_to_string(file).expect("failed to read the input file"); + + run(contents); +} + +fn run_prompt() { + let mut line = String::new(); + + loop { + print!("> "); + io::stdout().flush().unwrap(); + io::stdin() + .read_line(&mut line) + .expect("failed to read user input"); + run(mem::take(&mut line)); + line.clear(); + } +} + +fn run(code: String) { + match eval::interpret(code) { + Ok(result) => println!("=> {:?}", result), + Err(err) => eprintln!("{}", err), + } } -- cgit 1.4.1