Function tracing_capture::predicates::level
source · pub fn level<P: IntoLevelPredicate>(matches: P) -> LevelPredicate<P::Predicate>
Expand description
Creates a predicate for the Level
of a CapturedSpan
or CapturedEvent
.
§Arguments
The argument of this function may be:
Level
: will be compared exactlyLevelFilter
: will be compared as per ordinary rules- Any
Predicate
forLevel
. To bypass Rust orphaning rules, the predicate must be enclosed in square brackets (i.e., a one-value array).
§Examples
let storage = SharedStorage::default();
let subscriber = Registry::default().with(CaptureLayer::new(&storage));
tracing::subscriber::with_default(subscriber, || {
tracing::info_span!("compute").in_scope(|| {
tracing::info!(answer = 42, "done");
});
});
let storage = storage.lock();
// All of these access the single captured span.
let spans = storage.scan_spans();
let _ = spans.single(&level(Level::INFO));
let _ = spans.first(&level(LevelFilter::DEBUG));
let _ = spans.last(&level([gt(Level::WARN)]));