summaryrefslogtreecommitdiffstats
path: root/vendor/winnow-0.4.7/benches
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-07 05:48:42 +0000
commitcec1877e180393eba0f6ddb0cf97bf3a791631c7 (patch)
tree47b4dac2a9dd9a40c30c251b4d4a72d7ccf77e9f /vendor/winnow-0.4.7/benches
parentAdding debian version 1.74.1+dfsg1-1. (diff)
downloadrustc-cec1877e180393eba0f6ddb0cf97bf3a791631c7.tar.xz
rustc-cec1877e180393eba0f6ddb0cf97bf3a791631c7.zip
Merging upstream version 1.75.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/winnow-0.4.7/benches')
-rw-r--r--vendor/winnow-0.4.7/benches/contains_token.rs102
-rw-r--r--vendor/winnow-0.4.7/benches/number.rs70
2 files changed, 172 insertions, 0 deletions
diff --git a/vendor/winnow-0.4.7/benches/contains_token.rs b/vendor/winnow-0.4.7/benches/contains_token.rs
new file mode 100644
index 000000000..a35c1b2b1
--- /dev/null
+++ b/vendor/winnow-0.4.7/benches/contains_token.rs
@@ -0,0 +1,102 @@
+use criterion::black_box;
+
+use winnow::combinator::alt;
+use winnow::combinator::repeat;
+use winnow::prelude::*;
+use winnow::token::take_till1;
+use winnow::token::take_while;
+
+fn contains_token(c: &mut criterion::Criterion) {
+ let data = [
+ ("contiguous", CONTIGUOUS),
+ ("interleaved", INTERLEAVED),
+ ("canada", CANADA),
+ ];
+ let mut group = c.benchmark_group("contains_token");
+ for (name, sample) in data {
+ let len = sample.len();
+ group.throughput(criterion::Throughput::Bytes(len as u64));
+
+ group.bench_with_input(criterion::BenchmarkId::new("str", name), &len, |b, _| {
+ b.iter(|| black_box(parser_str.parse_next(black_box(sample)).unwrap()));
+ });
+ group.bench_with_input(criterion::BenchmarkId::new("slice", name), &len, |b, _| {
+ b.iter(|| black_box(parser_slice.parse_next(black_box(sample)).unwrap()));
+ });
+ group.bench_with_input(criterion::BenchmarkId::new("array", name), &len, |b, _| {
+ b.iter(|| black_box(parser_array.parse_next(black_box(sample)).unwrap()));
+ });
+ group.bench_with_input(criterion::BenchmarkId::new("tuple", name), &len, |b, _| {
+ b.iter(|| black_box(parser_tuple.parse_next(black_box(sample)).unwrap()));
+ });
+ group.bench_with_input(
+ criterion::BenchmarkId::new("closure-or", name),
+ &len,
+ |b, _| {
+ b.iter(|| black_box(parser_closure_or.parse_next(black_box(sample)).unwrap()));
+ },
+ );
+ group.bench_with_input(
+ criterion::BenchmarkId::new("closure-matches", name),
+ &len,
+ |b, _| {
+ b.iter(|| {
+ black_box(
+ parser_closure_matches
+ .parse_next(black_box(sample))
+ .unwrap(),
+ )
+ });
+ },
+ );
+ }
+ group.finish();
+}
+
+fn parser_str(input: &str) -> IResult<&str, usize> {
+ let contains = "0123456789";
+ repeat(0.., alt((take_while(1.., contains), take_till1(contains)))).parse_next(input)
+}
+
+fn parser_slice(input: &str) -> IResult<&str, usize> {
+ let contains = &['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'][..];
+ repeat(0.., alt((take_while(1.., contains), take_till1(contains)))).parse_next(input)
+}
+
+fn parser_array(input: &str) -> IResult<&str, usize> {
+ let contains = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'];
+ repeat(0.., alt((take_while(1.., contains), take_till1(contains)))).parse_next(input)
+}
+
+fn parser_tuple(input: &str) -> IResult<&str, usize> {
+ let contains = ('0', '1', '2', '3', '4', '5', '6', '7', '8', '9');
+ repeat(0.., alt((take_while(1.., contains), take_till1(contains)))).parse_next(input)
+}
+
+fn parser_closure_or(input: &str) -> IResult<&str, usize> {
+ let contains = |c: char| {
+ c == '0'
+ || c == '1'
+ || c == '2'
+ || c == '3'
+ || c == '4'
+ || c == '5'
+ || c == '6'
+ || c == '7'
+ || c == '8'
+ || c == '9'
+ };
+ repeat(0.., alt((take_while(1.., contains), take_till1(contains)))).parse_next(input)
+}
+
+fn parser_closure_matches(input: &str) -> IResult<&str, usize> {
+ let contains = |c: char| matches!(c, '0' | '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9');
+ repeat(0.., alt((take_while(1.., contains), take_till1(contains)))).parse_next(input)
+}
+
+const CONTIGUOUS: &str = "012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789";
+const INTERLEAVED: &str = "0123456789abc0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab0123456789ab";
+const CANADA: &str = include_str!("../third_party/nativejson-benchmark/data/canada.json");
+
+criterion::criterion_group!(benches, contains_token);
+criterion::criterion_main!(benches);
diff --git a/vendor/winnow-0.4.7/benches/number.rs b/vendor/winnow-0.4.7/benches/number.rs
new file mode 100644
index 000000000..b6c6fac57
--- /dev/null
+++ b/vendor/winnow-0.4.7/benches/number.rs
@@ -0,0 +1,70 @@
+#[macro_use]
+extern crate criterion;
+
+use criterion::Criterion;
+
+use winnow::ascii::float;
+use winnow::binary::be_u64;
+use winnow::error::ErrMode;
+use winnow::error::Error;
+use winnow::error::ErrorKind;
+use winnow::prelude::*;
+use winnow::stream::ParseSlice;
+
+type Stream<'i> = &'i [u8];
+
+fn parser(i: Stream<'_>) -> IResult<Stream<'_>, u64> {
+ be_u64(i)
+}
+
+fn number(c: &mut Criterion) {
+ let data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12];
+
+ parser(&data[..]).expect("should parse correctly");
+ c.bench_function("number", move |b| {
+ b.iter(|| parser(&data[..]).unwrap());
+ });
+}
+
+fn float_bytes(c: &mut Criterion) {
+ println!(
+ "float_bytes result: {:?}",
+ float::<_, f64, Error<_>>(&b"-1.234E-12"[..])
+ );
+ c.bench_function("float bytes", |b| {
+ b.iter(|| float::<_, f64, Error<_>>(&b"-1.234E-12"[..]));
+ });
+}
+
+fn float_str(c: &mut Criterion) {
+ println!(
+ "float_str result: {:?}",
+ float::<_, f64, Error<_>>("-1.234E-12")
+ );
+ c.bench_function("float str", |b| {
+ b.iter(|| float::<_, f64, Error<_>>("-1.234E-12"));
+ });
+}
+
+fn std_float(input: &[u8]) -> IResult<&[u8], f64, Error<&[u8]>> {
+ match input.parse_slice() {
+ Some(n) => Ok((&[], n)),
+ None => Err(ErrMode::Backtrack(Error {
+ input,
+ kind: ErrorKind::Slice,
+ })),
+ }
+}
+
+fn std_float_bytes(c: &mut Criterion) {
+ println!(
+ "std_float_bytes result: {:?}",
+ std_float(&b"-1.234E-12"[..])
+ );
+ c.bench_function("std_float bytes", |b| {
+ b.iter(|| std_float(&b"-1.234E-12"[..]));
+ });
+}
+
+criterion_group!(benches, number, float_bytes, std_float_bytes, float_str);
+criterion_main!(benches);