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.

Raspunde prin e-mail lui