saphyr-serde/parser/tools/time_parse.rs

34 lines
912 B
Rust
Raw Permalink Normal View History

2024-06-13 20:05:43 +00:00
use std::env;
use std::fs::File;
use std::io::prelude::*;
2024-01-23 21:48:20 +00:00
2024-08-05 15:08:23 +00:00
use saphyr_parser::{Event, Parser, Span, SpannedEventReceiver};
2024-01-23 21:48:20 +00:00
/// A sink which discards any event sent.
struct NullSink {}
2024-08-05 15:08:23 +00:00
impl SpannedEventReceiver for NullSink {
fn on_event(&mut self, _: Event, _: Span) {}
2024-01-23 21:48:20 +00:00
}
fn main() {
let args: Vec<_> = env::args().collect();
let mut f = File::open(&args[1]).unwrap();
let mut s = String::new();
f.read_to_string(&mut s).unwrap();
let mut sink = NullSink {};
2024-03-24 21:51:15 +00:00
let mut parser = Parser::new_from_str(&s);
2024-01-23 21:48:20 +00:00
// Load events using our sink as the receiver.
let begin = std::time::Instant::now();
parser.load(&mut sink, true).unwrap();
let end = std::time::Instant::now();
2024-03-15 16:34:39 +00:00
if args.len() == 3 && args[2] == "--short" {
println!("{}", (end - begin).as_nanos());
} else {
println!("Loaded {}MiB in {:?}", s.len() / 1024 / 1024, end - begin);
}
2024-01-23 21:48:20 +00:00
}