forked from aniani/vim
patch 9.0.0228: crash when pattern looks below the last line
Problem: Crash when pattern looks below the last line. Solution: Consider invalid lines to be empty. (closes #10938)
This commit is contained in:
@@ -3439,12 +3439,17 @@ regmatch(
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case RE_VCOL:
|
case RE_VCOL:
|
||||||
if (!re_num_cmp((long_u)win_linetabsize(
|
{
|
||||||
rex.reg_win == NULL ? curwin : rex.reg_win,
|
win_T *wp = rex.reg_win == NULL ? curwin : rex.reg_win;
|
||||||
rex.reg_firstlnum + rex.lnum,
|
linenr_T lnum = rex.reg_firstlnum + rex.lnum;
|
||||||
rex.line,
|
long_u vcol = 0;
|
||||||
(colnr_T)(rex.input - rex.line)) + 1, scan))
|
|
||||||
status = RA_NOMATCH;
|
if (lnum > 0 && lnum <= wp->w_buffer->b_ml.ml_line_count)
|
||||||
|
vcol = (long_u)win_linetabsize(wp, lnum, rex.line,
|
||||||
|
(colnr_T)(rex.input - rex.line));
|
||||||
|
if (!re_num_cmp(vcol + 1, scan))
|
||||||
|
status = RA_NOMATCH;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case BOW: // \<word; rex.input points to w
|
case BOW: // \<word; rex.input points to w
|
||||||
|
@@ -6774,10 +6774,16 @@ nfa_regmatch(
|
|||||||
result = col > t->state->val * ts;
|
result = col > t->state->val * ts;
|
||||||
}
|
}
|
||||||
if (!result)
|
if (!result)
|
||||||
result = nfa_re_num_cmp(t->state->val, op,
|
{
|
||||||
(long_u)win_linetabsize(wp,
|
linenr_T lnum = rex.reg_firstlnum + rex.lnum;
|
||||||
rex.reg_firstlnum + rex.lnum,
|
long_u vcol = 0;
|
||||||
rex.line, col) + 1);
|
|
||||||
|
if (lnum > 0
|
||||||
|
&& lnum <= wp->w_buffer->b_ml.ml_line_count)
|
||||||
|
vcol = (long_u)win_linetabsize(wp, lnum,
|
||||||
|
rex.line, col);
|
||||||
|
result = nfa_re_num_cmp(t->state->val, op, vcol + 1);
|
||||||
|
}
|
||||||
if (result)
|
if (result)
|
||||||
{
|
{
|
||||||
add_here = TRUE;
|
add_here = TRUE;
|
||||||
|
@@ -1129,4 +1129,16 @@ func Test_recursive_substitute_expr()
|
|||||||
delfunc Repl
|
delfunc Repl
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
def Test_compare_columns()
|
||||||
|
# this was using a line below the last line
|
||||||
|
enew
|
||||||
|
setline(1, ['', ''])
|
||||||
|
prop_type_add('name', {highlight: 'ErrorMsg'})
|
||||||
|
prop_add(1, 1, {length: 1, type: 'name'})
|
||||||
|
search('\%#=1\%>.l\n.*\%<2v', 'nW')
|
||||||
|
search('\%#=2\%>.l\n.*\%<2v', 'nW')
|
||||||
|
bwipe!
|
||||||
|
prop_type_delete('name')
|
||||||
|
enddef
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -731,6 +731,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
228,
|
||||||
/**/
|
/**/
|
||||||
227,
|
227,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user