mirror of
https://github.com/crate-ci/typos.git
synced 2025-02-18 19:12:50 -05:00
bench: Remove cased_map
This commit is contained in:
parent
dcc8f15fae
commit
4330c4b8d5
3 changed files with 0 additions and 256014 deletions
File diff suppressed because it is too large
Load diff
|
@ -2,7 +2,6 @@
|
|||
#![allow(dead_code)]
|
||||
|
||||
mod aho_corasick_codegen;
|
||||
mod cased_map_codegen;
|
||||
mod map_codegen;
|
||||
|
||||
static AHO_CORASICK: std::sync::LazyLock<aho_corasick_codegen::Word> =
|
||||
|
@ -22,11 +21,6 @@ mod miss {
|
|||
|
||||
const MISS: &str = "finalizes";
|
||||
|
||||
#[divan::bench(args = [MISS])]
|
||||
fn cased_map(word: &str) -> Option<&'static &[&str]> {
|
||||
cased_map_codegen::WORD_ASCII_LOWER.find(&word)
|
||||
}
|
||||
|
||||
#[divan::bench(args = [unicase::UniCase::new(MISS)])]
|
||||
fn map(word: unicase::UniCase<&str>) -> Option<&'static &[&str]> {
|
||||
map_codegen::WORD.find(&word)
|
||||
|
@ -43,11 +37,6 @@ mod hit {
|
|||
|
||||
const HIT: &str = "finallizes";
|
||||
|
||||
#[divan::bench(args = [HIT])]
|
||||
fn cased_map(word: &str) -> Option<&'static &[&str]> {
|
||||
cased_map_codegen::WORD_ASCII_LOWER.find(&word)
|
||||
}
|
||||
|
||||
#[divan::bench(args = [unicase::UniCase::new(HIT)])]
|
||||
fn map(word: unicase::UniCase<&str>) -> Option<&'static &[&str]> {
|
||||
map_codegen::WORD.find(&word)
|
||||
|
|
|
@ -11,15 +11,6 @@ fn codegen() {
|
|||
snapbox::file!["../benches/benches/map_codegen.rs"].raw()
|
||||
);
|
||||
|
||||
let mut cased_map_content = vec![];
|
||||
generate_cased_map(&mut cased_map_content, "WORD", DICT);
|
||||
let cased_map_content = String::from_utf8(cased_map_content).unwrap();
|
||||
let cased_map_content = codegenrs::rustfmt(&cased_map_content, None).unwrap();
|
||||
snapbox::assert_data_eq!(
|
||||
&cased_map_content,
|
||||
snapbox::file!["../benches/benches/cased_map_codegen.rs"].raw()
|
||||
);
|
||||
|
||||
let mut aho_corasick_content = vec![];
|
||||
generate_aho_corasick(&mut aho_corasick_content, "Word", DICT);
|
||||
let aho_corasick_content = String::from_utf8(aho_corasick_content).unwrap();
|
||||
|
@ -32,111 +23,6 @@ fn codegen() {
|
|||
snapbox::assert_data_eq!(&map_content, snapbox::file!["../src/word_codegen.rs"].raw());
|
||||
}
|
||||
|
||||
fn generate_cased_map<W: std::io::Write>(file: &mut W, name: &str, dict: &[u8]) {
|
||||
writeln!(
|
||||
file,
|
||||
"// This file is @generated by {}",
|
||||
file!().replace('\\', "/")
|
||||
)
|
||||
.unwrap();
|
||||
writeln!(file, "#![allow(clippy::unreadable_literal)]",).unwrap();
|
||||
writeln!(file, "#![allow(unreachable_pub)]",).unwrap();
|
||||
writeln!(file).unwrap();
|
||||
|
||||
let records: Vec<_> = csv::ReaderBuilder::new()
|
||||
.has_headers(false)
|
||||
.flexible(true)
|
||||
.from_reader(dict)
|
||||
.records()
|
||||
.map(|r| r.unwrap())
|
||||
.collect();
|
||||
dictgen::DictGen::new()
|
||||
.name(&format!("{name}_ASCII_LOWER"))
|
||||
.value_type("&[&str]")
|
||||
.map()
|
||||
.unicase(false)
|
||||
.write(
|
||||
file,
|
||||
records
|
||||
.iter()
|
||||
.filter(|r| r.iter().next().unwrap().is_ascii())
|
||||
.map(|record| {
|
||||
let mut record_fields = record.iter();
|
||||
let key = record_fields.next().unwrap();
|
||||
let value = format!(
|
||||
"&[{}]",
|
||||
itertools::join(record_fields.map(|field| format!(r#""{field}""#)), ", ")
|
||||
);
|
||||
(key, value)
|
||||
}),
|
||||
)
|
||||
.unwrap();
|
||||
dictgen::DictGen::new()
|
||||
.name(&format!("{name}_ASCII_UPPER"))
|
||||
.value_type("&[&str]")
|
||||
.map()
|
||||
.unicase(false)
|
||||
.write(
|
||||
file,
|
||||
records
|
||||
.iter()
|
||||
.filter(|r| r.iter().next().unwrap().is_ascii())
|
||||
.map(|record| {
|
||||
use heck::ToShoutySnakeCase;
|
||||
let mut record_fields = record.iter();
|
||||
let key = record_fields.next().unwrap().to_shouty_snake_case();
|
||||
let value = format!(
|
||||
"&[{}]",
|
||||
itertools::join(record_fields.map(|field| format!(r#""{field}""#)), ", ")
|
||||
);
|
||||
(key, value)
|
||||
}),
|
||||
)
|
||||
.unwrap();
|
||||
dictgen::DictGen::new()
|
||||
.name(&format!("{name}_ASCII_TITLE"))
|
||||
.value_type("&[&str]")
|
||||
.map()
|
||||
.unicase(false)
|
||||
.write(
|
||||
file,
|
||||
records
|
||||
.iter()
|
||||
.filter(|r| r.iter().next().unwrap().is_ascii())
|
||||
.map(|record| {
|
||||
use heck::ToTitleCase;
|
||||
let mut record_fields = record.iter();
|
||||
let key = record_fields.next().unwrap().to_title_case();
|
||||
let value = format!(
|
||||
"&[{}]",
|
||||
itertools::join(record_fields.map(|field| format!(r#""{field}""#)), ", ")
|
||||
);
|
||||
(key, value)
|
||||
}),
|
||||
)
|
||||
.unwrap();
|
||||
dictgen::DictGen::new()
|
||||
.name(&format!("{name}_UNICODE"))
|
||||
.value_type("&[&str]")
|
||||
.ordered_map()
|
||||
.write(
|
||||
file,
|
||||
records
|
||||
.iter()
|
||||
.filter(|r| !r.iter().next().unwrap().is_ascii())
|
||||
.map(|record| {
|
||||
let mut record_fields = record.iter();
|
||||
let key = record_fields.next().unwrap();
|
||||
let value = format!(
|
||||
"&[{}]",
|
||||
itertools::join(record_fields.map(|field| format!(r#""{field}""#)), ", ")
|
||||
);
|
||||
(key, value)
|
||||
}),
|
||||
)
|
||||
.unwrap();
|
||||
}
|
||||
|
||||
fn generate_map<W: std::io::Write>(file: &mut W, name: &str, dict: &[u8]) {
|
||||
writeln!(
|
||||
file,
|
||||
|
|
Loading…
Add table
Reference in a new issue