42 releases
0.11.0-alpha.21 | Oct 21, 2024 |
---|---|
0.11.0-alpha.17 | Sep 20, 2024 |
0.11.0-alpha.7 | Jul 31, 2024 |
0.10.0 | Jul 4, 2016 |
0.1.0 | Aug 8, 2015 |
#64 in Debugging
205 downloads per month
Used in 8 crates
3MB
11K
SLoC
emit
Developer-first diagnostics for Rust applications
emit
is a framework for adding 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.0-alpha.21"
[dependencies.emit_term]
version = "0.11.0-alpha.21"
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
//
// Try uncommenting the following line as an example:
//
// greet("Rust");
// Flush any remaining events before `main` returns
rt.blocking_flush(std::time::Duration::from_secs(5));
}
#[emit::span("Greet {user}")]
fn greet(user: &str) {
emit::info!("Hello, {user}!");
}