-
Notifications
You must be signed in to change notification settings - Fork 721
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs: add doc-cfg attributes to tracing and tracing-core (#523)
Starts on #440. This branch adds `doc_cfg` attributes to `tracing` and `tracing-core`, when a `docsrs` cfg flag is passed to rustdoc. It also adds docs.rs crate metadata to configure docs.rs to set that flag, and adds it to the Netlify config as well. Signed-off-by: Eliza Weisman <eliza@buoyant.io> Co-authored-by: Jane Lusby <jlusby42@gmail.com>
- Loading branch information
Showing
12 changed files
with
194 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,11 @@ | ||
[build] | ||
command = "curl https://sh.rustup.rs -sSf | sh -s -- -y && source $HOME/.cargo/env && cargo doc --no-deps" | ||
command = """ | ||
curl https://sh.rustup.rs -sSf | sh -s -- -y --default-toolchain nightly --profile minimal \ | ||
&& source $HOME/.cargo/env \ | ||
&& RUSTDOCFLAGS=\"--cfg docsrs\" cargo +nightly doc --no-deps | ||
""" | ||
publish = "target/doc" | ||
|
||
[[redirects]] | ||
from = "/" | ||
to = "/tracing" | ||
to = "/tracing" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,159 @@ | ||
//! Dispatches trace events to [`Subscriber`]s. | ||
//! | ||
//! The _dispatcher_ is the component of the tracing system which is responsible | ||
//! for forwarding trace data from the instrumentation points that generate it | ||
//! to the subscriber that collects it. | ||
//! | ||
//! # Using the Trace Dispatcher | ||
//! | ||
//! Every thread in a program using `tracing` has a _default subscriber_. When | ||
//! events occur, or spans are created, they are dispatched to the thread's | ||
//! current subscriber. | ||
//! | ||
//! ## Setting the Default Subscriber | ||
//! | ||
//! By default, the current subscriber is an empty implementation that does | ||
//! nothing. To use a subscriber implementation, it must be set as the default. | ||
//! There are two methods for doing so: [`with_default`] and | ||
//! [`set_global_default`]. `with_default` sets the default subscriber for the | ||
//! duration of a scope, while `set_global_default` sets a default subscriber | ||
//! for the entire process. | ||
//! | ||
//! To use either of these functions, we must first wrap our subscriber in a | ||
//! [`Dispatch`], a cloneable, type-erased reference to a subscriber. For | ||
//! example: | ||
//! ```rust | ||
//! # pub struct FooSubscriber; | ||
//! # use tracing_core::{ | ||
//! # dispatcher, Event, Metadata, | ||
//! # span::{Attributes, Id, Record} | ||
//! # }; | ||
//! # impl tracing_core::Subscriber for FooSubscriber { | ||
//! # fn new_span(&self, _: &Attributes) -> Id { Id::from_u64(0) } | ||
//! # fn record(&self, _: &Id, _: &Record) {} | ||
//! # fn event(&self, _: &Event) {} | ||
//! # fn record_follows_from(&self, _: &Id, _: &Id) {} | ||
//! # fn enabled(&self, _: &Metadata) -> bool { false } | ||
//! # fn enter(&self, _: &Id) {} | ||
//! # fn exit(&self, _: &Id) {} | ||
//! # } | ||
//! # impl FooSubscriber { fn new() -> Self { FooSubscriber } } | ||
//! # fn main() { | ||
//! use dispatcher::Dispatch; | ||
//! | ||
//! let my_subscriber = FooSubscriber::new(); | ||
//! let my_dispatch = Dispatch::new(my_subscriber); | ||
//! # } | ||
//! ``` | ||
//! Then, we can use [`with_default`] to set our `Dispatch` as the default for | ||
//! the duration of a block: | ||
//! ```rust | ||
//! # pub struct FooSubscriber; | ||
//! # use tracing_core::{ | ||
//! # dispatcher, Event, Metadata, | ||
//! # span::{Attributes, Id, Record} | ||
//! # }; | ||
//! # impl tracing_core::Subscriber for FooSubscriber { | ||
//! # fn new_span(&self, _: &Attributes) -> Id { Id::from_u64(0) } | ||
//! # fn record(&self, _: &Id, _: &Record) {} | ||
//! # fn event(&self, _: &Event) {} | ||
//! # fn record_follows_from(&self, _: &Id, _: &Id) {} | ||
//! # fn enabled(&self, _: &Metadata) -> bool { false } | ||
//! # fn enter(&self, _: &Id) {} | ||
//! # fn exit(&self, _: &Id) {} | ||
//! # } | ||
//! # impl FooSubscriber { fn new() -> Self { FooSubscriber } } | ||
//! # fn main() { | ||
//! # let my_subscriber = FooSubscriber::new(); | ||
//! # let my_dispatch = dispatcher::Dispatch::new(my_subscriber); | ||
//! // no default subscriber | ||
//! | ||
//! # #[cfg(feature = "std")] | ||
//! dispatcher::with_default(&my_dispatch, || { | ||
//! // my_subscriber is the default | ||
//! }); | ||
//! | ||
//! // no default subscriber again | ||
//! # } | ||
//! ``` | ||
//! It's important to note that `with_default` will not propagate the current | ||
//! thread's default subscriber to any threads spawned within the `with_default` | ||
//! block. To propagate the default subscriber to new threads, either use | ||
//! `with_default` from the new thread, or use `set_global_default`. | ||
//! | ||
//! As an alternative to `with_default`, we can use [`set_global_default`] to | ||
//! set a `Dispatch` as the default for all threads, for the lifetime of the | ||
//! program. For example: | ||
//! ```rust | ||
//! # pub struct FooSubscriber; | ||
//! # use tracing_core::{ | ||
//! # dispatcher, Event, Metadata, | ||
//! # span::{Attributes, Id, Record} | ||
//! # }; | ||
//! # impl tracing_core::Subscriber for FooSubscriber { | ||
//! # fn new_span(&self, _: &Attributes) -> Id { Id::from_u64(0) } | ||
//! # fn record(&self, _: &Id, _: &Record) {} | ||
//! # fn event(&self, _: &Event) {} | ||
//! # fn record_follows_from(&self, _: &Id, _: &Id) {} | ||
//! # fn enabled(&self, _: &Metadata) -> bool { false } | ||
//! # fn enter(&self, _: &Id) {} | ||
//! # fn exit(&self, _: &Id) {} | ||
//! # } | ||
//! # impl FooSubscriber { fn new() -> Self { FooSubscriber } } | ||
//! # fn main() { | ||
//! # let my_subscriber = FooSubscriber::new(); | ||
//! # let my_dispatch = dispatcher::Dispatch::new(my_subscriber); | ||
//! // no default subscriber | ||
//! | ||
//! dispatcher::set_global_default(my_dispatch) | ||
//! // `set_global_default` will return an error if the global default | ||
//! // subscriber has already been set. | ||
//! .expect("global default was already set!"); | ||
//! | ||
//! // `my_subscriber` is now the default | ||
//! # } | ||
//! ``` | ||
//! | ||
//! **Note**: the thread-local scoped dispatcher (`with_default`) requires the | ||
//! Rust standard library. `no_std` users should use [`set_global_default`] | ||
//! instead. | ||
//! | ||
//! Finally, `tokio` users should note that versions of `tokio` >= 0.1.22 | ||
//! support an `experimental-tracing` feature flag. When this flag is enabled, | ||
//! the `tokio` runtime's thread pool will automatically propagate the default | ||
//! subscriber. This means that if `tokio::runtime::Runtime::new()` or | ||
//! `tokio::run()` are invoked when a default subscriber is set, it will also be | ||
//! set by all worker threads created by that runtime. | ||
//! | ||
//! ## Accessing the Default Subscriber | ||
//! | ||
//! A thread's current default subscriber can be accessed using the | ||
//! [`get_default`] function, which executes a closure with a reference to the | ||
//! currently default `Dispatch`. This is used primarily by `tracing` | ||
//! instrumentation. | ||
//! | ||
//! [`Subscriber`]: struct.Subscriber.html | ||
//! [`with_default`]: fn.with_default.html | ||
//! [`set_global_default`]: fn.set_global_default.html | ||
//! [`get_default`]: fn.get_default.html | ||
//! [`Dispatch`]: struct.Dispatch.html | ||
#[cfg(feature = "std")] | ||
#[cfg_attr(docsrs, doc(cfg(feature = "std")))] | ||
pub use tracing_core::dispatcher::set_default; | ||
#[cfg(feature = "std")] | ||
#[cfg_attr(docsrs, doc(cfg(feature = "std")))] | ||
pub use tracing_core::dispatcher::with_default; | ||
#[cfg(feature = "std")] | ||
#[cfg_attr(docsrs, doc(cfg(feature = "std")))] | ||
pub use tracing_core::dispatcher::DefaultGuard; | ||
pub use tracing_core::dispatcher::{ | ||
get_default, set_global_default, Dispatch, SetGlobalDefaultError, | ||
}; | ||
|
||
/// Private API for internal use by tracing's macros. | ||
/// | ||
/// This function is *not* considered part of `tracing`'s public API, and has no | ||
/// stability guarantees. If you use it, and it breaks or disappears entirely, | ||
/// don't say we didn;'t warn you. | ||
#[doc(hidden)] | ||
pub use tracing_core::dispatcher::has_been_set; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters