mirror of
https://github.com/vim/vim
synced 2025-07-16 09:12:00 +00:00
patch 8.2.4782: accessing freed memory
Problem: Accessing freed memory. Solution: Clear evalarg after checking for trailing characters. (issue #10218)
This commit is contained in:
@ -1,6 +1,7 @@
|
|||||||
" Test for lambda and closure
|
" Test for lambda and closure
|
||||||
|
|
||||||
source check.vim
|
source check.vim
|
||||||
|
import './vim9.vim' as v9
|
||||||
|
|
||||||
func Test_lambda_feature()
|
func Test_lambda_feature()
|
||||||
call assert_equal(1, has('lambda'))
|
call assert_equal(1, has('lambda'))
|
||||||
@ -54,6 +55,21 @@ func Test_lambda_with_timer()
|
|||||||
call assert_true(s:n > m)
|
call assert_true(s:n > m)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_lambda_vim9cmd_linebreak()
|
||||||
|
CheckFeature timers
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
vim9cmd call timer_start(10, (x) => {
|
||||||
|
# comment
|
||||||
|
g:result = 'done'
|
||||||
|
})
|
||||||
|
END
|
||||||
|
call v9.CheckScriptSuccess(lines)
|
||||||
|
sleep 50m
|
||||||
|
call assert_equal('done', g:result)
|
||||||
|
unlet g:result
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_lambda_with_partial()
|
func Test_lambda_with_partial()
|
||||||
let l:Cb = function({... -> ['zero', a:1, a:2, a:3]}, ['one', 'two'])
|
let l:Cb = function({... -> ['zero', a:1, a:2, a:3]}, ['one', 'two'])
|
||||||
call assert_equal(['zero', 'one', 'two', 'three'], l:Cb('three'))
|
call assert_equal(['zero', 'one', 'two', 'three'], l:Cb('three'))
|
||||||
|
@ -5529,7 +5529,6 @@ ex_call(exarg_T *eap)
|
|||||||
}
|
}
|
||||||
if (eap->skip)
|
if (eap->skip)
|
||||||
--emsg_skip;
|
--emsg_skip;
|
||||||
clear_evalarg(&evalarg, eap);
|
|
||||||
|
|
||||||
// When inside :try we need to check for following "| catch" or "| endtry".
|
// When inside :try we need to check for following "| catch" or "| endtry".
|
||||||
// Not when there was an error, but do check if an exception was thrown.
|
// Not when there was an error, but do check if an exception was thrown.
|
||||||
@ -5549,6 +5548,8 @@ ex_call(exarg_T *eap)
|
|||||||
else
|
else
|
||||||
set_nextcmd(eap, arg);
|
set_nextcmd(eap, arg);
|
||||||
}
|
}
|
||||||
|
// Must be after using "arg", it may point into memory cleared here.
|
||||||
|
clear_evalarg(&evalarg, eap);
|
||||||
|
|
||||||
end:
|
end:
|
||||||
dict_unref(fudi.fd_dict);
|
dict_unref(fudi.fd_dict);
|
||||||
|
@ -746,6 +746,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 */
|
||||||
|
/**/
|
||||||
|
4782,
|
||||||
/**/
|
/**/
|
||||||
4781,
|
4781,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user