pub struct DynFilterFn<C, F = fn(&Metadata<'_>, &Context<'_, C>) -> bool, R = fn(&'static Metadata<'static>) -> Interest> { /* private fields */ }
Expand description
A filter implemented by a closure or function pointer that determines whether a given span or event is enabled dynamically, potentially based on the current span context.
This type can be used for both per-subscriber filtering (using its
Filter
implementation) and global filtering (using its
Subscribe
implementation).
See the documentation on filtering with subscribers for details.
Implementationsยง
Sourceยงimpl<C, F> DynFilterFn<C, F>
impl<C, F> DynFilterFn<C, F>
Sourcepub fn new(enabled: F) -> Self
pub fn new(enabled: F) -> Self
Constructs a Filter
from a function or closure that returns true
if a span or event should be enabled in the current span
context.
Unlike FilterFn
, a DynFilterFn
is constructed from a closure or
function pointer that takes both the Metadata
for a span or event
and the current Context
. This means that a DynFilterFn
can
choose whether to enable spans or events based on information about the
current span (or its parents).
If this is not necessary, use FilterFn
instead.
See the documentation on per-subscriber filtering for details on using
Filter
s.
ยงExamples
use tracing_subscriber::{
subscribe::{Subscribe, CollectExt},
filter::DynFilterFn,
util::SubscriberInitExt,
};
// Only enable spans or events within a span named "interesting_span".
let my_filter = DynFilterFn::new(|metadata, cx| {
// If this *is* "interesting_span", make sure to enable it.
if metadata.is_span() && metadata.name() == "interesting_span" {
return true;
}
// Otherwise, are we in an interesting span?
if let Some(current_span) = cx.lookup_current() {
return current_span.name() == "interesting_span";
}
false
});
let my_subscriber = tracing_subscriber::fmt::subscriber();
tracing_subscriber::registry()
.with(my_subscriber.with_filter(my_filter))
.init();
// This event will not be enabled.
tracing::info!("something happened");
tracing::info_span!("interesting_span").in_scope(|| {
// This event will be enabled.
tracing::debug!("something else happened");
});
Sourceยงimpl<C, F, R> DynFilterFn<C, F, R>
impl<C, F, R> DynFilterFn<C, F, R>
Sourcepub fn with_max_level_hint(self, max_level_hint: impl Into<LevelFilter>) -> Self
pub fn with_max_level_hint(self, max_level_hint: impl Into<LevelFilter>) -> Self
Sets the highest verbosity Level
the filter function will enable.
The value passed to this method will be returned by this DynFilterFn
โs
Filter::max_level_hint
method.
If the provided function will not enable all levels, it is recommended to call this method to configure it with the most verbose level it will enable.
ยงExamples
use tracing_subscriber::{
subscribe::{Subscribe, CollectExt},
filter::{DynFilterFn, LevelFilter},
util::SubscriberInitExt,
};
use tracing_core::Level;
// Only enable spans or events with levels at or below `INFO`, if
// we are inside a span called "interesting_span".
let my_filter = DynFilterFn::new(|metadata, cx| {
// If the level is greater than INFO, disable it.
if metadata.level() > &Level::INFO {
return false;
}
// If any span in the current scope is named "interesting_span",
// enable this span or event.
for span in cx.lookup_current().iter().flat_map(|span| span.scope()) {
if span.name() == "interesting_span" {
return true;
}
}
// Otherwise, disable it.
false
})
// Since the filter closure will only enable the `INFO` level and
// below, set the max level hint
.with_max_level_hint(LevelFilter::INFO);
let my_subscriber = tracing_subscriber::fmt::subscriber();
tracing_subscriber::registry()
.with(my_subscriber.with_filter(my_filter))
.init();
Sourcepub fn with_callsite_filter<R2>(
self,
callsite_enabled: R2,
) -> DynFilterFn<C, F, R2> โ
pub fn with_callsite_filter<R2>( self, callsite_enabled: R2, ) -> DynFilterFn<C, F, R2> โ
Adds a function for filtering callsites to this filter.
When this filterโs Filter::callsite_enabled
method is called,
the provided function will be used rather than the default.
By default, DynFilterFn
assumes that, because the filter may depend
dynamically on the current span context, its result should never be
cached. However, some filtering strategies may require dynamic information
from the current span context in some cases, but are able to make
static filtering decisions from Metadata
alone in others.
For example, consider the filter given in the example for
DynFilterFn::new
. That filter enables all spans named
โinteresting_spanโ, and any events and spans that occur inside of an
interesting span. Since the spanโs name is part of its static
Metadata
, the โinteresting_spanโ can be enabled in
callsite_enabled
:
use tracing_subscriber::{
subscribe::{Subscribe, CollectExt},
filter::DynFilterFn,
util::SubscriberInitExt,
};
use tracing_core::collect::Interest;
// Only enable spans or events within a span named "interesting_span".
let my_filter = DynFilterFn::new(|metadata, cx| {
// If this *is* "interesting_span", make sure to enable it.
if metadata.is_span() && metadata.name() == "interesting_span" {
return true;
}
// Otherwise, are we in an interesting span?
if let Some(current_span) = cx.lookup_current() {
return current_span.name() == "interesting_span";
}
false
}).with_callsite_filter(|metadata| {
// If this is an "interesting_span", we know we will always
// enable it.
if metadata.is_span() && metadata.name() == "interesting_span" {
return Interest::always();
}
// Otherwise, it depends on whether or not we're in an interesting
// span. You'll have to ask us again for each span/event!
Interest::sometimes()
});
let my_subscriber = tracing_subscriber::fmt::subscriber();
tracing_subscriber::registry()
.with(my_subscriber.with_filter(my_filter))
.init();
Trait Implementationsยง
Sourceยงimpl<C, F, R> Clone for DynFilterFn<C, F, R>
impl<C, F, R> Clone for DynFilterFn<C, F, R>
Sourceยงimpl<C, F, R> Debug for DynFilterFn<C, F, R>
impl<C, F, R> Debug for DynFilterFn<C, F, R>
Sourceยงimpl<C, F, R> Filter<C> for DynFilterFn<C, F, R>
Available on crate features registry
and std
only.
impl<C, F, R> Filter<C> for DynFilterFn<C, F, R>
registry
and std
only.Sourceยงfn enabled(&self, metadata: &Metadata<'_>, cx: &Context<'_, C>) -> bool
fn enabled(&self, metadata: &Metadata<'_>, cx: &Context<'_, C>) -> bool
true
if this subscriber is interested in a span or event with the
given Metadata
in the current Context
, similarly to
Collect::enabled
. Read moreSourceยงfn callsite_enabled(&self, metadata: &'static Metadata<'static>) -> Interest
fn callsite_enabled(&self, metadata: &'static Metadata<'static>) -> Interest
Sourceยงfn max_level_hint(&self) -> Option<LevelFilter> โ
fn max_level_hint(&self) -> Option<LevelFilter> โ
Sourceยงfn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>)
Sourceยงfn on_enter(&self, id: &Id, ctx: Context<'_, S>)
fn on_enter(&self, id: &Id, ctx: Context<'_, S>)
Sourceยงimpl<F, C> From<F> for DynFilterFn<C, F>
impl<F, C> From<F> for DynFilterFn<C, F>
Sourceยงimpl<C, F, R> Subscribe<C> for DynFilterFn<C, F, R>
impl<C, F, R> Subscribe<C> for DynFilterFn<C, F, R>
Sourceยงfn enabled(&self, metadata: &Metadata<'_>, cx: Context<'_, C>) -> bool
fn enabled(&self, metadata: &Metadata<'_>, cx: Context<'_, C>) -> bool
true
if this subscriber is interested in a span or event with the
given metadata
in the current Context
, similarly to
Collect::enabled
. Read moreSourceยงfn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
fn register_callsite(&self, metadata: &'static Metadata<'static>) -> Interest
Collect::register_callsite
. Read moreSourceยงfn on_register_dispatch(&self, collector: &Dispatch)
fn on_register_dispatch(&self, collector: &Dispatch)
Sourceยงfn on_subscribe(&mut self, collector: &mut C)
fn on_subscribe(&mut self, collector: &mut C)
Sourceยงfn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, C>)
fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, C>)
Attributes
and Id
.Sourceยงfn on_record(&self, _span: &Id, _values: &Record<'_>, _ctx: Context<'_, C>)
fn on_record(&self, _span: &Id, _values: &Record<'_>, _ctx: Context<'_, C>)
Id
recorded the given
values
.Sourceยงfn on_follows_from(&self, _span: &Id, _follows: &Id, _ctx: Context<'_, C>)
fn on_follows_from(&self, _span: &Id, _follows: &Id, _ctx: Context<'_, C>)
span
recorded that it
follows from the span with the ID follows
.Sourceยงfn on_event(&self, _event: &Event<'_>, _ctx: Context<'_, C>)
fn on_event(&self, _event: &Event<'_>, _ctx: Context<'_, C>)
Sourceยงfn on_enter(&self, _id: &Id, _ctx: Context<'_, C>)
fn on_enter(&self, _id: &Id, _ctx: Context<'_, C>)
Sourceยงfn on_exit(&self, _id: &Id, _ctx: Context<'_, C>)
fn on_exit(&self, _id: &Id, _ctx: Context<'_, C>)
Sourceยงfn on_close(&self, _id: Id, _ctx: Context<'_, C>)
fn on_close(&self, _id: Id, _ctx: Context<'_, C>)
Sourceยงfn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, C>)
fn on_id_change(&self, _old: &Id, _new: &Id, _ctx: Context<'_, C>)
Sourceยงfn and_then<S>(self, subscriber: S) -> Layered<S, Self, C> โ
fn and_then<S>(self, subscriber: S) -> Layered<S, Self, C> โ
Layered
struct implementing Subscribe
. Read moreSourceยงfn with_filter<F>(self, filter: F) -> Filtered<Self, F, C> โ
fn with_filter<F>(self, filter: F) -> Filtered<Self, F, C> โ
registry
and std
only.Auto Trait Implementationsยง
impl<C, F, R> Freeze for DynFilterFn<C, F, R>
impl<C, F, R> RefUnwindSafe for DynFilterFn<C, F, R>where
F: RefUnwindSafe,
R: RefUnwindSafe,
impl<C, F, R> Send for DynFilterFn<C, F, R>
impl<C, F, R> Sync for DynFilterFn<C, F, R>
impl<C, F, R> Unpin for DynFilterFn<C, F, R>
impl<C, F, R> UnwindSafe for DynFilterFn<C, F, R>where
F: UnwindSafe,
R: UnwindSafe,
Blanket Implementationsยง
Sourceยงimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Sourceยงfn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Sourceยงimpl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Sourceยงimpl<F, S> FilterExt<S> for Fwhere
F: Filter<S>,
impl<F, S> FilterExt<S> for Fwhere
F: Filter<S>,
Sourceยงfn and<B>(self, other: B) -> And<Self, B, S> โ
fn and<B>(self, other: B) -> And<Self, B, S> โ
registry
and std
only.Sourceยงfn or<B>(self, other: B) -> Or<Self, B, S> โ
fn or<B>(self, other: B) -> Or<Self, B, S> โ
registry
and std
only.