22 stable releases
1.1.17 | Sep 9, 2023 |
---|---|
1.1.16 | Jun 29, 2023 |
1.1.15 | Nov 3, 2022 |
1.1.14 | Mar 18, 2022 |
1.1.5 | Nov 14, 2018 |
#543 in Debugging
Used in pipe-logger
30KB
512 lines
Pipe Logger Lib
Stores, rotates, compresses process logs.
Example
use pipe_logger_lib::*;
use std::fs;
use std::path::Path;
let test_folder = {
let folder = Path::join(&Path::join(Path::new("tests"), Path::new("out")), "log-example");
fs::remove_dir_all(&folder);
fs::create_dir_all(&folder).unwrap();
folder
};
let test_log_file = Path::join(&test_folder, Path::new("mylog.txt"));
let mut builder = PipeLoggerBuilder::new(&test_log_file);
builder
.set_tee(Some(Tee::Stdout))
.set_rotate(Some(RotateMethod::FileSize(30))) // bytes
.set_count(Some(10))
.set_compress(false);
{
let mut logger = builder.build().unwrap();
logger.write_line("Hello world!").unwrap();
let rotated_log_file_1 = logger.write_line("This is a convenient logger.").unwrap().unwrap();
logger.write_line("Other logs...").unwrap();
logger.write_line("Other logs...").unwrap();
let rotated_log_file_2 = logger.write_line("Rotate again!").unwrap().unwrap();
logger.write_line("Ops!").unwrap();
}
fs::remove_dir_all(test_folder).unwrap();
Now, the contents of test_log_file
are,
Ops!
The contents of rotated_log_file_1
are,
Hello world!
This is a convenient logger.
The contents of rotated_log_file_2
are,
Other logs...
Other logs...
Rotate again!
Crates.io
https://crates.io/crates/pipe-logger-lib
Documentation
https://docs.rs/pipe-logger-lib
Official CLI
https://crates.io/crates/pipe-logger
License
Dependencies
~5–12MB
~122K SLoC