slog

Struct PushFnValue

Source
pub struct PushFnValue<F>(pub F)
where
    F: 'static + for<'c, 'd> Fn(&'c Record<'d>, PushFnValueSerializer<'c>) -> Result;
Expand description

Lazy Value that writes to Serializer

It’s more ergonomic for closures used as lazy values to return type implementing Serialize, but sometimes that forces an allocation (eg. Strings)

In some cases it might make sense for another closure form to be used - one taking a serializer as an argument, which avoids lifetimes / allocation issues.

Generally this method should be used if it avoids a big allocation of Serialize-implementing type in performance-critical logging statement.

#[macro_use]
extern crate slog;
use slog::{PushFnValue, Logger, Discard};

fn main() {
    // Create a logger with a key-value printing
    // `file:line` string value for every logging statement.
    // `Discard` `Drain` used for brevity.
    let root = Logger::root(Discard, o!(
        "source_location" => PushFnValue(|record , s| {
             s.serialize(
                  format_args!(
                       "{}:{}",
                       record.file(),
                       record.line(),
                  )
             )
        })
    ));
}

Tuple Fields§

§0: F

Trait Implementations§

Source§

impl<F> Value for PushFnValue<F>
where F: 'static + for<'c, 'd> Fn(&'c Record<'d>, PushFnValueSerializer<'c>) -> Result,

Source§

fn serialize( &self, record: &Record<'_>, key: Key, serializer: &mut dyn Serializer, ) -> Result

Serialize self into Serializer Read more

Auto Trait Implementations§

§

impl<F> Freeze for PushFnValue<F>
where F: Freeze,

§

impl<F> RefUnwindSafe for PushFnValue<F>
where F: RefUnwindSafe,

§

impl<F> Send for PushFnValue<F>
where F: Send,

§

impl<F> Sync for PushFnValue<F>
where F: Sync,

§

impl<F> Unpin for PushFnValue<F>
where F: Unpin,

§

impl<F> UnwindSafe for PushFnValue<F>
where F: UnwindSafe,

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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, 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> SendSyncUnwindSafe for T
where T: Send + Sync + UnwindSafe + ?Sized,