33 lines
912 B
Rust
33 lines
912 B
Rust
use std::env;
|
|
use std::fs::File;
|
|
use std::io::prelude::*;
|
|
|
|
use saphyr_parser::{Event, Parser, Span, SpannedEventReceiver};
|
|
|
|
/// A sink which discards any event sent.
|
|
struct NullSink {}
|
|
|
|
impl SpannedEventReceiver for NullSink {
|
|
fn on_event(&mut self, _: Event, _: Span) {}
|
|
}
|
|
|
|
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 {};
|
|
let mut parser = Parser::new_from_str(&s);
|
|
|
|
// 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();
|
|
|
|
if args.len() == 3 && args[2] == "--short" {
|
|
println!("{}", (end - begin).as_nanos());
|
|
} else {
|
|
println!("Loaded {}MiB in {:?}", s.len() / 1024 / 1024, end - begin);
|
|
}
|
|
}
|