1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
use clap::{AppSettings};
use structopt::StructOpt;
use env_logger;
use log::{ trace, error };
mod conf;
mod backends;
#[derive(StructOpt, Debug)]
#[structopt(
name = "evr",
version = "0.1",
author = "by syn",
global_settings = &[
AppSettings::ColoredHelp,
AppSettings::UnifiedHelpMessage
],
)]
struct EVROpts {
/// source filename
#[structopt(long, index = 1)]
src: String,
/// be quiet
#[structopt(short, long)]
quiet: bool,
/// optimize with this level
#[structopt(short, long)]
opt: Option<u8>,
/// show time (wall)
#[structopt(short, long)]
time: bool,
/// show mem usage (rss)
#[structopt(short, long)]
mem: bool
}
fn main() {
let opts = EVROpts::from_args();
if !opts.quiet {
env_logger::builder()
.format_timestamp(None)
.init();
}
trace!("{:#?}", opts);
let src_path: std::path::PathBuf = opts.src.into();
let config = conf::get_conf();
trace!("{:#?}", config);
let (action, result) =
if src_path.exists() {
("run", config.run(&src_path))
} else {
("make", config.make(&src_path))
};
match result {
Ok(_) => trace!("ok {}", action),
Err(err) => error!("{}", err)
}
}
|