svn commit: r318914 - head/usr.bin/grep

Ed Maste emaste at FreeBSD.org
Fri May 26 02:30:28 UTC 2017


Author: emaste
Date: Fri May 26 02:30:26 2017
New Revision: 318914
URL: https://svnweb.freebsd.org/changeset/base/318914

Log:
  bsdgrep: correct assumptions to prepare for chunking
  
  Correct a couple of minor BSD grep assumptions that are valid for line
  processing but not future chunk-based processing.
  
  Submitted by:	Kyle Evans <kevans91 at ksu.edu>
  Reviewed by:	bapt, cem
  Differential Revision:	https://reviews.freebsd.org/D10824

Modified:
  head/usr.bin/grep/grep.c
  head/usr.bin/grep/grep.h
  head/usr.bin/grep/util.c

Modified: head/usr.bin/grep/grep.c
==============================================================================
--- head/usr.bin/grep/grep.c	Fri May 26 01:14:58 2017	(r318913)
+++ head/usr.bin/grep/grep.c	Fri May 26 02:30:26 2017	(r318914)
@@ -78,7 +78,7 @@ const char	*errstr[] = {
 };
 
 /* Flags passed to regcomp() and regexec() */
-int		 cflags = REG_NOSUB;
+int		 cflags = REG_NOSUB | REG_NEWLINE;
 int		 eflags = REG_STARTEND;
 
 /* XXX TODO: Get rid of this flag.

Modified: head/usr.bin/grep/grep.h
==============================================================================
--- head/usr.bin/grep/grep.h	Fri May 26 01:14:58 2017	(r318913)
+++ head/usr.bin/grep/grep.h	Fri May 26 02:30:26 2017	(r318914)
@@ -82,7 +82,7 @@ extern const char		*errstr[];
 #define	EXCL_PAT	0
 #define	INCL_PAT	1
 
-#define	MAX_LINE_MATCHES	32
+#define	MAX_MATCHES	32
 
 struct file {
 	int		 fd;

Modified: head/usr.bin/grep/util.c
==============================================================================
--- head/usr.bin/grep/util.c	Fri May 26 01:14:58 2017	(r318913)
+++ head/usr.bin/grep/util.c	Fri May 26 02:30:26 2017	(r318914)
@@ -61,7 +61,7 @@ static bool	 first_match = true;
  * other useful bits
  */
 struct parsec {
-	regmatch_t	matches[MAX_LINE_MATCHES];	/* Matches made */
+	regmatch_t	matches[MAX_MATCHES];		/* Matches made */
 	struct str	ln;				/* Current line */
 	size_t		lnstart;			/* Position in line */
 	size_t		matchidx;			/* Latest match index */
@@ -295,7 +295,7 @@ procfile(const char *fn)
 		/* Print the matching line, but only if not quiet/binary */
 		if (t == 0 && printmatch) {
 			printline(&pc, ':');
-			while (pc.matchidx >= MAX_LINE_MATCHES) {
+			while (pc.matchidx >= MAX_MATCHES) {
 				/* Reset matchidx and try again */
 				pc.matchidx = 0;
 				if (procline(&pc) == 0)
@@ -401,7 +401,7 @@ procline(struct parsec *pc)
 		lastmatches = 0;
 		startm = matchidx;
 		retry = 0;
-		if (st > 0)
+		if (st > 0 && pc->ln.dat[st - 1] != fileeol)
 			leflags |= REG_NOTBOL;
 		/* Loop to compare with all the patterns */
 		for (i = 0; i < patterns; i++) {
@@ -483,7 +483,7 @@ procline(struct parsec *pc)
 			}
 			/* avoid excessive matching - skip further patterns */
 			if ((color == NULL && !oflag) || qflag || lflag ||
-			    matchidx >= MAX_LINE_MATCHES) {
+			    matchidx >= MAX_MATCHES) {
 				pc->lnstart = nst;
 				lastmatches = 0;
 				break;


More information about the svn-src-all mailing list