flexi_logger

Struct LogSpecification

Source
pub struct LogSpecification { /* private fields */ }
Expand description

Immutable struct that defines which loglines are to be written, based on the module, the log level, and the text.

Providing the loglevel specification via String (LogSpecification::parse and LogSpecification::env) works essentially like with env_logger, but we are a bit more tolerant with spaces. Its functionality can be described with some Backus-Naur-form:

<log_level_spec> ::= single_log_level_spec[{,single_log_level_spec}][/<text_filter>]
<single_log_level_spec> ::= <path_to_module>|<log_level>|<path_to_module>=<log_level>
<text_filter> ::= <regex>
  • Examples:

    • "info": all logs with info, warn, or error level are written
    • "crate1": all logs of this crate are written, but nothing else
    • "warn, crate2::mod_a=debug, mod_x::mod_y=trace": all crates log warnings and errors, mod_a additionally debug messages, and mod_x::mod_y is fully traced
  • If you just specify the module, without log_level, all levels will be traced for this module.

  • If you just specify a log level, this will be applied as default to all modules without explicit log level assigment. (You see that for modules named error, warn, info, debug or trace, it is necessary to specify their loglevel explicitly).

  • The module names are compared as Strings, with the side effect that a specified module filter affects all modules whose name starts with this String.
    Example: "foo" affects e.g.

    • foo
    • foo::bar
    • foobaz (!)
    • foobaz::bar (!)

The optional text filter is applied for all modules.

Note that external module names are to be specified like in "extern crate ...", i.e., for crates with a dash in their name this means: the dash is to be replaced with the underscore (e.g. karl_heinz, not karl-heinz). See https://github.com/rust-lang/rfcs/pull/940/files for an explanation of the different naming conventions in Cargo (packages allow hyphen) and rustc (“extern crate” does not allow hyphens).

Implementations§

Source§

impl LogSpecification

Source

pub fn off() -> Self

Returns a LogSpecification where all log output is switched off.

Source

pub fn error() -> Self

Returns a LogSpecification where the global tracelevel is set to LevelFilter::Error.

Source

pub fn warn() -> Self

Returns a LogSpecification where the global tracelevel is set to LevelFilter::Warn.

Source

pub fn info() -> Self

Returns a LogSpecification where the global tracelevel is set to LevelFilter::Info.

Source

pub fn debug() -> Self

Returns a LogSpecification where the global tracelevel is set to LevelFilter::Debug.

Source

pub fn trace() -> Self

Returns a LogSpecification where the global tracelevel is set to LevelFilter::Trace.

Source

pub fn parse<S: AsRef<str>>(spec: S) -> Result<Self, FlexiLoggerError>

Returns a log specification from a String.

§Errors

FlexiLoggerError::Parse if the input is malformed.

Source

pub fn env() -> Result<Self, FlexiLoggerError>

Returns a log specification based on the value of the environment variable RUST_LOG, or an empty one.

§Errors

FlexiLoggerError::Parse if the input is malformed.

Source

pub fn env_or_parse<S: AsRef<str>>( given_spec: S, ) -> Result<Self, FlexiLoggerError>

Returns a log specification based on the value of the environment variable RUST_LOG, if it exists and can be parsed, or on the given String.

§Errors

FlexiLoggerError::Parse if the given spec is malformed.

Source

pub fn builder() -> LogSpecBuilder

Creates a LogSpecBuilder, which allows building a log spec programmatically.

Source

pub fn from_toml<S: AsRef<str>>(s: S) -> Result<Self, FlexiLoggerError>

Available on crate feature specfile only.

Reads a log specification from an appropriate toml document.

This method is only avaible with feature specfile.

§Errors

FlexiLoggerError::Parse if the input is malformed.

Source

pub fn to_toml(&self, w: &mut dyn Write) -> Result<(), FlexiLoggerError>

Available on crate feature specfile only.

Serializes itself in toml format.

This method is only avaible with feature specfile.

§Errors

FlexiLoggerError::SpecfileIo if writing fails.

Source

pub fn enabled(&self, level: Level, writing_module: &str) -> bool

Returns true if messages on the specified level from the writing module should be written.

Source

pub fn module_filters(&self) -> &Vec<ModuleFilter>

Provides a reference to the module filters.

Source

pub fn text_filter(&self) -> Option<&Regex>

Provides a reference to the text filter.

This method is only avaible if the default feature textfilter is not switched off.

Trait Implementations§

Source§

impl Clone for LogSpecification

Source§

fn clone(&self) -> LogSpecification

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for LogSpecification

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for LogSpecification

Source§

fn default() -> LogSpecification

Returns the “default value” for a type. Read more
Source§

impl Display for LogSpecification

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<LevelFilter> for LogSpecification

Source§

fn from(value: LevelFilter) -> Self

Converts to this type from the input type.
Source§

impl TryFrom<&String> for LogSpecification

Source§

type Error = FlexiLoggerError

The type returned in the event of a conversion error.
Source§

fn try_from(value: &String) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl TryFrom<&str> for LogSpecification

Source§

type Error = FlexiLoggerError

The type returned in the event of a conversion error.
Source§

fn try_from(value: &str) -> Result<Self, Self::Error>

Performs the conversion.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more