extern crate lazy_static;
extern crate qbe;
extern crate regex;
extern crate rust_embed;
extern crate structopt;
use generator::Target;
use std::path::PathBuf;
use std::process;
use structopt::StructOpt;
mod ast;
mod builder;
mod command;
mod generator;
mod lexer;
mod parser;
#[cfg(test)]
mod tests;
mod util;
use rust_embed::RustEmbed;
#[derive(RustEmbed)]
#[folder = "lib/"]
pub struct Lib;
#[derive(RustEmbed)]
#[folder = "builtin/"]
pub struct Builtins;
#[derive(StructOpt, Debug)]
enum Command {
#[structopt()]
Build {
in_file: PathBuf,
#[structopt(short, long)]
out_file: PathBuf,
},
#[structopt()]
Run { in_file: PathBuf },
}
#[derive(StructOpt, Debug)]
struct Opt {
#[structopt(subcommand)]
command: Command,
#[structopt(long, short, parse(try_from_str))]
target: Option<Target>,
}
fn main() {
if let Err(err) = run() {
eprintln!("Error: {}", err);
process::exit(1);
}
}
fn run() -> Result<(), String> {
let opts = Opt::from_args();
match opts.command {
Command::Build { in_file, out_file } => {
let target = match opts.target {
Some(t) => t,
None => Target::from_extension(&out_file).ok_or_else(|| {
format!(
"Cannot detect target from output file {}, use --target option to set it explicitly",
&out_file.to_string_lossy(),
)
})?,
};
command::build::build(&target, &in_file, &out_file)?
}
Command::Run { in_file } => command::run::run(opts.target.unwrap_or(Target::JS), in_file)?,
};
Ok(())
}