mirror of
https://github.com/vim/vim.git
synced 2025-10-03 05:14:07 -04:00
updated for version 7.2.391
Problem: Internal alloc(0) error when doing "CTRL-V $ c". (Martti Kuparinen) Solution: Fix computations in getvcol(). (partly by Lech Lorens)
This commit is contained in:
@@ -1255,6 +1255,9 @@ getvcol(wp, pos, start, cursor, end)
|
|||||||
|
|
||||||
vcol = 0;
|
vcol = 0;
|
||||||
ptr = ml_get_buf(wp->w_buffer, pos->lnum, FALSE);
|
ptr = ml_get_buf(wp->w_buffer, pos->lnum, FALSE);
|
||||||
|
if (pos->col == MAXCOL)
|
||||||
|
posptr = NULL; /* continue until the NUL */
|
||||||
|
else
|
||||||
posptr = ptr + pos->col;
|
posptr = ptr + pos->col;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -1313,7 +1316,7 @@ getvcol(wp, pos, start, cursor, end)
|
|||||||
incr = CHARSIZE(c);
|
incr = CHARSIZE(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ptr >= posptr) /* character at pos->col */
|
if (posptr != NULL && ptr >= posptr) /* character at pos->col */
|
||||||
break;
|
break;
|
||||||
|
|
||||||
vcol += incr;
|
vcol += incr;
|
||||||
@@ -1334,7 +1337,7 @@ getvcol(wp, pos, start, cursor, end)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ptr >= posptr) /* character at pos->col */
|
if (posptr != NULL && ptr >= posptr) /* character at pos->col */
|
||||||
break;
|
break;
|
||||||
|
|
||||||
vcol += incr;
|
vcol += incr;
|
||||||
|
@@ -2113,7 +2113,7 @@ errorret:
|
|||||||
if (buf->b_ml.ml_mfp == NULL) /* there are no lines */
|
if (buf->b_ml.ml_mfp == NULL) /* there are no lines */
|
||||||
return (char_u *)"";
|
return (char_u *)"";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* See if it is the same line as requested last time.
|
* See if it is the same line as requested last time.
|
||||||
* Otherwise may need to flush last used line.
|
* Otherwise may need to flush last used line.
|
||||||
* Don't use the last used line when 'swapfile' is reset, need to load all
|
* Don't use the last used line when 'swapfile' is reset, need to load all
|
||||||
|
@@ -681,6 +681,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 */
|
||||||
|
/**/
|
||||||
|
391,
|
||||||
/**/
|
/**/
|
||||||
390,
|
390,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user