MeiliSearch/tracing-trace/src/bin/trace-to-callstats.rs

22 lines
829 B
Rust
Raw Normal View History

2024-01-24 09:50:51 +01:00
use std::ffi::OsString;
use std::io::Write;
2024-01-24 11:16:41 +01:00
use serde_json::json;
2024-01-24 09:50:51 +01:00
fn main() {
let input_file = std::env::args_os().nth(1).expect("missing <INPUT> file");
let input =
std::io::BufReader::new(std::fs::File::open(&input_file).expect("could not open <INPUT>"));
let trace = tracing_trace::TraceReader::new(input);
let profile = tracing_trace::processor::span_stats::to_call_stats(trace).unwrap();
let mut output_file = OsString::new();
output_file.push("callstats-");
output_file.push(input_file);
let mut output_file = std::io::BufWriter::new(std::fs::File::create(output_file).unwrap());
2024-01-24 11:16:41 +01:00
for (key, value) in profile {
serde_json::to_writer(&mut output_file, &json!({key: value})).unwrap();
writeln!(&mut output_file).unwrap();
}
2024-01-24 09:50:51 +01:00
output_file.flush().unwrap();
}