[][src]Struct tracing_subscriber::fmt::SubscriberBuilder

pub struct SubscriberBuilder<N = DefaultFields, E = Format<Full>, F = LevelFilter, W = fn() -> Stdout> { /* fields omitted */ }
This is supported on crate feature fmt only.

Configures and constructs Subscribers.

Implementations

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, 
[src]

pub fn finish(self) -> Subscriber<N, E, F, W>[src]

This is supported on crate feature fmt only.

Finish the builder, returning a new FmtSubscriber.

pub fn try_init(self) -> Result<(), Box<dyn Error + Send + Sync + 'static>>[src]

This is supported on crate feature fmt only.

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 Events.

Errors

Returns an Error if the initialization was unsuccessful, likely because a global subscriber was already installed by another call to try_init.

pub fn init(self)[src]

This is supported on crate feature fmt only.

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 Events.

Panics

Panics if the initialization was unsuccessful, likely because a global subscriber was already installed by another call to try_init.

impl<N, L, T, F, W> SubscriberBuilder<N, Format<L, T>, F, W> where
    N: for<'writer> FormatFields<'writer> + 'static, 
[src]

pub fn with_timer<T2>(
    self,
    timer: T2
) -> SubscriberBuilder<N, Format<L, T2>, F, W>
[src]

This is supported on crate feature fmt only.

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.

pub fn without_time(self) -> SubscriberBuilder<N, Format<L, ()>, F, W>[src]

This is supported on crate feature fmt only.

Do not emit timestamps with log messages.

pub fn with_span_events(self, kind: FmtSpan) -> Self[src]

This is supported on crate feature fmt only.

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::ACTIVE: Events will be synthesized when spans are entered or 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::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.

Note that the generated events will only be part of the log output by this formatter; they will not be recorded by other Subscribers or by Layers added to this subscriber.

pub fn with_ansi(self, ansi: bool) -> SubscriberBuilder<N, Format<L, T>, F, W>[src]

This is supported on crate features fmt and ansi only.

Enable ANSI encoding for formatted events.

pub fn with_target(
    self,
    display_target: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
[src]

This is supported on crate feature fmt only.

Sets whether or not an event's target is displayed.

pub fn with_level(
    self,
    display_level: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
[src]

This is supported on crate feature fmt only.

Sets whether or not an event's level is displayed.

pub fn with_thread_names(
    self,
    display_thread_names: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
[src]

This is supported on crate feature fmt only.

Sets whether or not the name of the current thread is displayed when formatting events

pub fn with_thread_ids(
    self,
    display_thread_ids: bool
) -> SubscriberBuilder<N, Format<L, T>, F, W>
[src]

This is supported on crate feature fmt only.

Sets whether or not the thread ID of the current thread is displayed when formatting events

pub fn compact(self) -> SubscriberBuilder<N, Format<Compact, T>, F, W> where
    N: for<'writer> FormatFields<'writer> + 'static, 
[src]

This is supported on crate feature fmt only.

Sets the subscriber being built to use a less verbose formatter.

See format::Compact.

pub fn json(self) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W> where
    N: for<'writer> FormatFields<'writer> + 'static, 
[src]

This is supported on crate features fmt and json only.

Sets the subscriber being built to use a JSON formatter.

See format::Json

impl<T, F, W> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>[src]

pub fn flatten_event(
    self,
    flatten_event: bool
) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
[src]

This is supported on crate features fmt and json only.

Sets the json subscriber being built to flatten event metadata.

See format::Json

pub fn with_current_span(
    self,
    display_current_span: bool
) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
[src]

This is supported on crate features fmt and json only.

Sets whether or not the JSON layer being built will include the current span in formatted events.

See format::Json

pub fn with_span_list(
    self,
    display_span_list: bool
) -> SubscriberBuilder<JsonFields, Format<Json, T>, F, W>
[src]

This is supported on crate features fmt and json only.

Sets whether or not the JSON layer being built will include a list (from root to leaf) of all currently entered spans in formatted events.

See format::Json

impl<N, E, W> SubscriberBuilder<N, E, EnvFilter, W> where
    Formatter<N, E, W>: Subscriber + 'static, 
[src]

pub fn with_filter_reloading(
    self
) -> SubscriberBuilder<N, E, Layer<EnvFilter, Formatter<N, E, W>>, W>
[src]

This is supported on crate features fmt and env-filter only.

Configures the subscriber being built to allow filter reloading at runtime.

impl<N, E, W> SubscriberBuilder<N, E, Layer<EnvFilter, Formatter<N, E, W>>, W> where
    Formatter<N, E, W>: Subscriber + 'static, 
[src]

pub fn reload_handle(&self) -> Handle<EnvFilter, Formatter<N, E, W>>[src]

This is supported on crate features fmt and env-filter only.

Returns a Handle that may be used to reload the constructed subscriber's filter.

impl<N, E, F, W> SubscriberBuilder<N, E, F, W>[src]

pub fn fmt_fields<N2>(self, fmt_fields: N2) -> SubscriberBuilder<N2, E, F, W> where
    N2: for<'writer> FormatFields<'writer> + 'static, 
[src]

This is supported on crate feature fmt only.

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();

pub fn with_env_filter(
    self,
    filter: impl Into<EnvFilter>
) -> SubscriberBuilder<N, E, EnvFilter, W> where
    Formatter<N, E, W>: Subscriber + 'static, 
[src]

This is supported on crate features fmt and env-filter only.

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()?;

pub fn with_max_level(
    self,
    filter: impl Into<LevelFilter>
) -> SubscriberBuilder<N, E, LevelFilter, W>
[src]

This is supported on crate feature fmt only.

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();

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, 
[src]

This is supported on crate feature fmt only.

Sets the function that the subscriber being built should use to format events that occur.

pub fn inherit_fields(self, inherit_fields: bool) -> Self[src]

👎 Deprecated since 0.2.0:

this no longer does anything

This is supported on crate feature fmt only.

Sets whether or not spans inherit their parents' field values (disabled by default).

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, 
[src]

👎 Deprecated since 0.2.0:

renamed to event_format.

This is supported on crate feature fmt only.

Sets the function that the subscriber being built should use to format events that occur.

pub fn with_writer<W2>(self, make_writer: W2) -> SubscriberBuilder<N, E, F, W2> where
    W2: MakeWriter + 'static, 
[src]

This is supported on crate feature fmt only.

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();

pub fn with_test_writer(self) -> SubscriberBuilder<N, E, F, TestWriter>[src]

This is supported on crate feature fmt only.

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

impl<N: Debug, E: Debug, F: Debug, W: Debug> Debug for SubscriberBuilder<N, E, F, W>[src]

impl Default for SubscriberBuilder[src]

impl<N, E, F, W> Into<Dispatch> for 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, 
[src]

Auto Trait Implementations

impl<N = DefaultFields, E = Format<Full, SystemTime>, F = LevelFilter, W = fn() -> Stdout> !RefUnwindSafe for SubscriberBuilder<N, E, F, W>

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

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> SubscriberInitExt for T where
    T: Into<Dispatch>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.