Struct tracing_subscriber::filter::Filtered
source · pub struct Filtered<L, F, S> { /* private fields */ }
registry
and std
only.Expand description
A Layer
that wraps an inner Layer
and adds a Filter
which
controls what spans and events are enabled for that layer.
This is returned by the Layer::with_filter
method. See the
documentation on per-layer filtering for details.
Implementations§
source§impl<L, F, S> Filtered<L, F, S>
impl<L, F, S> Filtered<L, F, S>
sourcepub fn new(layer: L, filter: F) -> Self
pub fn new(layer: L, filter: F) -> Self
Wraps the provided Layer
so that it is filtered by the given
Filter
.
This is equivalent to calling the Layer::with_filter
method.
See the documentation on per-layer filtering for details.
sourcepub fn filter_mut(&mut self) -> &mut F
pub fn filter_mut(&mut self) -> &mut F
Mutably borrows the Filter
used by this layer.
When this layer can be mutably borrowed, this may be used to mutate the filter.
Generally, this will primarily be used with the
reload::Handle::modify
method.
Examples
let filtered_layer = fmt::Layer::default().with_filter(filter::LevelFilter::WARN);
let (filtered_layer, reload_handle) = reload::Layer::new(filtered_layer);
info!("This will be ignored");
reload_handle.modify(|layer| *layer.filter_mut() = filter::LevelFilter::INFO);
info!("This will be logged");
sourcepub fn inner_mut(&mut self) -> &mut L
pub fn inner_mut(&mut self) -> &mut L
Mutably borrows the inner Layer
wrapped by this Filtered
layer.
This method is primarily expected to be used with the
reload::Handle::modify
method.
Examples
let filtered_layer = fmt::layer().with_writer(non_blocking(std::io::stderr())).with_filter(filter::LevelFilter::INFO);
let (filtered_layer, reload_handle) = reload::Layer::new(filtered_layer);
info!("This will be logged to stderr");
reload_handle.modify(|layer| *layer.inner_mut().writer_mut() = non_blocking(std::io::stdout()));
info!("This will be logged to stdout");
Trait Implementations§
source§impl<S, L, F> Layer<S> for Filtered<L, F, S>
impl<S, L, F> Layer<S> for Filtered<L, F, S>
source§fn on_register_dispatch(&self, subscriber: &Dispatch)
fn on_register_dispatch(&self, subscriber: &Dispatch)
Subscriber
. Read moresource§fn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
fn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
Subscriber::register_callsite
. Read moresource§fn enabled(&self, metadata: &Metadata<'_>, cx: Context<'_, S>) -> bool
fn enabled(&self, metadata: &Metadata<'_>, cx: Context<'_, S>) -> bool
true
if this layer is interested in a span or event with the
given metadata
in the current Context
, similarly to
Subscriber::enabled
. Read moresource§fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, cx: Context<'_, S>)
fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, cx: Context<'_, S>)
Attributes
and Id
.source§fn on_record(&self, span: &Id, values: &Record<'_>, cx: Context<'_, S>)
fn on_record(&self, span: &Id, values: &Record<'_>, cx: Context<'_, S>)
Id
recorded the given
values
.source§fn on_follows_from(&self, span: &Id, follows: &Id, cx: Context<'_, S>)
fn on_follows_from(&self, span: &Id, follows: &Id, cx: Context<'_, S>)
span
recorded that it
follows from the span with the ID follows
.source§fn event_enabled(&self, event: &Event<'_>, cx: Context<'_, S>) -> bool
fn event_enabled(&self, event: &Event<'_>, cx: Context<'_, S>) -> bool
on_event
, to determine if on_event
should be called.source§fn on_event(&self, event: &Event<'_>, cx: Context<'_, S>)
fn on_event(&self, event: &Event<'_>, cx: Context<'_, S>)
source§fn on_enter(&self, id: &Id, cx: Context<'_, S>)
fn on_enter(&self, id: &Id, cx: Context<'_, S>)
source§fn on_exit(&self, id: &Id, cx: Context<'_, S>)
fn on_exit(&self, id: &Id, cx: Context<'_, S>)
source§fn on_close(&self, id: Id, cx: Context<'_, S>)
fn on_close(&self, id: Id, cx: Context<'_, S>)
source§fn on_id_change(&self, old: &Id, new: &Id, cx: Context<'_, S>)
fn on_id_change(&self, old: &Id, new: &Id, cx: Context<'_, S>)
source§fn and_then<L>(self, layer: L) -> Layered<L, Self, S> ⓘ
fn and_then<L>(self, layer: L) -> Layered<L, Self, S> ⓘ
Layer
, returning a Layered
struct implementing Layer
. Read moresource§fn with_subscriber(self, inner: S) -> Layered<Self, S> ⓘwhere
Self: Sized,
fn with_subscriber(self, inner: S) -> Layered<Self, S> ⓘwhere
Self: Sized,
Layer
with the given Subscriber
, returning a
Layered
struct that implements Subscriber
. Read more