mirror of
https://github.com/vim/vim.git
synced 2025-09-23 03:43:49 -04:00
patch 8.2.4359: crash when repeatedly using :retab
Problem: crash when repeatedly using :retab. Solution: Bail out when the line is getting too long.
This commit is contained in:
@@ -1750,6 +1750,11 @@ ex_retab(exarg_T *eap)
|
|||||||
if (ptr[col] == NUL)
|
if (ptr[col] == NUL)
|
||||||
break;
|
break;
|
||||||
vcol += chartabsize(ptr + col, (colnr_T)vcol);
|
vcol += chartabsize(ptr + col, (colnr_T)vcol);
|
||||||
|
if (vcol >= MAXCOL)
|
||||||
|
{
|
||||||
|
emsg(_(e_resulting_text_too_long));
|
||||||
|
break;
|
||||||
|
}
|
||||||
if (has_mbyte)
|
if (has_mbyte)
|
||||||
col += (*mb_ptr2len)(ptr + col);
|
col += (*mb_ptr2len)(ptr + col);
|
||||||
else
|
else
|
||||||
|
@@ -70,6 +70,8 @@ func Test_retab()
|
|||||||
call assert_equal(" a b c ", Retab('!', 3))
|
call assert_equal(" a b c ", Retab('!', 3))
|
||||||
call assert_equal(" a b c ", Retab('', 5))
|
call assert_equal(" a b c ", Retab('', 5))
|
||||||
call assert_equal(" a b c ", Retab('!', 5))
|
call assert_equal(" a b c ", Retab('!', 5))
|
||||||
|
|
||||||
|
set tabstop& expandtab&
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
func Test_retab_error()
|
func Test_retab_error()
|
||||||
@@ -80,4 +82,21 @@ func Test_retab_error()
|
|||||||
call assert_fails('ret 80000000000000000000', 'E475:')
|
call assert_fails('ret 80000000000000000000', 'E475:')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_retab_endless()
|
||||||
|
new
|
||||||
|
call setline(1, "\t0\t")
|
||||||
|
let caught = 'no'
|
||||||
|
try
|
||||||
|
while 1
|
||||||
|
set ts=4000
|
||||||
|
retab 4
|
||||||
|
endwhile
|
||||||
|
catch /E1240/
|
||||||
|
let caught = 'yes'
|
||||||
|
endtry
|
||||||
|
bwipe!
|
||||||
|
set tabstop&
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -750,6 +750,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 */
|
||||||
|
/**/
|
||||||
|
4359,
|
||||||
/**/
|
/**/
|
||||||
4358,
|
4358,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user