Compare commits

..

No commits in common. "beb337cefd817938bc5023be30c3390be49f6845" and "dd5bfff7d2f0859e92ca1ca1b068638e3eb1333c" have entirely different histories.

View File

@ -7,7 +7,6 @@ mod test;
use std::fmt::Display;
use std::fs::OpenOptions;
use std::io;
use std::io::Write;
use config::log::LogSettings;
@ -25,49 +24,45 @@ use LogMessageType::GenericWarn;
/**
* Logs the given message.
*
* # Panics
* Panics if readlock on [`config::CONFIG`] could not be acquired
* or if another error occurs, such as a full disk.
*/
pub fn log_message(msg: &LogMessage, conf: &LogSettings, file: &str, line: u32, column: u32) -> Result<(), io::Error> {
// Check if message may be logged according to config.
pub fn log_message(msg: &LogMessage, conf: &LogSettings, file: &str, line: u32, column: u32) {
let Some(log_line) = log_to_str(msg, conf, file, line, column) else {
return Ok(());
return;
};
// Log to file
match conf.path().as_ref()
{
None => {/* Do not log to file */}
Some(p) =>
{
let file = OpenOptions::new()
// May panic if file cannot be opened or written to.
conf.path().as_ref().map_or_else(
|| {},
|path| {
let mut file = OpenOptions::new()
.write(true)
.append(true)
.create(true)
.open(p);
let mut file = match file
{
Ok(f) => f,
Err(e) => return Err(e),
};
match writeln!(file, "{log_line}")
{
Ok(_) => {},
Err(e) => return Err(e),
}
}
};
.open(path)
.unwrap_or_else(|_| panic!("Could not open log file: {path:#?}"));
writeln!(file, "{log_line}")
.unwrap_or_else(|_| panic!("Could not write log to file: {path:#?}"));
},
);
if msg.1 <= Warning && *conf.stderr() {
let mut stdout = io::stdout().lock();
return writeln!(stdout, "{log_line}");
// May panic if writing to stderr fails.
eprintln!("{log_line}");
} else if msg.1 >= Information && *conf.stdout() {
let mut stderr = io::stderr().lock();
return writeln!(stderr, "{log_line}")
// May panic if writing to stdout fails.
println!("{log_line}");
}
return Ok(());
}
/**
* Return log line, if message may be logged according to [`config::log::LogSettings`].
* # Panics
* Panics if readlock on [`config::CONFIG`] could not be acquired
* or if another error occurs, such as a full disk.
*/
#[must_use]
pub fn log_to_str(
@ -108,12 +103,11 @@ macro_rules! log {
let conf = config::LOG_SETTINGS
.read()
.unwrap_or_else(|_| panic!("Failed aqcuire read lock on config!"));
let res = log_message($msg, &*conf, file!(), line!(), column!());
log_message($msg, &*conf, file!(), line!(), column!());
drop(conf);
res
};
($msg:expr, $config:expr) => {
log_message($msg, $config, file!(), line!(), column!())
log_message($msg, $config, file!(), line!(), column!());
};
}
@ -129,8 +123,6 @@ impl Display for LogMessage {
}
}
// TODO: Evaluate replacing the following with a trait, to decouple this component from the rest.
/**
* Every possible Message, which may be logged. Grouped the following:
*
@ -190,4 +182,4 @@ impl Display for LogMessageType {
}
}
}
}
}