1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
//! Server-Timing support for Tide + Tracing
//!
//! # Examples
//!
//! ```no_run
//! use tide_server_timing::{TimingLayer, TimingMiddleware};
//! use tracing_core::Level;
//! use tracing_subscriber::layer::SubscriberExt;
//!
//! #[async_std::main]
//! async fn main() -> tide::Result<()> {
//!     let sub = tracing_subscriber::fmt()
//!         .with_max_level(Level::TRACE)
//!         .finish()
//!         .with(TimingLayer::new());
//!
//!     tracing::subscriber::set_global_default(sub).expect("no global subscriber has been set");
//!
//!     let mut app = tide::new();
//!     app.with(TimingMiddleware::new());
//!     app.at("/").get(|_| async move { Ok("Hello chashu") });
//!     app.listen("localhost:8080").await?;
//!     Ok(())
//! }
//! ```

#![forbid(future_incompatible, rust_2018_idioms)]
#![deny(missing_debug_implementations, nonstandard_style)]
#![warn(missing_docs, missing_doc_code_examples, unreachable_pub)]

mod middleware;
mod span_ext;
mod timing_layer;

use timing_layer::{SpanRootTiming, SpanTiming};

pub use middleware::TimingMiddleware;
pub use timing_layer::TimingLayer;