diff options
author | Mark Whitley | 2001-05-21 21:13:00 +0000 |
---|---|---|
committer | Mark Whitley | 2001-05-21 21:13:00 +0000 |
commit | 1d9d41150bea7e89a881eeee7f71f88ae1fc2381 (patch) | |
tree | 3152c5e0e8d07ab5d9be81808700e1db0fc68365 /findutils | |
parent | 004015e9c4e8ff98bcbaf955cf42147218204da4 (diff) | |
download | busybox-1d9d41150bea7e89a881eeee7f71f88ae1fc2381.zip busybox-1d9d41150bea7e89a881eeee7f71f88ae1fc2381.tar.gz |
Fixed mishandling of -c & -l options and accounted for case when we're
grepping only one file.
Diffstat (limited to 'findutils')
-rw-r--r-- | findutils/grep.c | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/findutils/grep.c b/findutils/grep.c index a2fff44..061462e 100644 --- a/findutils/grep.c +++ b/findutils/grep.c @@ -104,9 +104,15 @@ static void grep_file(FILE *file) exit(0); } - /* otherwise, keep track of matches and print the matched line */ + /* keep track of matches */ nmatches++; - if (print_match_counts==0 && print_files_with_matches==0) { + + /* if we're just printing filenames, we stop after the first match */ + if (print_files_with_matches) + break; + + /* print the matched line */ + if (print_match_counts == 0) { #ifdef BB_FEATURE_GREP_CONTEXT int prevpos = (curpos == 0) ? lines_before - 1 : curpos - 1; @@ -162,14 +168,17 @@ static void grep_file(FILE *file) /* special-case file post-processing for options where we don't print line - * matches, just filenames */ + * matches, just filenames and possibly match counts */ - /* grep -cl or just grep -c: print filename:count, even if count is zero */ + /* grep -c: print [filename:]count, even if count is zero */ if (print_match_counts) { - printf("%s:%d\n", cur_file, nmatches); + if (print_filename) + printf("%s:", cur_file); + printf("%d\n", nmatches); } - /* just grep -l: print just the filename, but only if we grepped the line in the file */ - else if (print_files_with_matches && !print_match_counts && nmatches > 0) { + + /* grep -l: print just the filename, but only if we grepped the line in the file */ + if (print_files_with_matches && nmatches > 0) { puts(cur_file); } |