Summary: | graphics/libglapi: fails to build with bsdgrep | ||||||
---|---|---|---|---|---|---|---|
Product: | Base System | Reporter: | Jan Beich <jbeich> | ||||
Component: | bin | Assignee: | Kyle Evans <kevans> | ||||
Status: | Closed FIXED | ||||||
Severity: | Affects Only Me | CC: | alex.deiter, emaste, kevans, rozhuk.im, x11 | ||||
Priority: | --- | Keywords: | regression | ||||
Version: | CURRENT | ||||||
Hardware: | Any | ||||||
OS: | Any | ||||||
Bug Depends on: | |||||||
Bug Blocks: | 218385 | ||||||
Attachments: |
|
Description
Jan Beich
2017-04-22 12:13:30 UTC
Broken word matching also manifests via --color e.g., $ echo 'foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux foo bar qux' | env -i TERM=xterm bsdgrep --color bar load: 0.68 cmd: grep 40786 [running] 13.54r 13.52u 0.00s 74% 2264k ^C (In reply to Jan Beich from comment #1) D'oh. This is a trivially broken case; easily exceeds the maximum number of line matches (MAX_LINE_MATCHES=32), then it infinitely loops because it still matches past that but it's not able to be inserted into 'matches,' causing my failure mechanisms to fail because $bad. I'll fix this in my -w empty broken review (https://reviews.freebsd.org/D10433) version, because it's *not* straightforward to fix this on -HEAD since procline() conflates matching a line with printing context. In the current state of that patch, this will basically record 'st' and set lastmatches=0, force a break at util.c:443, then at util.c:284 I'll throw in a loop that does a procline() and printline() as long as we max out on matches. Thanks for the report! =) To clarify, I'll fix this separately after D10433, rather than trying to squeeze this in as well. I've got a fix in progress, though, to minimize delay. jbeich, is this broken with current HEAD src + ports (after r316477, because the port invokes bsdgrep), or only with bsdgrep installed as grep? (In reply to Ed Maste from comment #4) Only bsdgrep as grep breaks build. Created attachment 182056 [details]
Fix, applied on top of D10433
Attaching a patch to be applied after/on top of D10433 to address this, along with an associated test case. printline() had to be modified because it was doing the wrong thing in the case of -o and any flag specified to present file/line/offset information.
Comment on attachment 182056 [details] Fix, applied on top of D10433 I confirm, this fixes comment 1 but not comment 0. (In reply to Jan Beich from comment #7) Oh, you wanted the build failure fixed, too. =-) That part is actually fixed in D10329 [1] stemming from PR 218467. Apologies for missing that. [1] https://reviews.freebsd.org/D10329 *** Bug 218858 has been marked as a duplicate of this bug. *** A commit references this bug: Author: emaste Date: Tue May 2 02:32:10 UTC 2017 New revision: 317665 URL: https://svnweb.freebsd.org/changeset/base/317665 Log: bsdgrep: fix -w -v matching improperly with certain patterns -w and -v flag matching was mostly functional but had some minor problems: 1. -w flag processing only allowed one iteration through pattern matching on a line. This was problematic if one pattern could match more than once, or if there were multiple patterns and the earliest/ longest match was not the most ideal, and 2. Previous work "fixed" things to not further process a line if the first iteration through patterns produced no matches. This is clearly wrong if we're dealing with the more restrictive -w matching. #2 breakage could have also occurred before recent broad rewrites, but it would be more arbitrary based on input patterns as to whether or not it actually affected things. Fix both of these by forcing a retry of the patterns after advancing just past the start of the first match if we're doing more restrictive -w matching and we didn't get any hits to start with. Also move -v flag processing outside of the loop so that we have a greater change to match in the more restrictive cases. This wasn't strictly wrong, but it could be a little more error prone. While here, introduce some regressions tests for this behavior and fix some excessive wrapping nearby that hindered readability. GNU grep passes these new tests. PR: 218467, 218811 Submitted by: Kyle Evans <kevans91 at ksu.edu> Reviewed by: cem, ngie Differential Revision: https://reviews.freebsd.org/D10329 Changes: head/contrib/netbsd-tests/usr.bin/grep/t_grep.sh head/usr.bin/grep/util.c A commit references this bug: Author: emaste Date: Sat May 20 03:51:32 UTC 2017 New revision: 318571 URL: https://svnweb.freebsd.org/changeset/base/318571 Log: bsdgrep: emit more than MAX_LINE_MATCHES per line We should not set an arbitrary cap on the number of matches on a line, and in any case MAX_LINE_MATCHES of 32 is much too low. Instead, if we match more than MAX_LINE_MATCHES, keep processing and matching from the last match until all are found. For the regression test, we produce 4096 matches (larger than we expect we'll ever set MAX_LINE_MATCHES) and make sure we actually get 4096 lines of output with the -o flag. We'll also make sure that every distinct line is getting its own line number to detect line metadata not being printed as appropriate along the way. PR: 218811 Submitted by: Kyle Evans <kevans91@ksu.edu> Reported by: jbeich Reviewed by: cem Differential Revision: https://reviews.freebsd.org/D10577 Changes: head/contrib/netbsd-tests/usr.bin/grep/t_grep.sh head/usr.bin/grep/util.c A commit references this bug: Author: kevans Date: Wed Aug 16 17:42:39 UTC 2017 New revision: 322583 URL: https://svnweb.freebsd.org/changeset/base/322583 Log: MFC r317665: bsdgrep: fix -w -v matching improperly with certain patterns -w and -v flag matching was mostly functional but had some minor problems: 1. -w flag processing only allowed one iteration through pattern matching on a line. This was problematic if one pattern could match more than once, or if there were multiple patterns and the earliest/ longest match was not the most ideal, and 2. Previous work "fixed" things to not further process a line if the first iteration through patterns produced no matches. This is clearly wrong if we're dealing with the more restrictive -w matching. #2 breakage could have also occurred before recent broad rewrites, but it would be more arbitrary based on input patterns as to whether or not it actually affected things. Fix both of these by forcing a retry of the patterns after advancing just past the start of the first match if we're doing more restrictive -w matching and we didn't get any hits to start with. Also move -v flag processing outside of the loop so that we have a greater change to match in the more restrictive cases. This wasn't strictly wrong, but it could be a little more error prone. While here, introduce some regressions tests for this behavior and fix some excessive wrapping nearby that hindered readability. GNU grep passes these new tests. PR: 218467, 218811 Approved by: emaste (mentor, blanket MFC) Changes: _U stable/11/ stable/11/contrib/netbsd-tests/usr.bin/grep/t_grep.sh stable/11/usr.bin/grep/util.c A commit references this bug: Author: kevans Date: Thu Aug 17 04:26:04 UTC 2017 New revision: 322609 URL: https://svnweb.freebsd.org/changeset/base/322609 Log: MFC r318571: bsdgrep: emit more than MAX_LINE_MATCHES per line We should not set an arbitrary cap on the number of matches on a line, and in any case MAX_LINE_MATCHES of 32 is much too low. Instead, if we match more than MAX_LINE_MATCHES, keep processing and matching from the last match until all are found. For the regression test, we produce 4096 matches (larger than we expect we'll ever set MAX_LINE_MATCHES) and make sure we actually get 4096 lines of output with the -o flag. We'll also make sure that every distinct line is getting its own line number to detect line metadata not being printed as appropriate along the way. PR: 218811 Approved by: emaste (mentor, blanket MFC) Changes: _U stable/11/ stable/11/contrib/netbsd-tests/usr.bin/grep/t_grep.sh stable/11/usr.bin/grep/util.c Kyle, is this now resolved? *** Bug 221758 has been marked as a duplicate of this bug. *** |