mirror of
https://github.com/crate-ci/typos.git
synced 2025-01-08 15:54:47 -05:00
fix(parse): Don't skip binary files when explicitly requested
Fixes #35
This commit is contained in:
parent
6142941cfc
commit
750005e971
3 changed files with 10 additions and 8 deletions
|
@ -15,7 +15,7 @@ fn process_empty(b: &mut test::Bencher) {
|
|||
let corrections = typos::BuiltIn::new();
|
||||
let parser = typos::tokens::Parser::new();
|
||||
let checks = typos::checks::CheckSettings::new().build(&corrections, &parser);
|
||||
b.iter(|| checks.check_file(sample_path.path(), typos::report::print_silent));
|
||||
b.iter(|| checks.check_file(sample_path.path(), true, typos::report::print_silent));
|
||||
|
||||
temp.close().unwrap();
|
||||
}
|
||||
|
@ -29,7 +29,7 @@ fn process_no_tokens(b: &mut test::Bencher) {
|
|||
let corrections = typos::BuiltIn::new();
|
||||
let parser = typos::tokens::Parser::new();
|
||||
let checks = typos::checks::CheckSettings::new().build(&corrections, &parser);
|
||||
b.iter(|| checks.check_file(sample_path.path(), typos::report::print_silent));
|
||||
b.iter(|| checks.check_file(sample_path.path(), true, typos::report::print_silent));
|
||||
|
||||
temp.close().unwrap();
|
||||
}
|
||||
|
@ -43,7 +43,7 @@ fn process_single_token(b: &mut test::Bencher) {
|
|||
let corrections = typos::BuiltIn::new();
|
||||
let parser = typos::tokens::Parser::new();
|
||||
let checks = typos::checks::CheckSettings::new().build(&corrections, &parser);
|
||||
b.iter(|| checks.check_file(sample_path.path(), typos::report::print_silent));
|
||||
b.iter(|| checks.check_file(sample_path.path(), true, typos::report::print_silent));
|
||||
|
||||
temp.close().unwrap();
|
||||
}
|
||||
|
@ -57,7 +57,7 @@ fn process_sherlock(b: &mut test::Bencher) {
|
|||
let corrections = typos::BuiltIn::new();
|
||||
let parser = typos::tokens::Parser::new();
|
||||
let checks = typos::checks::CheckSettings::new().build(&corrections, &parser);
|
||||
b.iter(|| checks.check_file(sample_path.path(), typos::report::print_silent));
|
||||
b.iter(|| checks.check_file(sample_path.path(), true, typos::report::print_silent));
|
||||
|
||||
temp.close().unwrap();
|
||||
}
|
||||
|
@ -71,7 +71,7 @@ fn process_code(b: &mut test::Bencher) {
|
|||
let corrections = typos::BuiltIn::new();
|
||||
let parser = typos::tokens::Parser::new();
|
||||
let checks = typos::checks::CheckSettings::new().build(&corrections, &parser);
|
||||
b.iter(|| checks.check_file(sample_path.path(), typos::report::print_silent));
|
||||
b.iter(|| checks.check_file(sample_path.path(), true, typos::report::print_silent));
|
||||
|
||||
temp.close().unwrap();
|
||||
}
|
||||
|
@ -85,7 +85,7 @@ fn process_corpus(b: &mut test::Bencher) {
|
|||
let corrections = typos::BuiltIn::new();
|
||||
let parser = typos::tokens::Parser::new();
|
||||
let checks = typos::checks::CheckSettings::new().build(&corrections, &parser);
|
||||
b.iter(|| checks.check_file(sample_path.path(), typos::report::print_silent));
|
||||
b.iter(|| checks.check_file(sample_path.path(), true, typos::report::print_silent));
|
||||
|
||||
temp.close().unwrap();
|
||||
}
|
||||
|
|
|
@ -111,6 +111,7 @@ impl<'d, 'p> Checks<'d, 'p> {
|
|||
pub fn check_file(
|
||||
&self,
|
||||
path: &std::path::Path,
|
||||
explicit: bool,
|
||||
report: report::Report,
|
||||
) -> Result<bool, failure::Error> {
|
||||
let mut typos_found = false;
|
||||
|
@ -121,7 +122,7 @@ impl<'d, 'p> Checks<'d, 'p> {
|
|||
|
||||
let mut buffer = Vec::new();
|
||||
File::open(path)?.read_to_end(&mut buffer)?;
|
||||
if !self.binary && buffer.find_byte(b'\0').is_some() {
|
||||
if !explicit && !self.binary && buffer.find_byte(b'\0').is_some() {
|
||||
let msg = report::BinaryFile {
|
||||
path,
|
||||
non_exhaustive: (),
|
||||
|
|
|
@ -290,10 +290,11 @@ fn run() -> Result<i32, failure::Error> {
|
|||
for entry in walk.build() {
|
||||
let entry = entry?;
|
||||
if entry.file_type().map(|t| t.is_file()).unwrap_or(true) {
|
||||
let explicit = entry.depth() == 0;
|
||||
if checks.check_filename(entry.path(), options.format.report())? {
|
||||
typos_found = true;
|
||||
}
|
||||
if checks.check_file(entry.path(), options.format.report())? {
|
||||
if checks.check_file(entry.path(), explicit, options.format.report())? {
|
||||
typos_found = true;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue