rotation-logger 0.1.3

Simple async logger with file rotation
Documentation
//! # Simple file rotation logger.
//!
//! This logger safe to use with threads as argument, or as macros.
//!
//! Example:
//!
//! ```
//! use std::{
//!     thread::{self, sleep},
//!     time::Duration,
//! };
//!
//! use rotation_logger::{FileSize, Logger, OutputChannel, MessageFormatter, Settings, log};
//!
//! fn main() {
//!     let formatter = MessageFormatter::new(
//!         "::",
//!         "{timestamp:-6:30:right}{splitter}{modules:_:_:left}{splitter}{message}",
//!         "%Y-%m-%d %H:%M:%S.%f",
//!     );
//!
//!     let output = OutputChannel::file(
//!         "./logs".into(),
//!         10,
//!         FileSize::from_kilobytes(1),
//!         "new_logger".into(),
//!         "log".into(),
//!     );
//!
//!     let settings = Settings::new(true, 5, output, formatter);
//!
//!     let logger = Logger::new(settings);
//!     let joiner = logger.run_async();
//!
//!     let logger_logger_01 = logger.clone();
//!     let logger_logger_02 = logger.clone();
//!     let _ = thread::spawn(move || {
//!         logger_logger_01.log(&vec!["THREAD1".into(), "MAIN".into()], "Starting...");
//!
//!         let mut counter = 0;
//!         loop {
//!             logger_logger_01.log(
//!                 &vec!["THREAD1".into(), "WORKER".into()],
//!                 format!("Processing Job: {counter}").as_str(),
//!             );
//!             counter += 1;
//!             sleep(Duration::from_secs(1));
//!         }
//!     });
//!
//!     let _ = thread::spawn(move || {
//!         logger_logger_02.log(&vec!["THREAD2".into(), "MAIN".into()], "Starting...");
//!
//!         let mut counter = 0;
//!         loop {
//!             logger_logger_02.log(
//!                 &vec!["THREAD2".into(), "WORKER".into()],
//!                 format!("Processing Job: {counter}").as_str(),
//!             );
//!             counter += 2;
//!             sleep(Duration::from_millis(400));
//!         }
//!     });
//!
//!     let _ = thread::spawn(move || {
//!         log!("Starting...");
//!
//!         let mut counter = 0;
//!         loop {
//!             log!(format!("Try Process Job: {counter}").as_str());
//!
//!             // Log as text
//!             log!(
//!                 ["THREAD3", "MODULE1"],
//!                 format!("Try Process Job: {counter}").as_str()
//!             );
//!             let module_str = "RAW_MODULE";
//!             let thread3_str = "THREAD3";
//!
//!             // Log from vars
//!             log!(
//!                 [thread3_str, module_str],
//!                 format!("Try Process Job: {counter}").as_str()
//!             );
//!
//!             // Log as ident
//!             log!((RAW_MODULE, RAW_MODULE2, RAW_MODULE3), "some");
//!             counter += 2;
//!             sleep(Duration::from_millis(400));
//!         }
//!     });
//!
//!     match joiner {
//!         Some(j) => {
//!             let _ = j.join();
//!         }
//!         None => {}
//!     };
//! }
//!
//! ```
//!
//!

pub use crate::rotation_logger::FileSettings;
pub use crate::rotation_logger::FileSize;
pub use crate::rotation_logger::LOG_SENDER;
pub use crate::rotation_logger::Logger;
pub use crate::rotation_logger::Message;
pub use crate::rotation_logger::MessageFormatter;
pub use crate::rotation_logger::OutputChannel;
pub use crate::rotation_logger::Settings;

mod rotation_logger;