2019-11-23 14:34:03 +00:00
|
|
|
use fern::colors::{Color, ColoredLevelConfig};
|
2020-03-05 19:26:07 +00:00
|
|
|
use std::fs;
|
2019-11-23 14:34:03 +00:00
|
|
|
|
2019-12-18 19:35:17 +00:00
|
|
|
use crate::settings::Settings;
|
|
|
|
|
|
|
|
pub fn init(
|
|
|
|
settings: &Settings,
|
|
|
|
term_log_level: log::LevelFilter,
|
|
|
|
file_log_level: log::LevelFilter,
|
|
|
|
) {
|
2019-11-23 14:34:03 +00:00
|
|
|
let colors = ColoredLevelConfig::new()
|
|
|
|
.error(Color::Red)
|
|
|
|
.warn(Color::Yellow)
|
|
|
|
.info(Color::Cyan)
|
|
|
|
.debug(Color::Green)
|
|
|
|
.trace(Color::BrightBlack);
|
|
|
|
|
2019-12-18 19:35:17 +00:00
|
|
|
let mut base = fern::Dispatch::new()
|
2019-11-23 14:34:03 +00:00
|
|
|
.level_for("dot_vox::parser", log::LevelFilter::Warn)
|
|
|
|
.level_for("gfx_device_gl::factory", log::LevelFilter::Warn)
|
|
|
|
.level_for("uvth", log::LevelFilter::Warn)
|
|
|
|
.level_for("tiny_http", log::LevelFilter::Warn);
|
|
|
|
|
|
|
|
let time = chrono::offset::Utc::now();
|
|
|
|
|
2019-12-18 19:35:17 +00:00
|
|
|
let mut file_cfg =
|
|
|
|
fern::Dispatch::new()
|
|
|
|
.level(file_log_level)
|
|
|
|
.format(|out, message, record| {
|
|
|
|
out.finish(format_args!(
|
|
|
|
"{}[{}:{}][{}] {}",
|
|
|
|
chrono::Local::now().format("[%Y-%m-%d][%H:%M:%S]"),
|
|
|
|
record.target(),
|
|
|
|
record
|
|
|
|
.line()
|
|
|
|
.map(|x| x.to_string())
|
|
|
|
.unwrap_or("X".to_string()),
|
|
|
|
record.level(),
|
|
|
|
message
|
|
|
|
))
|
|
|
|
});
|
|
|
|
|
2020-03-05 19:26:07 +00:00
|
|
|
// Try to create the logs file parent directories.
|
|
|
|
let mut log_file_created = fs::create_dir_all(&settings.log.logs_path);
|
|
|
|
|
|
|
|
if log_file_created.is_ok() {
|
|
|
|
// Try to create the log file.
|
|
|
|
match fern::log_file(
|
|
|
|
settings
|
|
|
|
.log
|
|
|
|
.logs_path
|
|
|
|
.join(&format!("voxygen-{}.log", time.format("%Y-%m-%d-%H"))),
|
|
|
|
) {
|
|
|
|
Ok(log_file) => file_cfg = file_cfg.chain(log_file),
|
|
|
|
Err(e) => log_file_created = Err(e),
|
|
|
|
}
|
2019-12-18 19:35:17 +00:00
|
|
|
}
|
2019-11-23 14:34:03 +00:00
|
|
|
|
|
|
|
let stdout_cfg = fern::Dispatch::new()
|
|
|
|
.level(term_log_level)
|
|
|
|
.format(move |out, message, record| {
|
|
|
|
out.finish(format_args!(
|
|
|
|
"[{}] {}",
|
|
|
|
colors.color(record.level()),
|
|
|
|
message
|
|
|
|
))
|
|
|
|
})
|
|
|
|
.chain(std::io::stdout());
|
|
|
|
|
2019-12-18 19:35:17 +00:00
|
|
|
if settings.log.log_to_file {
|
|
|
|
base = base.chain(file_cfg);
|
|
|
|
}
|
|
|
|
base.chain(stdout_cfg)
|
2019-11-23 14:34:03 +00:00
|
|
|
.apply()
|
|
|
|
.expect("Failed to setup logging!");
|
2019-12-20 14:59:50 +00:00
|
|
|
|
2020-03-05 19:26:07 +00:00
|
|
|
// Incase that the log file creation failed simply print it to the console
|
2019-12-20 14:59:50 +00:00
|
|
|
if let Err(e) = log_file_created {
|
|
|
|
log::error!("Failed to create log file! {}", e);
|
|
|
|
}
|
2019-11-23 14:34:03 +00:00
|
|
|
}
|