summaryrefslogtreecommitdiffstats
path: root/src/main.rs
blob: 0e976828b78e9ae8cfa69d501bee5dce73a47ba6 (plain) (blame)
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 result =
        if src_path.exists() {
            config.run(&src_path)
        } else {
            config.make(&src_path)
        };

    match result {
        Ok(_) => trace!("ok"),
        Err(err) => error!("{}", err)
    }
}