*
*/
+/*
+ 18-Dec-1999 Konstantin Boldyshev <konst@voshod.com>
+
+ + -q option (be quiet)
+ + exit code depending on grep result (TRUE or FALSE)
+ (useful for scripts)
+*/
+
#include "internal.h"
#include "regexp.h"
#include <stdio.h>
#include <ctype.h>
static const char grep_usage[] =
-"grep [-ihn]... PATTERN [FILE]...\n"
+"grep [OPTIONS]... PATTERN [FILE]...\n\n"
"Search for PATTERN in each FILE or standard input.\n\n"
+"OPTIONS:\n"
"\t-h\tsuppress the prefixing filename on output\n"
"\t-i\tignore case distinctions\n"
-"\t-n\tprint line number with output lines\n\n"
+"\t-n\tprint line number with output lines\n"
+"\t-q\tbe quiet. Returns 0 if result was found, 1 otherwise\n\n"
#if defined BB_REGEXP
-"This version of grep matches full regexps.\n";
+"This version of grep matches full regular expresions.\n";
#else
-"This version of grep matches strings (not full regexps).\n";
+"This version of grep matches strings (not regular expresions).\n";
#endif
-int tellName=TRUE;
-int ignoreCase=FALSE;
-int tellLine=FALSE;
+static int match = FALSE, beQuiet = FALSE;
-static do_grep(char* needle, char* haystack )
+static void do_grep(FILE *fp, char* needle, char *fileName, int tellName, int ignoreCase, int tellLine)
{
- line = 0;
+ char *cp;
+ long line = 0;
+ char haystack[BUF_SIZE];
- while (fgets (haystack, sizeof (haystack), fp)) {
- line++;
- cp = &haystack[strlen (haystack) - 1];
+ while (fgets (haystack, sizeof (haystack), fp)) {
+ line++;
+ cp = &haystack[strlen (haystack) - 1];
- if (*cp != '\n')
- fprintf (stderr, "%s: Line too long\n", name);
+ if (*cp != '\n')
+ fprintf (stderr, "%s: Line too long\n", fileName);
- if (find_match(haystack, needle, ignoreCase) == TRUE) {
- if (tellName==TRUE)
- printf ("%s: ", name);
+ if (find_match(haystack, needle, ignoreCase) == TRUE) {
+ if (tellName==TRUE)
+ printf ("%s:", fileName);
- if (tellLine==TRUE)
- printf ("%ld: ", line);
+ if (tellLine==TRUE)
+ printf ("%ld:", line);
+ if (beQuiet==FALSE)
fputs (haystack, stdout);
- }
+
+ match = TRUE;
}
+ }
}
extern int grep_main (int argc, char **argv)
{
FILE *fp;
- char *needle;
- char *name;
char *cp;
- long line;
- char haystack[BUF_SIZE];
+ char *needle;
+ char *fileName;
+ int tellName=FALSE;
+ int ignoreCase=FALSE;
+ int tellLine=FALSE;
+
ignoreCase = FALSE;
tellLine = FALSE;
break;
case 'h':
- tellName = FALSE;
+ tellName = TRUE;
break;
case 'n':
tellLine = TRUE;
break;
+ case 'q':
+ beQuiet = TRUE;
+ break;
+
default:
usage(grep_usage);
}
needle = *argv++;
argc--;
+ if (argc==0) {
+ do_grep( stdin, needle, "stdin", FALSE, ignoreCase, tellLine);
+ } else {
+ while (argc-- > 0) {
+ fileName = *argv++;
- while (argc-- > 0) {
-
- if (argc==0) {
- file = stdin;
- }
- else
- file = fopen(*argv, "r");
-
+ fp = fopen (fileName, "r");
+ if (fp == NULL) {
+ perror (fileName);
+ continue;
+ }
- name = *argv++;
+ do_grep( fp, needle, fileName, tellName, ignoreCase, tellLine);
- fp = fopen (name, "r");
- if (fp == NULL) {
- perror (name);
- continue;
+ if (ferror (fp))
+ perror (fileName);
+ fclose (fp);
}
-
- if (ferror (fp))
- perror (name);
-
- fclose (fp);
}
- exit( TRUE);
+ exit(match);
}