2019-04-11 15:23:14 -07:00
|
|
|
use crate::common::*;
|
2016-10-23 16:43:52 -07:00
|
|
|
|
2019-10-09 00:18:53 -07:00
|
|
|
pub fn run() -> Result<(), i32> {
|
2018-05-06 19:02:17 -07:00
|
|
|
#[cfg(windows)]
|
2019-10-09 00:18:53 -07:00
|
|
|
ansi_term::enable_ansi_support().ok();
|
2018-05-06 19:02:17 -07:00
|
|
|
|
2018-08-27 16:03:52 -07:00
|
|
|
env_logger::Builder::from_env(
|
2018-12-08 14:29:41 -08:00
|
|
|
env_logger::Env::new()
|
|
|
|
.filter("JUST_LOG")
|
|
|
|
.write_style("JUST_LOG_STYLE"),
|
|
|
|
)
|
|
|
|
.init();
|
2018-08-27 16:03:52 -07:00
|
|
|
|
2019-10-07 02:06:45 -07:00
|
|
|
let app = Config::app();
|
2019-07-18 21:58:06 -07:00
|
|
|
|
2020-03-31 00:00:05 -07:00
|
|
|
info!("Parsing command line arguments…");
|
2019-07-18 21:58:06 -07:00
|
|
|
let matches = app.get_matches();
|
2016-10-23 16:43:52 -07:00
|
|
|
|
2021-07-26 01:26:06 -07:00
|
|
|
let loader = Loader::new();
|
2016-12-30 00:09:35 -08:00
|
|
|
|
2021-07-26 01:26:06 -07:00
|
|
|
let mut color = Color::auto();
|
|
|
|
let mut verbosity = Verbosity::default();
|
|
|
|
|
|
|
|
Config::from_matches(&matches)
|
|
|
|
.map_err(Error::from)
|
|
|
|
.and_then(|config| {
|
|
|
|
color = config.color;
|
|
|
|
verbosity = config.verbosity;
|
2021-07-26 17:19:52 -07:00
|
|
|
config.run(&loader)
|
2021-07-26 01:26:06 -07:00
|
|
|
})
|
|
|
|
.map_err(|error| {
|
|
|
|
if !verbosity.quiet() {
|
|
|
|
error.write(&mut io::stderr(), color).ok();
|
|
|
|
}
|
|
|
|
error.code().unwrap_or(EXIT_FAILURE)
|
|
|
|
})
|
2016-10-23 16:43:52 -07:00
|
|
|
}
|