2 releases

0.1.1 Oct 12, 2024
0.1.0 Jul 5, 2024

#389 in Configuration

Download history 5/week @ 2024-09-11 5/week @ 2024-09-18 24/week @ 2024-09-25 4/week @ 2024-10-02 166/week @ 2024-10-09 11/week @ 2024-10-16 1/week @ 2024-10-30 3/week @ 2024-11-06 6/week @ 2024-11-13 5/week @ 2024-11-20 90/week @ 2024-11-27 29/week @ 2024-12-04 28/week @ 2024-12-11

58 downloads per month

MIT license

6KB
59 lines

Initializes logging based on the specified environment and output configurations.


lib.rs:

Initializes logging based on the specified environment and output configurations.

This function configures the global logging behavior according to the specified outputs and the environment string provided. It supports conditional logging to stderr, files, or journald based on the inputs.

Arguments

  • outputs - A vector of Option<String> where each element represents an optional output destination. Supported values are file paths and "journald".
  • env - A string slice that represents the logging environment. It can be a simple level string like "debug" or a detailed filter like "my_crate=info,my_crate::module=debug".

Examples

init_logging(vec![None, Some("log.log".to_string())], "debug");
init_logging(vec![None, Some("journald".to_string())], "debug");
init_logging(vec![Some("journald".to_string())], "debug");

Panics

This function panics if the outputs vector has more than two elements or if the specified logging configuration is invalid.

Errors

This function sets the global default logger and may return an error if logging initialization fails due to system-level constraints or invalid configurations.

Dependencies

~4.5–6MB
~96K SLoC