[][src]Enum pyo3_log::Caching

#[non_exhaustive]pub enum Caching {
    Nothing,
    Loggers,
    LoggersAndLevels,
}

What the Logger can cache.

Variants (Non-exhaustive)

Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Nothing

Disables caching.

Every time a log message passes the filters, the code goes to the Python side to check if the message shall be logged.

Loggers

Caches the Python Logger objects.

The logger objects (which should stay the same during the lifetime of a Python application) are cached. However, the log levels are not. This means there's some amount of calling of Python code saved during a logging call, but the GIL still needs to be acquired even if the message doesn't eventually get output anywhere.

LoggersAndLevels

Caches both the Python Logger and their respective effective log levels.

Therefore, once a Logger has been cached, it is possible to decide on the Rust side if a message would get logged or not. If the message is not to be logged, no Python code is called and the GIL doesn't have to be acquired.

Trait Implementations

impl Clone for Caching[src]

impl Copy for Caching[src]

impl Debug for Caching[src]

impl Default for Caching[src]

impl Eq for Caching[src]

impl PartialEq<Caching> for Caching[src]

impl StructuralEq for Caching[src]

impl StructuralPartialEq for Caching[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.