1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
|
use annotate_snippets::{Level, Renderer, Snippet};
#[divan::bench]
fn simple() -> String {
let source = r#") -> Option<String> {
for ann in annotations {
match (ann.range.0, ann.range.1) {
(None, None) => continue,
(Some(start), Some(end)) if start > end_index => continue,
(Some(start), Some(end)) if start >= start_index => {
let label = if let Some(ref label) = ann.label {
format!(" {}", label)
} else {
String::from("")
};
return Some(format!(
"{}{}{}",
" ".repeat(start - start_index),
"^".repeat(end - start),
label
));
}
_ => continue,
}
}"#;
let message = Level::Error.title("mismatched types").id("E0308").snippet(
Snippet::source(source)
.line_start(51)
.origin("src/format.rs")
.annotation(
Level::Warning
.span(5..19)
.label("expected `Option<String>` because of return type"),
)
.annotation(
Level::Error
.span(26..724)
.label("expected enum `std::option::Option`"),
),
);
let renderer = Renderer::plain();
let rendered = renderer.render(message).to_string();
rendered
}
#[divan::bench(args=[0, 1, 10, 100, 1_000, 10_000, 100_000])]
fn fold(bencher: divan::Bencher<'_, '_>, context: usize) {
bencher
.with_inputs(|| {
let line = "012345678901234567890123456789";
let mut input = String::new();
for _ in 1..=context {
input.push_str(line);
input.push('\n');
}
let span_start = input.len() + line.len();
let span = span_start..span_start;
input.push_str(line);
input.push('\n');
for _ in 1..=context {
input.push_str(line);
input.push('\n');
}
(input, span)
})
.bench_values(|(input, span)| {
let message = Level::Error.title("mismatched types").id("E0308").snippet(
Snippet::source(&input)
.fold(true)
.origin("src/format.rs")
.annotation(
Level::Warning
.span(span)
.label("expected `Option<String>` because of return type"),
),
);
let renderer = Renderer::plain();
let rendered = renderer.render(message).to_string();
rendered
});
}
fn main() {
divan::main();
}
|