aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArnold D. Robbins <arnold@skeeve.com>2016-11-30 21:27:52 +0200
committerArnold D. Robbins <arnold@skeeve.com>2016-11-30 21:27:52 +0200
commit0dd8054d05d8286f2f7cbcf85456c6953a9b6146 (patch)
treea07249da09cb1eb4fd820d305fe70fc0f9911016
parent295eef206ed65daa9801fc72875b34994b23ca01 (diff)
downloadegawk-0dd8054d05d8286f2f7cbcf85456c6953a9b6146.tar.gz
egawk-0dd8054d05d8286f2f7cbcf85456c6953a9b6146.tar.bz2
egawk-0dd8054d05d8286f2f7cbcf85456c6953a9b6146.zip
Sync dfa with GNULIB.
-rw-r--r--ChangeLog4
-rw-r--r--dfa.c6
2 files changed, 10 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index b2f0e8cb..b3f33633 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2016-11-30 Arnold D. Robbins <arnold@skeeve.com>
+
+ * dfa.c: Sync with fixes in GNULIB.
+
2016-11-29 Arnold D. Robbins <arnold@skeeve.com>
Remove redundant flag from dfa:
diff --git a/dfa.c b/dfa.c
index 0a231050..ae64ba95 100644
--- a/dfa.c
+++ b/dfa.c
@@ -2652,6 +2652,12 @@ dfastate (state_num s, struct dfa *d, unsigned char uc, state_num trans[])
continue;
if (j == CHARCLASS_WORDS)
continue;
+
+ /* If we have reset the bit that made us declare "matched", reset
+ that indicator, too. This is required to avoid an infinite loop
+ with this command: echo cx | LC_ALL=C grep -E 'c\b[x ]' */
+ if (!tstbit (uc, matches))
+ matched = false;
}
#ifdef DEBUG