Problem: Unlet command leaks memory. (Nikolai Pavlov)
Solution: Free the memory on error. (closes #1497)
}
/* existing variable, need to check if it can be changed */
else if (var_check_ro(lp->ll_di->di_flags, name, FALSE))
+ {
+ clear_tv(&var1);
return NULL;
+ }
if (len == -1)
clear_tv(&var1);
unlet! does_not_exist
call assert_fails('unlet does_not_exist', 'E108:')
endfunc
+
+func Test_unlet_fails()
+ call assert_fails('unlet v:["count"]', 'E46:')
+endfunc
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 344,
/**/
343,
/**/