Patch 8.2.2145
Problem: Vim9: concatenating lists does not adjust type of result.
Solution: When list member types differ use "any" member type.
(closes #7473)
Files: src/vim9compile.c, src/testdir/test_vim9_expr.vim
*** ../vim-8.2.2144/src/vim9compile.c 2020-12-13 21:26:51.565418479 +0100
--- src/vim9compile.c 2020-12-15 21:28:27.896083780 +0100
***************
*** 538,551 ****
type_T *type1,
type_T *type2)
{
! isn_T *isn = generate_instr_drop(cctx,
! vartype == VAR_NUMBER ? ISN_OPNR
! : vartype == VAR_LIST ? ISN_ADDLIST
! : vartype == VAR_BLOB ? ISN_ADDBLOB
#ifdef FEAT_FLOAT
! : vartype == VAR_FLOAT ? ISN_OPFLOAT
#endif
! : ISN_OPANY, 1);
if (vartype != VAR_LIST && vartype != VAR_BLOB
&& type1->tt_type != VAR_ANY
--- 538,552 ----
type_T *type1,
type_T *type2)
{
! garray_T *stack = &cctx->ctx_type_stack;
! isn_T *isn = generate_instr_drop(cctx,
! vartype == VAR_NUMBER ? ISN_OPNR
! : vartype == VAR_LIST ? ISN_ADDLIST
! : vartype == VAR_BLOB ? ISN_ADDBLOB
#ifdef FEAT_FLOAT
! : vartype == VAR_FLOAT ? ISN_OPFLOAT
#endif
! : ISN_OPANY, 1);
if (vartype != VAR_LIST && vartype != VAR_BLOB
&& type1->tt_type != VAR_ANY
***************
*** 556,561 ****
--- 557,570 ----
if (isn != NULL)
isn->isn_arg.op.op_type = EXPR_ADD;
+
+ // When concatenating two lists with different member types the member
type
+ // becomes "any".
+ if (vartype == VAR_LIST
+ && type1->tt_type == VAR_LIST && type2->tt_type == VAR_LIST
+ && type1->tt_member != type2->tt_member)
+ (((type_T **)stack->ga_data)[stack->ga_len - 1]) = &t_list_any;
+
return isn == NULL ? FAIL : OK;
}
***************
*** 7172,7177 ****
--- 7181,7187 ----
// Either no range or a number.
// "errormsg" will not be set because the range is ADDR_LINES.
if (parse_cmd_address(eap, &errormsg, FALSE) == FAIL)
+ // cannot happen
return NULL;
if (eap->addr_count == 0)
lnum = -1;
*** ../vim-8.2.2144/src/testdir/test_vim9_expr.vim 2020-12-09
12:41:44.934219841 +0100
--- src/testdir/test_vim9_expr.vim 2020-12-15 21:15:36.018534668 +0100
***************
*** 1317,1322 ****
--- 1317,1339 ----
call CheckDefFailure(["var x = 'a' .. test_null_channel()"], 'E1105:', 1)
endfunc
+ def Test_expr5_list_add()
+ # concatenating two lists with same member types is OK
+ var d = {}
+ for i in ['a'] + ['b']
+ d = {[i]: 0}
+ endfor
+
+ # concatenating two lists with different member types results in "any"
+ var lines =<< trim END
+ var d = {}
+ for i in ['a'] + [0]
+ d = {[i]: 0}
+ endfor
+ END
+ CheckDefExecFailure(lines, 'E1012:')
+ enddef
+
" test multiply, divide, modulo
def Test_expr6()
var lines =<< trim END
*** ../vim-8.2.2144/src/version.c 2020-12-14 18:31:24.062840347 +0100
--- src/version.c 2020-12-15 21:28:37.372053306 +0100
***************
*** 752,753 ****
--- 752,755 ----
{ /* Add new patch number below this line */
+ /**/
+ 2145,
/**/
--
The problem with political jokes is that they get elected.
/// Bram Moolenaar -- [email protected] -- http://www.Moolenaar.net \\\
/// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\ an exciting new programming language -- http://www.Zimbu.org ///
\\\ help me help AIDS victims -- http://ICCF-Holland.org ///
--
--
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php
---
You received this message because you are subscribed to the Google Groups
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To view this discussion on the web visit
https://groups.google.com/d/msgid/vim_dev/202012152029.0BFKTUAN445208%40masaka.moolenaar.net.