mirror of
https://github.com/sheumann/hush.git
synced 2025-01-10 16:29:44 +00:00
Fixed a subtle bug in the handling of -l and -c flags.
This commit is contained in:
parent
452cc1f293
commit
35e59bed97
@ -37,11 +37,11 @@ extern void xregcomp(regex_t *preg, const char *regex, int cflags); /* in busybo
|
|||||||
static int ignore_case = 0;
|
static int ignore_case = 0;
|
||||||
static int print_filename = 0;
|
static int print_filename = 0;
|
||||||
static int print_line_num = 0;
|
static int print_line_num = 0;
|
||||||
static int print_count_only = 0;
|
static int print_match_counts = 0;
|
||||||
static int be_quiet = 0;
|
static int be_quiet = 0;
|
||||||
static int invert_search = 0;
|
static int invert_search = 0;
|
||||||
static int suppress_err_msgs = 0;
|
static int suppress_err_msgs = 0;
|
||||||
static int files_that_match = 0;
|
static int print_files_with_matches = 0;
|
||||||
|
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
extern char *optarg; /* in getopt.h */
|
extern char *optarg; /* in getopt.h */
|
||||||
@ -106,7 +106,7 @@ static void grep_file(FILE *file)
|
|||||||
|
|
||||||
/* otherwise, keep track of matches and print the matched line */
|
/* otherwise, keep track of matches and print the matched line */
|
||||||
nmatches++;
|
nmatches++;
|
||||||
if (print_count_only==0 && files_that_match==0) {
|
if (print_match_counts==0 && print_files_with_matches==0) {
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
int prevpos = (curpos == 0) ? lines_before - 1 : curpos - 1;
|
int prevpos = (curpos == 0) ? lines_before - 1 : curpos - 1;
|
||||||
|
|
||||||
@ -160,20 +160,20 @@ static void grep_file(FILE *file)
|
|||||||
free(line);
|
free(line);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* special-case post processing */
|
|
||||||
if (files_that_match) {
|
/* special-case file post-processing for options where we don't print line
|
||||||
if (nmatches > 0) {
|
* matches, just filenames */
|
||||||
printf("%s", cur_file);
|
|
||||||
if (nmatches)
|
/* grep -cl or just grep -c: print filename:count, even if count is zero */
|
||||||
printf(":%d", nmatches);
|
if (print_match_counts) {
|
||||||
printf("\n");
|
printf("%s:%d\n", cur_file, nmatches);
|
||||||
}
|
}
|
||||||
} else if (print_count_only) {
|
/* just grep -l: print just the filename, but only if we grepped the line in the file */
|
||||||
if (print_filename)
|
else if (print_files_with_matches && !print_match_counts && nmatches > 0) {
|
||||||
printf("%s:", cur_file);
|
printf("%s\n", cur_file);
|
||||||
printf("%i\n", nmatches);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* remember if we matched */
|
/* remember if we matched */
|
||||||
if (nmatches != 0)
|
if (nmatches != 0)
|
||||||
matched = 1;
|
matched = 1;
|
||||||
@ -198,7 +198,7 @@ extern int grep_main(int argc, char **argv)
|
|||||||
ignore_case++;
|
ignore_case++;
|
||||||
break;
|
break;
|
||||||
case 'l':
|
case 'l':
|
||||||
files_that_match++;
|
print_files_with_matches++;
|
||||||
break;
|
break;
|
||||||
case 'H':
|
case 'H':
|
||||||
print_filename++;
|
print_filename++;
|
||||||
@ -219,7 +219,7 @@ extern int grep_main(int argc, char **argv)
|
|||||||
suppress_err_msgs++;
|
suppress_err_msgs++;
|
||||||
break;
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
print_count_only++;
|
print_match_counts++;
|
||||||
break;
|
break;
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
case 'A':
|
case 'A':
|
||||||
@ -250,7 +250,7 @@ extern int grep_main(int argc, char **argv)
|
|||||||
show_usage();
|
show_usage();
|
||||||
|
|
||||||
/* sanity check */
|
/* sanity check */
|
||||||
if (print_count_only || be_quiet || files_that_match) {
|
if (print_match_counts || be_quiet || print_files_with_matches) {
|
||||||
print_line_num = 0;
|
print_line_num = 0;
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
lines_before = 0;
|
lines_before = 0;
|
||||||
|
34
grep.c
34
grep.c
@ -37,11 +37,11 @@ extern void xregcomp(regex_t *preg, const char *regex, int cflags); /* in busybo
|
|||||||
static int ignore_case = 0;
|
static int ignore_case = 0;
|
||||||
static int print_filename = 0;
|
static int print_filename = 0;
|
||||||
static int print_line_num = 0;
|
static int print_line_num = 0;
|
||||||
static int print_count_only = 0;
|
static int print_match_counts = 0;
|
||||||
static int be_quiet = 0;
|
static int be_quiet = 0;
|
||||||
static int invert_search = 0;
|
static int invert_search = 0;
|
||||||
static int suppress_err_msgs = 0;
|
static int suppress_err_msgs = 0;
|
||||||
static int files_that_match = 0;
|
static int print_files_with_matches = 0;
|
||||||
|
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
extern char *optarg; /* in getopt.h */
|
extern char *optarg; /* in getopt.h */
|
||||||
@ -106,7 +106,7 @@ static void grep_file(FILE *file)
|
|||||||
|
|
||||||
/* otherwise, keep track of matches and print the matched line */
|
/* otherwise, keep track of matches and print the matched line */
|
||||||
nmatches++;
|
nmatches++;
|
||||||
if (print_count_only==0 && files_that_match==0) {
|
if (print_match_counts==0 && print_files_with_matches==0) {
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
int prevpos = (curpos == 0) ? lines_before - 1 : curpos - 1;
|
int prevpos = (curpos == 0) ? lines_before - 1 : curpos - 1;
|
||||||
|
|
||||||
@ -160,20 +160,20 @@ static void grep_file(FILE *file)
|
|||||||
free(line);
|
free(line);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* special-case post processing */
|
|
||||||
if (files_that_match) {
|
/* special-case file post-processing for options where we don't print line
|
||||||
if (nmatches > 0) {
|
* matches, just filenames */
|
||||||
printf("%s", cur_file);
|
|
||||||
if (nmatches)
|
/* grep -cl or just grep -c: print filename:count, even if count is zero */
|
||||||
printf(":%d", nmatches);
|
if (print_match_counts) {
|
||||||
printf("\n");
|
printf("%s:%d\n", cur_file, nmatches);
|
||||||
}
|
}
|
||||||
} else if (print_count_only) {
|
/* just grep -l: print just the filename, but only if we grepped the line in the file */
|
||||||
if (print_filename)
|
else if (print_files_with_matches && !print_match_counts && nmatches > 0) {
|
||||||
printf("%s:", cur_file);
|
printf("%s\n", cur_file);
|
||||||
printf("%i\n", nmatches);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* remember if we matched */
|
/* remember if we matched */
|
||||||
if (nmatches != 0)
|
if (nmatches != 0)
|
||||||
matched = 1;
|
matched = 1;
|
||||||
@ -198,7 +198,7 @@ extern int grep_main(int argc, char **argv)
|
|||||||
ignore_case++;
|
ignore_case++;
|
||||||
break;
|
break;
|
||||||
case 'l':
|
case 'l':
|
||||||
files_that_match++;
|
print_files_with_matches++;
|
||||||
break;
|
break;
|
||||||
case 'H':
|
case 'H':
|
||||||
print_filename++;
|
print_filename++;
|
||||||
@ -219,7 +219,7 @@ extern int grep_main(int argc, char **argv)
|
|||||||
suppress_err_msgs++;
|
suppress_err_msgs++;
|
||||||
break;
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
print_count_only++;
|
print_match_counts++;
|
||||||
break;
|
break;
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
case 'A':
|
case 'A':
|
||||||
@ -250,7 +250,7 @@ extern int grep_main(int argc, char **argv)
|
|||||||
show_usage();
|
show_usage();
|
||||||
|
|
||||||
/* sanity check */
|
/* sanity check */
|
||||||
if (print_count_only || be_quiet || files_that_match) {
|
if (print_match_counts || be_quiet || print_files_with_matches) {
|
||||||
print_line_num = 0;
|
print_line_num = 0;
|
||||||
#ifdef BB_FEATURE_GREP_CONTEXT
|
#ifdef BB_FEATURE_GREP_CONTEXT
|
||||||
lines_before = 0;
|
lines_before = 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user