refactor: Don't special case --files

This commit is contained in:
Ed Page 2020-11-10 06:26:42 -06:00
parent 628c011f77
commit b7700fa214
2 changed files with 198 additions and 163 deletions

View file

@ -149,6 +149,10 @@ impl TyposSettings {
binary: self.binary, binary: self.binary,
} }
} }
pub fn build_files(&self) -> Files {
Files {}
}
} }
impl Default for TyposSettings { impl Default for TyposSettings {
@ -161,6 +165,123 @@ impl Default for TyposSettings {
} }
} }
#[derive(Debug, Clone)]
pub struct Typos {
check_filenames: bool,
check_files: bool,
binary: bool,
}
impl Check for Typos {
fn check_str(
&self,
buffer: &str,
parser: &tokens::Parser,
dictionary: &dyn Dictionary,
reporter: &dyn report::Report,
) -> Result<bool, crate::Error> {
let mut typos_found = false;
for ident in parser.parse_str(buffer) {
match dictionary.correct_ident(ident) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = ident.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer.as_bytes()),
byte_offset,
typo: ident.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {
for word in ident.split() {
match dictionary.correct_word(word) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = word.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer.as_bytes()),
byte_offset,
typo: word.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {}
}
}
}
}
}
Ok(typos_found)
}
fn check_bytes(
&self,
buffer: &[u8],
parser: &tokens::Parser,
dictionary: &dyn Dictionary,
reporter: &dyn report::Report,
) -> Result<bool, crate::Error> {
let mut typos_found = false;
for ident in parser.parse_bytes(buffer) {
match dictionary.correct_ident(ident) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = ident.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer),
byte_offset,
typo: ident.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {
for word in ident.split() {
match dictionary.correct_word(word) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = word.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer),
byte_offset,
typo: word.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {}
}
}
}
}
}
Ok(typos_found)
}
fn check_filenames(&self) -> bool {
self.check_filenames
}
fn check_files(&self) -> bool {
self.check_files
}
fn binary(&self) -> bool {
self.binary
}
}
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct ParseIdentifiers { pub struct ParseIdentifiers {
check_filenames: bool, check_filenames: bool,
@ -294,119 +415,68 @@ impl Check for ParseWords {
} }
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct Typos { pub struct Files {}
check_filenames: bool,
check_files: bool,
binary: bool,
}
impl Check for Typos { impl Check for Files {
fn check_str( fn check_str(
&self, &self,
buffer: &str, _buffer: &str,
parser: &tokens::Parser, _parser: &tokens::Parser,
dictionary: &dyn Dictionary, _dictionary: &dyn Dictionary,
reporter: &dyn report::Report, _reporter: &dyn report::Report,
) -> Result<bool, crate::Error> { ) -> Result<bool, crate::Error> {
let mut typos_found = false; let typos_found = false;
for ident in parser.parse_str(buffer) {
match dictionary.correct_ident(ident) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = ident.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer.as_bytes()),
byte_offset,
typo: ident.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {
for word in ident.split() {
match dictionary.correct_word(word) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = word.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer.as_bytes()),
byte_offset,
typo: word.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {}
}
}
}
}
}
Ok(typos_found) Ok(typos_found)
} }
fn check_bytes( fn check_bytes(
&self, &self,
buffer: &[u8], _buffer: &[u8],
parser: &tokens::Parser, _parser: &tokens::Parser,
dictionary: &dyn Dictionary, _dictionary: &dyn Dictionary,
reporter: &dyn report::Report, _reporter: &dyn report::Report,
) -> Result<bool, crate::Error> { ) -> Result<bool, crate::Error> {
let mut typos_found = false; let typos_found = false;
for ident in parser.parse_bytes(buffer) {
match dictionary.correct_ident(ident) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = ident.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer),
byte_offset,
typo: ident.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {
for word in ident.split() {
match dictionary.correct_word(word) {
Some(Status::Valid) => {}
Some(corrections) => {
let byte_offset = word.offset();
let msg = report::Typo {
context: report::Context::None,
buffer: std::borrow::Cow::Borrowed(buffer),
byte_offset,
typo: word.token(),
corrections,
};
typos_found |= reporter.report(msg.into());
}
None => {}
}
}
}
}
}
Ok(typos_found) Ok(typos_found)
} }
fn check_filenames(&self) -> bool { fn check_filenames(&self) -> bool {
self.check_filenames true
} }
fn check_files(&self) -> bool { fn check_files(&self) -> bool {
self.check_files true
} }
fn binary(&self) -> bool { fn binary(&self) -> bool {
self.binary true
}
fn check_filename(
&self,
_path: &std::path::Path,
_parser: &tokens::Parser,
_dictionary: &dyn Dictionary,
_reporter: &dyn report::Report,
) -> Result<bool, crate::Error> {
let typos_found = false;
Ok(typos_found)
}
fn check_file(
&self,
path: &std::path::Path,
_explicit: bool,
_parser: &tokens::Parser,
_dictionary: &dyn Dictionary,
reporter: &dyn report::Report,
) -> Result<bool, crate::Error> {
let typos_found = false;
let msg = report::File::new(path);
reporter.report(msg.into());
Ok(typos_found)
} }
} }

View file

@ -3,7 +3,6 @@
extern crate clap; extern crate clap;
use std::io::Write; use std::io::Write;
use std::sync::atomic;
use structopt::StructOpt; use structopt::StructOpt;
@ -91,77 +90,43 @@ fn run() -> Result<i32, anyhow::Error> {
reporter = &replace_reporter; reporter = &replace_reporter;
} }
if args.files { let (files, identifier_parser, word_parser, checks);
if single_threaded { let selected_checks: &dyn typos::checks::Check = if args.files {
for entry in walk.build() { files = settings.build_files();
match entry { &files
Ok(entry) => { } else if args.identifiers {
let msg = typos::report::File::new(entry.path()); identifier_parser = settings.build_identifier_parser();
reporter.report(msg.into()); &identifier_parser
} } else if args.words {
Err(err) => { word_parser = settings.build_word_parser();
let msg = typos::report::Error::new(err.to_string()); &word_parser
reporter.report(msg.into());
errors_found = true
}
}
}
} else {
let atomic_errors = atomic::AtomicBool::new(errors_found);
walk.build_parallel().run(|| {
Box::new(|entry: Result<ignore::DirEntry, ignore::Error>| {
match entry {
Ok(entry) => {
let msg = typos::report::File::new(entry.path());
reporter.report(msg.into());
}
Err(err) => {
let msg = typos::report::Error::new(err.to_string());
reporter.report(msg.into());
atomic_errors.store(true, atomic::Ordering::Relaxed);
}
}
ignore::WalkState::Continue
})
});
errors_found = atomic_errors.into_inner();
}
} else { } else {
let (identifier_parser, word_parser, checks); checks = settings.build_typos();
let selected_checks: &dyn typos::checks::Check = if args.identifiers { &checks
identifier_parser = settings.build_identifier_parser(); };
&identifier_parser
} else if args.words {
word_parser = settings.build_word_parser();
&word_parser
} else {
checks = settings.build_typos();
&checks
};
let (cur_typos, cur_errors) = if single_threaded { let (cur_typos, cur_errors) = if single_threaded {
checks::check_path( checks::check_path(
walk.build(), walk.build(),
selected_checks, selected_checks,
&parser, &parser,
&dictionary, &dictionary,
reporter, reporter,
) )
} else { } else {
checks::check_path_parallel( checks::check_path_parallel(
walk.build_parallel(), walk.build_parallel(),
selected_checks, selected_checks,
&parser, &parser,
&dictionary, &dictionary,
reporter, reporter,
) )
}; };
if cur_typos { if cur_typos {
typos_found = true; typos_found = true;
} }
if cur_errors { if cur_errors {
errors_found = true; errors_found = true;
}
} }
if args.write_changes { if args.write_changes {