summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2017-12-16 19:59:37 +0100
committerBram Moolenaar <Bram@vim.org>2017-12-16 19:59:37 +0100
commit890dd05492d88d48eee1dda7f7a1811d027ce7ca (patch)
tree94ff6a4e197a1c1947b5a311f92c2ce88c7c3dab
parenta1d5c154dbd5fbe317726bbf2ba99632b91878f4 (diff)
patch 8.0.1397: pattern with \& following nothing gives an errorv8.0.1397
Problem: Pattern with \& following nothing gives an error. Solution: Emit an empty node when needed.
-rw-r--r--src/regexp_nfa.c8
-rw-r--r--src/testdir/test_search.vim8
-rw-r--r--src/version.c2
3 files changed, 14 insertions, 4 deletions
diff --git a/src/regexp_nfa.c b/src/regexp_nfa.c
index feb17bcaf5..afd42383cf 100644
--- a/src/regexp_nfa.c
+++ b/src/regexp_nfa.c
@@ -2321,7 +2321,6 @@ nfa_regconcat(void)
static int
nfa_regbranch(void)
{
- int ch;
int old_post_pos;
old_post_pos = (int)(post_ptr - post_start);
@@ -2330,11 +2329,13 @@ nfa_regbranch(void)
if (nfa_regconcat() == FAIL)
return FAIL;
- ch = peekchr();
/* Try next concats */
- while (ch == Magic('&'))
+ while (peekchr() == Magic('&'))
{
skipchr();
+ /* if concat is empty do emit a node */
+ if (old_post_pos == (int)(post_ptr - post_start))
+ EMIT(NFA_EMPTY);
EMIT(NFA_NOPEN);
EMIT(NFA_PREV_ATOM_NO_WIDTH);
old_post_pos = (int)(post_ptr - post_start);
@@ -2344,7 +2345,6 @@ nfa_regbranch(void)
if (old_post_pos == (int)(post_ptr - post_start))
EMIT(NFA_EMPTY);
EMIT(NFA_CONCAT);
- ch = peekchr();
}
/* if a branch is empty, emit one node for it */
diff --git a/src/testdir/test_search.vim b/src/testdir/test_search.vim
index d13e65458e..cb65fbf0ba 100644
--- a/src/testdir/test_search.vim
+++ b/src/testdir/test_search.vim
@@ -721,3 +721,11 @@ func Test_search_multibyte()
enew!
let &encoding = save_enc
endfunc
+
+" This was causing E874. Also causes an invalid read?
+func Test_look_behind()
+ new
+ call setline(1, '0\|\&\n\@<=')
+ call search(getline("."))
+ bwipe!
+endfunc
diff --git a/src/version.c b/src/version.c
index 224118a11d..096d21c993 100644
--- a/src/version.c
+++ b/src/version.c
@@ -772,6 +772,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1397,
+/**/
1396,
/**/
1395,