Struct tracing_subscriber::fmt::SubscriberBuilder
source · pub struct SubscriberBuilder<N = DefaultFields, E = Format<Full>, F = LevelFilter, W = fn() -> Stdout> { /* private fields */ }
Expand description
Configures and constructs Subscriber
s.
Implementations§
source§impl<N, E, F, W> SubscriberBuilder<N, E, F, W>where
N: for<'writer> FormatFields<'writer> + 'static,
E: FormatEvent<Registry, N> + 'static,
W: MakeWriter + 'static,
F: Layer<Formatter<N, E, W>> + Send + Sync + 'static,
Layer<Registry, N, E, W>: Layer<Registry> + Send + Sync + 'static,
impl<N, E, F, W> SubscriberBuilder<N, E, F, W>where N: for<'writer> FormatFields<'writer> + 'static, E: FormatEvent<Registry, N> + 'static, W: MakeWriter + 'static, F: Layer<Formatter<N, E, W>> + Send + Sync + 'static, Layer<Registry, N, E, W>: Layer<Registry> + Send + Sync + 'static,
sourcepub fn finish(self) -> Subscriber<N, E, F, W>
pub fn finish(self) -> Subscriber<N, E, F, W>
Finish the builder, returning a new FmtSubscriber
.
sourcepub fn try_init(self) -> Result<(), Box<dyn Error + Send + Sync + 'static>>
pub fn try_init(self) -> Result<(), Box<dyn Error + Send + Sync + 'static>>
Install this Subscriber as the global default if one is not already set.
If the tracing-log
feature is enabled, this will also install
the LogTracer to convert Log
records into tracing
Event
s.
Errors
Returns an Error if the initialization was unsuccessful, likely
because a global subscriber was already installed by another
call to try_init
.
sourcepub fn init(self)
pub fn init(self)
Install this Subscriber as the global default.
If the tracing-log
feature is enabled, this will also install
the LogTracer to convert Log
records into tracing
Event
s.
Panics
Panics if the initialization was unsuccessful, likely because a
global subscriber was already installed by another call to try_init
.
source§impl<N, L, T, F, W> SubscriberBuilder<N, Format<L, T>, F, W>where
N: for<'writer> FormatFields<'writer> + 'static,
impl<N, L, T, F, W> SubscriberBuilder<N, Format<L, T>, F, W>where N: for<'writer> FormatFields<'writer> + 'static,
sourcepub fn with_timer<T2>(
self,
timer: T2
) -> SubscriberBuilder<N, Format<L, T2>, F, W>
pub fn with_timer<T2>( self, timer: T2 ) -> SubscriberBuilder<N, Format<L, T2>, F, W>
Use the given timer
for log message timestamps.
See time
for the provided timer implementations.
Note that using the chrono
feature flag enables the
additional time formatters ChronoUtc
and ChronoLocal
.
sourcepub fn without_time(self) -> SubscriberBuilder<N, Format<L, ()>, F, W>
pub fn without_time(self) -> SubscriberBuilder<N, Format<L, ()>, F, W>
Do not emit timestamps with log messages.
sourcepub fn with_span_events(self, kind: FmtSpan) -> Self
pub fn with_span_events(self, kind: FmtSpan) -> Self
Configures how synthesized events are emitted at points in the span lifecycle.
The following options are available:
FmtSpan::NONE
: No events will be synthesized when spans are created, entered, exited, or closed. Data from spans will still be included as the context for formatted events. This is the default.FmtSpan::NEW
: An event will be synthesized when spans are created.FmtSpan::ENTER
: An event will be synthesized when spans are entered.FmtSpan::EXIT
: An event will be synthesized when spans are exited.FmtSpan::CLOSE
: An event will be synthesized when a span closes. If timestamps are enabled for this formatter, the generated event will contain fields with the span’s busy time (the total time for which it was entered) and idle time (the total time that the span existed but was not entered).FmtSpan::ACTIVE
: An event will be synthesized when spans are entered or exited.FmtSpan::FULL
: Events will be synthesized whenever a span is created, entered, exited, or closed. If timestamps are enabled, the close event will contain the span’s busy and idle time, as described above.
The options can be enabled in any combination. For instance, the following will synthesize events whenever spans are created and closed:
use tracing_subscriber::fmt::format::FmtSpan;
use tracing_subscriber::fmt;
let subscriber = fmt()
.with_span_events(FmtSpan::NEW | FmtSpan::CLOSE)
.finish();
Note that the generated events will only be part of the log output by
this formatter; they will not be recorded by other Subscriber
s or by
Layer
s added to this subscriber.
sourcepub fn with_ansi(self, ansi: bool) -> SubscriberBuilder<N, Format<L, T>, F, W>
pub fn with_ansi(self, ansi: bool) -> SubscriberBuilder<N, Format<L, T>, F, W>
Enable ANSI encoding for formatted events.
sourcepub fn with_target(
self,
display_target: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
pub fn with_target( self, display_target: bool ) -> SubscriberBuilder<N, Format<L, T>, F, W>
Sets whether or not an event’s target is displayed.
sourcepub fn with_level(
self,
display_level: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
pub fn with_level( self, display_level: bool ) -> SubscriberBuilder<N, Format<L, T>, F, W>
Sets whether or not an event’s level is displayed.
sourcepub fn with_thread_names(
self,
display_thread_names: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
pub fn with_thread_names( self, display_thread_names: bool ) -> SubscriberBuilder<N, Format<L, T>, F, W>
Sets whether or not the name of the current thread is displayed when formatting events
sourcepub fn with_thread_ids(
self,
display_thread_ids: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
pub fn with_thread_ids( self, display_thread_ids: bool ) -> SubscriberBuilder<N, Format<L, T>, F, W>
Sets whether or not the thread ID of the current thread is displayed when formatting events
sourcepub fn compact(self) -> SubscriberBuilder<N, Format<Compact, T>, F, W>where
N: for<'writer> FormatFields<'writer> + 'static,
pub fn compact(self) -> SubscriberBuilder<N, Format<Compact, T>, F, W>where N: for<'writer> FormatFields<'writer> + 'static,
Sets the subscriber being built to use a less verbose formatter.
See format::Compact
.
sourcepub fn pretty(self) -> SubscriberBuilder<Pretty, Format<Pretty, T>, F, W>
pub fn pretty(self) -> SubscriberBuilder<Pretty, Format<Pretty, T>, F, W>
Sets the subscriber being built to use an excessively pretty, human-readable formatter.
sourcepub fn json(self) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>where
N: for<'writer> FormatFields<'writer> + 'static,
pub fn json(self) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>where N: for<'writer> FormatFields<'writer> + 'static,
Sets the subscriber being built to use a JSON formatter.
See format::Json
source§impl<T, F, W> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
impl<T, F, W> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
sourcepub fn flatten_event(
self,
flatten_event: bool
) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
pub fn flatten_event( self, flatten_event: bool ) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
Sets the json subscriber being built to flatten event metadata.
See format::Json
sourcepub fn with_current_span(
self,
display_current_span: bool
) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
pub fn with_current_span( self, display_current_span: bool ) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
Sets whether or not the JSON subscriber being built will include the current span in formatted events.
See format::Json
sourcepub fn with_span_list(
self,
display_span_list: bool
) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
pub fn with_span_list( self, display_span_list: bool ) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
Sets whether or not the JSON subscriber being built will include a list (from root to leaf) of all currently entered spans in formatted events.
See format::Json
source§impl<N, E, W> SubscriberBuilder<N, E, EnvFilter, W>where
Formatter<N, E, W>: Subscriber + 'static,
impl<N, E, W> SubscriberBuilder<N, E, EnvFilter, W>where Formatter<N, E, W>: Subscriber + 'static,
sourcepub fn with_filter_reloading(
self
) -> SubscriberBuilder<N, E, Layer<EnvFilter, Formatter<N, E, W>>, W>
pub fn with_filter_reloading( self ) -> SubscriberBuilder<N, E, Layer<EnvFilter, Formatter<N, E, W>>, W>
Configures the subscriber being built to allow filter reloading at runtime.
source§impl<N, E, W> SubscriberBuilder<N, E, Layer<EnvFilter, Formatter<N, E, W>>, W>where
Formatter<N, E, W>: Subscriber + 'static,
impl<N, E, W> SubscriberBuilder<N, E, Layer<EnvFilter, Formatter<N, E, W>>, W>where Formatter<N, E, W>: Subscriber + 'static,
sourcepub fn reload_handle(&self) -> Handle<EnvFilter, Formatter<N, E, W>>
pub fn reload_handle(&self) -> Handle<EnvFilter, Formatter<N, E, W>>
Returns a Handle
that may be used to reload the constructed subscriber’s
filter.
source§impl<N, E, F, W> SubscriberBuilder<N, E, F, W>
impl<N, E, F, W> SubscriberBuilder<N, E, F, W>
sourcepub fn fmt_fields<N2>(self, fmt_fields: N2) -> SubscriberBuilder<N2, E, F, W>where
N2: for<'writer> FormatFields<'writer> + 'static,
pub fn fmt_fields<N2>(self, fmt_fields: N2) -> SubscriberBuilder<N2, E, F, W>where N2: for<'writer> FormatFields<'writer> + 'static,
Sets the Visitor that the subscriber being built will use to record fields.
For example:
use tracing_subscriber::fmt::format;
use tracing_subscriber::prelude::*;
let formatter =
// Construct a custom formatter for `Debug` fields
format::debug_fn(|writer, field, value| write!(writer, "{}: {:?}", field, value))
// Use the `tracing_subscriber::MakeFmtExt` trait to wrap the
// formatter so that a delimiter is added between fields.
.delimited(", ");
let subscriber = tracing_subscriber::fmt()
.fmt_fields(formatter)
.finish();
sourcepub fn with_env_filter(
self,
filter: impl Into<EnvFilter>
) -> SubscriberBuilder<N, E, EnvFilter, W>where
Formatter<N, E, W>: Subscriber + 'static,
pub fn with_env_filter( self, filter: impl Into<EnvFilter> ) -> SubscriberBuilder<N, E, EnvFilter, W>where Formatter<N, E, W>: Subscriber + 'static,
Sets the EnvFilter
that the subscriber will use to determine if
a span or event is enabled.
Note that this method requires the “env-filter” feature flag to be enabled.
If a filter was previously set, or a maximum level was set by the
with_max_level
method, that value is replaced by the new filter.
Examples
Setting a filter based on the value of the RUST_LOG
environment
variable:
use tracing_subscriber::{fmt, EnvFilter};
fmt()
.with_env_filter(EnvFilter::from_default_env())
.init();
Setting a filter based on a pre-set filter directive string:
use tracing_subscriber::fmt;
fmt()
.with_env_filter("my_crate=info,my_crate::my_mod=debug,[my_span]=trace")
.init();
Adding additional directives to a filter constructed from an env var:
use tracing_subscriber::{fmt, filter::{EnvFilter, LevelFilter}};
let filter = EnvFilter::try_from_env("MY_CUSTOM_FILTER_ENV_VAR")?
// Set the base level when not matched by other directives to WARN.
.add_directive(LevelFilter::WARN.into())
// Set the max level for `my_crate::my_mod` to DEBUG, overriding
// any directives parsed from the env variable.
.add_directive("my_crate::my_mod=debug".parse()?);
fmt()
.with_env_filter(filter)
.try_init()?;
sourcepub fn with_max_level(
self,
filter: impl Into<LevelFilter>
) -> SubscriberBuilder<N, E, LevelFilter, W>
pub fn with_max_level( self, filter: impl Into<LevelFilter> ) -> SubscriberBuilder<N, E, LevelFilter, W>
Sets the maximum verbosity level that will be enabled by the subscriber.
If the max level has already been set, or a EnvFilter
was added by
with_filter
, this replaces that configuration with the new
maximum level.
Examples
Enable up to the DEBUG
verbosity level:
use tracing_subscriber::fmt;
use tracing::Level;
fmt()
.with_max_level(Level::DEBUG)
.init();
This subscriber won’t record any spans or events!
use tracing_subscriber::{fmt, filter::LevelFilter};
let subscriber = fmt()
.with_max_level(LevelFilter::OFF)
.finish();
sourcepub fn event_format<E2>(self, fmt_event: E2) -> SubscriberBuilder<N, E2, F, W>where
E2: FormatEvent<Registry, N> + 'static,
N: for<'writer> FormatFields<'writer> + 'static,
W: MakeWriter + 'static,
pub fn event_format<E2>(self, fmt_event: E2) -> SubscriberBuilder<N, E2, F, W>where E2: FormatEvent<Registry, N> + 'static, N: for<'writer> FormatFields<'writer> + 'static, W: MakeWriter + 'static,
Sets the function that the subscriber being built should use to format events that occur.
sourcepub fn inherit_fields(self, inherit_fields: bool) -> Self
👎Deprecated since 0.2.0: this no longer does anything
pub fn inherit_fields(self, inherit_fields: bool) -> Self
Sets whether or not spans inherit their parents’ field values (disabled by default).
sourcepub fn on_event<E2>(self, fmt_event: E2) -> SubscriberBuilder<N, E2, F, W>where
E2: FormatEvent<Registry, N> + 'static,
N: for<'writer> FormatFields<'writer> + 'static,
W: MakeWriter + 'static,
👎Deprecated since 0.2.0: renamed to event_format
.
pub fn on_event<E2>(self, fmt_event: E2) -> SubscriberBuilder<N, E2, F, W>where E2: FormatEvent<Registry, N> + 'static, N: for<'writer> FormatFields<'writer> + 'static, W: MakeWriter + 'static,
event_format
.Sets the function that the subscriber being built should use to format events that occur.
sourcepub fn with_writer<W2>(self, make_writer: W2) -> SubscriberBuilder<N, E, F, W2>where
W2: MakeWriter + 'static,
pub fn with_writer<W2>(self, make_writer: W2) -> SubscriberBuilder<N, E, F, W2>where W2: MakeWriter + 'static,
Sets the MakeWriter
that the subscriber being built will use to write events.
Examples
Using stderr
rather than stdout
:
use tracing_subscriber::fmt;
use std::io;
fmt()
.with_writer(io::stderr)
.init();
sourcepub fn with_test_writer(self) -> SubscriberBuilder<N, E, F, TestWriter>
pub fn with_test_writer(self) -> SubscriberBuilder<N, E, F, TestWriter>
Configures the subscriber to support libtest
’s output capturing when used in
unit tests.
See TestWriter
for additional details.
Examples
Using TestWriter
to let cargo test
capture test output. Note that we do not install it
globally as it may cause conflicts.
use tracing_subscriber::fmt;
use tracing::subscriber;
subscriber::set_default(
fmt()
.with_test_writer()
.finish()
);
Trait Implementations§
source§impl Default for SubscriberBuilder
impl Default for SubscriberBuilder
source§impl<N, E, F, W> From<SubscriberBuilder<N, E, F, W>> for Dispatchwhere
N: for<'writer> FormatFields<'writer> + 'static,
E: FormatEvent<Registry, N> + 'static,
W: MakeWriter + 'static,
F: Layer<Formatter<N, E, W>> + Send + Sync + 'static,
Layer<Registry, N, E, W>: Layer<Registry> + Send + Sync + 'static,
impl<N, E, F, W> From<SubscriberBuilder<N, E, F, W>> for Dispatchwhere N: for<'writer> FormatFields<'writer> + 'static, E: FormatEvent<Registry, N> + 'static, W: MakeWriter + 'static, F: Layer<Formatter<N, E, W>> + Send + Sync + 'static, Layer<Registry, N, E, W>: Layer<Registry> + Send + Sync + 'static,
source§fn from(builder: SubscriberBuilder<N, E, F, W>) -> Dispatch
fn from(builder: SubscriberBuilder<N, E, F, W>) -> Dispatch
Auto Trait Implementations§
impl<N, E, F, W> RefUnwindSafe for SubscriberBuilder<N, E, F, W>where E: RefUnwindSafe, F: RefUnwindSafe, N: RefUnwindSafe, W: RefUnwindSafe,
impl<N, E, F, W> Send for SubscriberBuilder<N, E, F, W>where E: Send, F: Send, N: Send, W: Send,
impl<N, E, F, W> Sync for SubscriberBuilder<N, E, F, W>where E: Sync, F: Sync, N: Sync, W: Sync,
impl<N, E, F, W> Unpin for SubscriberBuilder<N, E, F, W>where E: Unpin, F: Unpin, N: Unpin, W: Unpin,
impl<N = DefaultFields, E = Format<Full, SystemTime>, F = LevelFilter, W = fn() -> Stdout> !UnwindSafe for SubscriberBuilder<N, E, F, W>
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> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> SubscriberInitExt for Twhere
T: Into<Dispatch>,
impl<T> SubscriberInitExt for Twhere T: Into<Dispatch>,
source§fn set_default(self) -> DefaultGuard
fn set_default(self) -> DefaultGuard
self
as the default subscriber in the current scope, returning a
guard that will unset it when dropped. Read moresource§fn try_init(self) -> Result<(), TryInitError>
fn try_init(self) -> Result<(), TryInitError>
self
as the global default subscriber in the current
scope, returning an error if one is already set. Read moresource§fn init(self)
fn init(self)
self
as the global default subscriber in the current
scope, panicking if this fails. Read more