0
0
mirror of https://github.com/vim/vim.git synced 2025-09-25 03:54:15 -04:00

patch 8.2.1134: Vim9: getting a list member may not work

Problem:    Vim9: getting a list member may not work.
Solution:   Clear the list only after copying the item. (closes #6393)
This commit is contained in:
Bram Moolenaar
2020-07-05 16:42:13 +02:00
parent fce82b3aa7
commit 435d89789e
3 changed files with 14 additions and 2 deletions

View File

@@ -1141,6 +1141,11 @@ def Test_expr_member()
call CheckDefExecFailure(["let d: dict<number>", "d = g:list_empty"], 'E1029: Expected dict but got list')
enddef
def Test_expr_index()
# getting the one member should clear the list only after getting the item
assert_equal('bbb', ['aaa', 'bbb', 'ccc'][1])
enddef
def Test_expr_member_vim9script()
let lines =<< trim END
vim9script

View File

@@ -754,6 +754,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
1134,
/**/
1133,
/**/

View File

@@ -2085,6 +2085,7 @@ call_def_function(
list_T *list;
varnumber_T n;
listitem_T *li;
typval_T temp_tv;
// list index: list is at stack-2, index at stack-1
tv = STACK_TV_BOT(-2);
@@ -2109,8 +2110,12 @@ call_def_function(
goto failed;
}
--ectx.ec_stack.ga_len;
clear_tv(STACK_TV_BOT(-1));
copy_tv(&li->li_tv, STACK_TV_BOT(-1));
// Clear the list after getting the item, to avoid that it
// make the item invalid.
tv = STACK_TV_BOT(-1);
temp_tv = *tv;
copy_tv(&li->li_tv, tv);
clear_tv(&temp_tv);
}
break;