0
0
mirror of https://github.com/vim/vim.git synced 2025-09-24 03:44:06 -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') call CheckDefExecFailure(["let d: dict<number>", "d = g:list_empty"], 'E1029: Expected dict but got list')
enddef 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() def Test_expr_member_vim9script()
let lines =<< trim END let lines =<< trim END
vim9script vim9script

View File

@@ -754,6 +754,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 */
/**/
1134,
/**/ /**/
1133, 1133,
/**/ /**/

View File

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