#[macro_use] extern crate criterion; use criterion::Criterion; use winnow::ascii::float; use winnow::binary::be_u64; use winnow::error::ErrMode; use winnow::error::ErrorKind; use winnow::error::InputError; use winnow::error::ParserError; use winnow::prelude::*; use winnow::stream::ParseSlice; type Stream<'i> = &'i [u8]; fn parser(i: &mut Stream<'_>) -> PResult { be_u64.parse_next(i) } fn number(c: &mut Criterion) { let data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]; parser .parse_peek(&data[..]) .expect("should parse correctly"); c.bench_function("number", move |b| { b.iter(|| parser.parse_peek(&data[..]).unwrap()); }); } fn float_bytes(c: &mut Criterion) { println!( "float_bytes result: {:?}", float::<_, f64, InputError<_>>.parse_peek(&b"-1.234E-12"[..]) ); c.bench_function("float bytes", |b| { b.iter(|| float::<_, f64, InputError<_>>.parse_peek(&b"-1.234E-12"[..])); }); } fn float_str(c: &mut Criterion) { println!( "float_str result: {:?}", float::<_, f64, InputError<_>>.parse_peek("-1.234E-12") ); c.bench_function("float str", |b| { b.iter(|| float::<_, f64, InputError<_>>.parse_peek("-1.234E-12")); }); } fn std_float(input: &mut &[u8]) -> PResult { match input.parse_slice() { Some(n) => Ok(n), None => Err(ErrMode::from_error_kind(input, ErrorKind::Slice)), } } fn std_float_bytes(c: &mut Criterion) { println!( "std_float_bytes result: {:?}", std_float.parse_peek(&b"-1.234E-12"[..]) ); c.bench_function("std_float bytes", |b| { b.iter(|| std_float.parse_peek(&b"-1.234E-12"[..])); }); } criterion_group!(benches, number, float_bytes, std_float_bytes, float_str); criterion_main!(benches);