diff options
-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | findutils/grep.c | 15 |
2 files changed, 12 insertions, 5 deletions
@@ -1,6 +1,6 @@ VERSION = 1 PATCHLEVEL = 7 -SUBLEVEL = 4 +SUBLEVEL = 5 EXTRAVERSION = NAME = Unnamed diff --git a/findutils/grep.c b/findutils/grep.c index c45d0ed..521b88e 100644 --- a/findutils/grep.c +++ b/findutils/grep.c @@ -154,14 +154,14 @@ static int grep_file(FILE *file) while ((line = xmalloc_getline(file)) != NULL) { llist_t *pattern_ptr = pattern_head; - grep_list_data_t * gl; + grep_list_data_t *gl = gl; /* for gcc */ linenum++; ret = 0; while (pattern_ptr) { gl = (grep_list_data_t *)pattern_ptr->data; if (FGREP_FLAG) { - ret = strstr(line, gl->pattern) != NULL; + ret |= (strstr(line, gl->pattern) != NULL); } else { /* * test for a postitive-assertion match (regexec returns success (0) @@ -255,8 +255,15 @@ static int grep_file(FILE *file) print_n_lines_after = lines_after; #endif if (option_mask32 & OPT_o) { - line[regmatch.rm_eo] = '\0'; - print_line(line + regmatch.rm_so, linenum, ':'); + if (FGREP_FLAG) { + /* -Fo just prints the pattern + * (unless -v: -Fov doesnt print anything at all) */ + if (ret) + print_line(gl->pattern, linenum, ':'); + } else { + line[regmatch.rm_eo] = '\0'; + print_line(line + regmatch.rm_so, linenum, ':'); + } } else { print_line(line, linenum, ':'); } |