Fix handling of ^$ by removing the newline from input lines and by not
authorMatt Kraai <kraai@debian.org>
Fri, 13 Oct 2000 18:55:06 +0000 (18:55 -0000)
committerMatt Kraai <kraai@debian.org>
Fri, 13 Oct 2000 18:55:06 +0000 (18:55 -0000)
compiling with REG_NEWLINE.

findutils/grep.c
grep.c

index 003dae9..c0193bc 100644 (file)
@@ -56,7 +56,7 @@ static void print_matched_line(char *line, int linenum)
        if (print_line_num)
                printf("%i:", linenum);
 
-       printf("%s", line);
+       puts(line);
 }
 
 static void grep_file(FILE *file)
@@ -67,6 +67,8 @@ static void grep_file(FILE *file)
        int nmatches = 0;
 
        while ((line = get_line_from_file(file)) != NULL) {
+               if (line[strlen(line)-1] == '\n')
+                       line[strlen(line)-1] = '\0';
                linenum++;
                ret = regexec(&regex, line, 0, NULL, 0);
                if (ret == 0 && !invert_search) { /* match */
@@ -144,7 +146,7 @@ extern int grep_main(int argc, char **argv)
        /* compile the regular expression
         * we're not going to mess with sub-expressions, and we need to
         * treat newlines right. */
-       reflags = REG_NOSUB | REG_NEWLINE
+       reflags = REG_NOSUB; 
        if (ignore_case)
                reflags |= REG_ICASE;
        xregcomp(&regex, argv[optind], reflags);
diff --git a/grep.c b/grep.c
index 003dae9..c0193bc 100644 (file)
--- a/grep.c
+++ b/grep.c
@@ -56,7 +56,7 @@ static void print_matched_line(char *line, int linenum)
        if (print_line_num)
                printf("%i:", linenum);
 
-       printf("%s", line);
+       puts(line);
 }
 
 static void grep_file(FILE *file)
@@ -67,6 +67,8 @@ static void grep_file(FILE *file)
        int nmatches = 0;
 
        while ((line = get_line_from_file(file)) != NULL) {
+               if (line[strlen(line)-1] == '\n')
+                       line[strlen(line)-1] = '\0';
                linenum++;
                ret = regexec(&regex, line, 0, NULL, 0);
                if (ret == 0 && !invert_search) { /* match */
@@ -144,7 +146,7 @@ extern int grep_main(int argc, char **argv)
        /* compile the regular expression
         * we're not going to mess with sub-expressions, and we need to
         * treat newlines right. */
-       reflags = REG_NOSUB | REG_NEWLINE
+       reflags = REG_NOSUB; 
        if (ignore_case)
                reflags |= REG_ICASE;
        xregcomp(&regex, argv[optind], reflags);