patch 7.4.690 for Problem: Memory access errors when changing indent in Ex mode. Also missing
redraw when using CTRL-U. (Knil Ino) Solution: Update pointers after calling ga_grow().
This commit is contained in:
@ -2245,6 +2245,9 @@ getexmodeline(promptc, cookie, indent)
|
||||
got_int = FALSE;
|
||||
while (!got_int)
|
||||
{
|
||||
long sw;
|
||||
char_u *s;
|
||||
|
||||
if (ga_grow(&line_ga, 40) == FAIL)
|
||||
break;
|
||||
|
||||
@ -2296,13 +2299,12 @@ getexmodeline(promptc, cookie, indent)
|
||||
msg_col = startcol;
|
||||
msg_clr_eos();
|
||||
line_ga.ga_len = 0;
|
||||
continue;
|
||||
goto redraw;
|
||||
}
|
||||
|
||||
if (c1 == Ctrl_T)
|
||||
{
|
||||
long sw = get_sw_value(curbuf);
|
||||
|
||||
sw = get_sw_value(curbuf);
|
||||
p = (char_u *)line_ga.ga_data;
|
||||
p[line_ga.ga_len] = NUL;
|
||||
indent = get_indent_str(p, 8, FALSE);
|
||||
@ -2310,9 +2312,9 @@ getexmodeline(promptc, cookie, indent)
|
||||
add_indent:
|
||||
while (get_indent_str(p, 8, FALSE) < indent)
|
||||
{
|
||||
char_u *s = skipwhite(p);
|
||||
|
||||
ga_grow(&line_ga, 1);
|
||||
ga_grow(&line_ga, 2); /* one more for the NUL */
|
||||
p = (char_u *)line_ga.ga_data;
|
||||
s = skipwhite(p);
|
||||
mch_memmove(s + 1, s, line_ga.ga_len - (s - p) + 1);
|
||||
*s = ' ';
|
||||
++line_ga.ga_len;
|
||||
@ -2361,13 +2363,15 @@ redraw:
|
||||
{
|
||||
p[line_ga.ga_len] = NUL;
|
||||
indent = get_indent_str(p, 8, FALSE);
|
||||
if (indent > 0)
|
||||
{
|
||||
--indent;
|
||||
indent -= indent % get_sw_value(curbuf);
|
||||
}
|
||||
}
|
||||
while (get_indent_str(p, 8, FALSE) > indent)
|
||||
{
|
||||
char_u *s = skipwhite(p);
|
||||
|
||||
s = skipwhite(p);
|
||||
mch_memmove(s - 1, s, line_ga.ga_len - (s - p) + 1);
|
||||
--line_ga.ga_len;
|
||||
}
|
||||
|
||||
@ -741,6 +741,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
690,
|
||||
/**/
|
||||
689,
|
||||
/**/
|
||||
|
||||
Reference in New Issue
Block a user