mirror of
https://github.com/vim/vim.git
synced 2025-09-23 03:43:49 -04:00
updated for version 7.3.121
Problem: Complicated 'statusline' causes a crash. (Christian Brabandt) Solution: Check that the number of items is not too big.
This commit is contained in:
12
src/buffer.c
12
src/buffer.c
@@ -3460,6 +3460,18 @@ build_stl_str_hl(wp, out, outlen, fmt, use_sandbox, fillchar,
|
|||||||
prevchar_isitem = FALSE;
|
prevchar_isitem = FALSE;
|
||||||
for (s = usefmt; *s; )
|
for (s = usefmt; *s; )
|
||||||
{
|
{
|
||||||
|
if (curitem == STL_MAX_ITEM)
|
||||||
|
{
|
||||||
|
/* There are too many items. Add the error code to the statusline
|
||||||
|
* to give the user a hint about what went wrong. */
|
||||||
|
if (p + 6 < out + outlen)
|
||||||
|
{
|
||||||
|
mch_memmove(p, " E541", (size_t)5);
|
||||||
|
p += 5;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (*s != NUL && *s != '%')
|
if (*s != NUL && *s != '%')
|
||||||
prevchar_isflag = prevchar_isitem = FALSE;
|
prevchar_isflag = prevchar_isitem = FALSE;
|
||||||
|
|
||||||
|
@@ -714,6 +714,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 */
|
||||||
|
/**/
|
||||||
|
121,
|
||||||
/**/
|
/**/
|
||||||
120,
|
120,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user