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;