mirror of
https://github.com/crate-ci/typos.git
synced 2025-01-25 07:58:58 -05:00
refactor(cli): Share bool logic
This commit is contained in:
parent
517da7ecd2
commit
6146824b4e
1 changed files with 18 additions and 54 deletions
68
src/args.rs
68
src/args.rs
|
@ -145,30 +145,15 @@ impl FileArgs {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn binary(&self) -> Option<bool> {
|
fn binary(&self) -> Option<bool> {
|
||||||
match (self.binary, self.no_binary) {
|
resolve_bool_arg(self.binary, self.no_binary)
|
||||||
(true, false) => Some(true),
|
|
||||||
(false, true) => Some(false),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_filename(&self) -> Option<bool> {
|
fn check_filename(&self) -> Option<bool> {
|
||||||
match (self.check_filenames, self.no_check_filenames) {
|
resolve_bool_arg(self.check_filenames, self.no_check_filenames)
|
||||||
(true, false) => Some(true),
|
|
||||||
(false, true) => Some(false),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_file(&self) -> Option<bool> {
|
fn check_file(&self) -> Option<bool> {
|
||||||
match (self.check_files, self.no_check_files) {
|
resolve_bool_arg(self.check_files, self.no_check_files)
|
||||||
(true, false) => Some(true),
|
|
||||||
(false, true) => Some(false),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -244,56 +229,35 @@ impl WalkArgs {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn ignore_hidden(&self) -> Option<bool> {
|
fn ignore_hidden(&self) -> Option<bool> {
|
||||||
match (self.hidden, self.no_hidden) {
|
resolve_bool_arg(self.no_hidden, self.hidden)
|
||||||
(true, false) => Some(false),
|
|
||||||
(false, true) => Some(true),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn ignore_files(&self) -> Option<bool> {
|
fn ignore_files(&self) -> Option<bool> {
|
||||||
match (self.no_ignore, self.ignore) {
|
resolve_bool_arg(self.ignore, self.no_ignore)
|
||||||
(true, false) => Some(false),
|
|
||||||
(false, true) => Some(true),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn ignore_dot(&self) -> Option<bool> {
|
fn ignore_dot(&self) -> Option<bool> {
|
||||||
match (self.no_ignore_dot, self.ignore_dot) {
|
resolve_bool_arg(self.ignore_dot, self.no_ignore_dot)
|
||||||
(true, false) => Some(false),
|
|
||||||
(false, true) => Some(true),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn ignore_vcs(&self) -> Option<bool> {
|
fn ignore_vcs(&self) -> Option<bool> {
|
||||||
match (self.no_ignore_vcs, self.ignore_vcs) {
|
resolve_bool_arg(self.ignore_vcs, self.no_ignore_vcs)
|
||||||
(true, false) => Some(false),
|
|
||||||
(false, true) => Some(true),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn ignore_global(&self) -> Option<bool> {
|
fn ignore_global(&self) -> Option<bool> {
|
||||||
match (self.no_ignore_global, self.ignore_global) {
|
resolve_bool_arg(self.ignore_global, self.no_ignore_global)
|
||||||
(true, false) => Some(false),
|
|
||||||
(false, true) => Some(true),
|
|
||||||
(false, false) => None,
|
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn ignore_parent(&self) -> Option<bool> {
|
fn ignore_parent(&self) -> Option<bool> {
|
||||||
match (self.no_ignore_parent, self.ignore_parent) {
|
resolve_bool_arg(self.ignore_parent, self.no_ignore_parent)
|
||||||
(true, false) => Some(false),
|
}
|
||||||
(false, true) => Some(true),
|
}
|
||||||
|
|
||||||
|
fn resolve_bool_arg(yes: bool, no: bool) -> Option<bool> {
|
||||||
|
match (yes, no) {
|
||||||
|
(true, false) => Some(true),
|
||||||
|
(false, true) => Some(false),
|
||||||
(false, false) => None,
|
(false, false) => None,
|
||||||
(_, _) => unreachable!("StructOpt should make this impossible"),
|
(_, _) => unreachable!("StructOpt should make this impossible"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue