#![windows_subsystem = "windows"]
#[cfg(feature = "message-box")]
mod alert_service;
mod config;
mod content;
mod error;
mod file_editor;
mod filename;
mod filter;
mod logger;
mod note;
mod process_ext;
#[cfg(feature = "viewer")]
mod viewer;
mod workflow;
extern crate semver;
use crate::config::backup_config_file;
use crate::config::ARGS;
use crate::config::CFG;
use crate::config::CFG_FILE_LOADING;
use crate::logger::AppLogger;
use crate::workflow::run;
use error::FileError;
use semver::Version;
use std::process;
const VERSION: Option<&'static str> = option_env!("CARGO_PKG_VERSION");
const MIN_CONFIG_FILE_VERSION: Option<&'static str> = VERSION;
const AUTHOR: &str = "(c) Jens Getreu, 2020-2021";
fn main() {
AppLogger::init();
lazy_static::initialize(&CFG);
let level = ARGS.debug.unwrap_or(CFG.debug_arg_default);
AppLogger::set_max_level(level);
AppLogger::set_popup_always_enabled(ARGS.popup || CFG.popup_arg_default);
let cfg_file_loading = &*CFG_FILE_LOADING.read().unwrap();
let cfg_file_loading_err = cfg_file_loading.as_ref().err().map(|e| e.to_string());
let cfg_file_version = Version::parse(&*CFG.version);
let cfg_file_version_err = cfg_file_version.as_ref().err().map(|e| e.to_string());
let cfg_err = cfg_file_loading_err.or(cfg_file_version_err);
let config_file_version = match cfg_err {
None => cfg_file_version.ok(),
Some(e) => {
log::error!("{}", FileError::ConfigFileLoadParseWrite { error: e });
if let Err(e) = backup_config_file() {
log::error!(
"{}",
FileError::ConfigFileBackup {
error: e.to_string()
}
.to_string()
);
AppLogger::flush();
process::exit(5);
};
None
}
};
if let Some(config_file_version) = config_file_version {
if config_file_version < Version::parse(MIN_CONFIG_FILE_VERSION.unwrap_or("0.0.0")).unwrap()
{
log::error!(
"{}",
FileError::ConfigFileVersionMismatch {
config_file_version: config_file_version.to_string(),
min_version: MIN_CONFIG_FILE_VERSION.unwrap_or("0.0.0").to_string(),
}
.to_string()
);
if let Err(e) = backup_config_file() {
log::error!(
"{}",
FileError::ConfigFileBackup {
error: e.to_string()
}
.to_string()
);
AppLogger::flush();
process::exit(5);
};
};
};
match run() {
Err(e) => {
log::error!("{}", e);
AppLogger::flush();
process::exit(1);
}
Ok(path) => {
if let Some(p) = &ARGS.export {
if p.as_os_str().to_str().unwrap_or_default() != "-" {
println!("{}", path.to_str().unwrap_or_default());
}
} else {
println!("{}", path.to_str().unwrap_or_default());
}
}
};
AppLogger::flush();
}