refactor(cli): Share bool logic

This commit is contained in:
Ed Page 2021-04-30 10:26:12 -05:00
parent 517da7ecd2
commit 6146824b4e

View file

@ -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"),
} }
} }
}