48 releases
new 0.11.5 | Jan 12, 2025 |
---|---|
0.11.0-alpha.21 | Oct 21, 2024 |
0.11.0-alpha.7 | Jul 31, 2024 |
0.10.0 | Jul 4, 2016 |
0.1.0 | Aug 8, 2015 |
#48 in Debugging
868 downloads per month
Used in 8 crates
3MB
12K
SLoC
emit
Developer-first diagnostics for Rust applications
emit
is a framework for adding structured diagnostics to your Rust applications with a simple, powerful data model and an expressive syntax inspired by Message Templates. emit
's guiding design principle is low ceremony, low cognitive-load.
This readme covers just enough to give you an idea of what emit
is. For a proper treatment, see:
Getting started
Add emit
to your Cargo.toml
:
[dependencies.emit]
version = "0.11.5"
# Optional
features = ["serde"]
# Optional
[dependencies.emit_term]
version = "0.11.5"
# Optional
[dependencies.serde]
version = "1"
features = ["derive"]
Initialize emit
in your main.rs
and start peppering diagnostics throughout your application:
fn main() {
// Configure `emit` to write events to the console
let rt = emit::setup()
.emit_to(emit_term::stdout())
.init();
// Your app code goes here
greet(&User { id: 1, name: "Rust" });
// Flush any remaining events before `main` returns
rt.blocking_flush(std::time::Duration::from_secs(5));
}
#[derive(serde::Serialize)]
pub struct User<'a> {
id: u32,
name: &'a str,
}
#[emit::span("Greet {user}", #[emit::as_serde] user)]
fn greet(user: &User) {
emit::info!("Hello, {user: user.name}!");
}
Tracing
emit
can also produce trace data that's compatible with standard tracing tools, like Zipkin.
The above screenshot was generated by this example application.
See the guide for details.
Metrics
emit
can also produce metric data that's compatible with standard metric tools, like Prometheus.
The above screenshot was generated by this example application.
See the guide for details.
Quick debugging
emit
has a dbg!
macro like the standard library's which you can use for quick-and-dirty debugging:
#[derive(Debug)]
pub struct User<'a> {
id: u32,
name: &'a str,
}
emit::dbg!(&User { id: 1, name: "Rust" });
See the guide for details.