summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Gallant <jamslam@gmail.com>2018-02-04 11:41:06 -0500
committerAndrew Gallant <jamslam@gmail.com>2018-02-06 12:07:59 -0500
commit224c112e0509ab2aeb28de05efbbce9486a55eff (patch)
treea98c7285ac687ad29afae0c0016ec9ec84cd6d40
parent8cb5833ef9fd6c4c351d10a3e950339fa89adf49 (diff)
argv: tweak the meaning of zero
This commit makes a small tweak to the --max-columns flag. Namely, if the value of the flag is 0, then ripgrep behaves as-if the flag were absent. This is useful in the context of ripgrep reading configuration from the environment. For example, an end user might set --max-columns=150, but we should permit the user to disable this setting when needed. Using -M0 is a nice way to do that. We do this because a zero value for --max-columns isn't particularly meaningful. We do leave the --max-count, --max-filesize and --maxdepth flags alone though, since a zero value for those flags is potentially meaningful. (--max-count even has tests for ripgrep's behavior when given a value of 0.)
-rw-r--r--src/app.rs2
-rw-r--r--src/args.rs22
2 files changed, 22 insertions, 2 deletions
diff --git a/src/app.rs b/src/app.rs
index 05f411ac..3591dc22 100644
--- a/src/app.rs
+++ b/src/app.rs
@@ -1034,6 +1034,8 @@ fn flag_max_columns(args: &mut Vec<RGArg>) {
const LONG: &str = long!("\
Don't print lines longer than this limit in bytes. Longer lines are omitted,
and only the number of matches in that line is printed.
+
+When this flag is omitted or is set to 0, then it has no effect.
");
let arg = RGArg::flag("max-columns", "NUM").short("M")
.help(SHORT).long_help(LONG)
diff --git a/src/args.rs b/src/args.rs
index 0c25727f..0461261b 100644
--- a/src/args.rs
+++ b/src/args.rs
@@ -381,8 +381,8 @@ impl<'a> ArgMatches<'a> {
line_number: line_number,
line_number_width: try!(self.usize_of("line-number-width")),
line_per_match: self.is_present("vimgrep"),
- max_columns: self.usize_of("max-columns")?,
- max_count: self.usize_of("max-count")?.map(|max| max as u64),
+ max_columns: self.usize_of_nonzero("max-columns")?,
+ max_count: self.usize_of("max-count")?.map(|n| n as u64),
max_filesize: self.max_filesize()?,
maxdepth: self.usize_of("maxdepth")?,
mmap: mmap,
@@ -973,6 +973,24 @@ impl<'a> ArgMatches<'a> {
/// Safely reads an arg value with the given name, and if it's present,
/// tries to parse it as a usize value.
+ ///
+ /// If the number is zero, then it is considered absent and `None` is
+ /// returned.
+ fn usize_of_nonzero(&self, name: &str) -> Result<Option<usize>> {
+ match self.value_of_lossy(name) {
+ None => Ok(None),
+ Some(v) => v.parse().map_err(From::from).map(|n| {
+ if n == 0 {
+ None
+ } else {
+ Some(n)
+ }
+ }),
+ }
+ }
+
+ /// Safely reads an arg value with the given name, and if it's present,
+ /// tries to parse it as a usize value.
fn usize_of(&self, name: &str) -> Result<Option<usize>> {
match self.value_of_lossy(name) {
None => Ok(None),