]> granicus.if.org Git - vim/commitdiff
patch 8.2.1106: crash when trying to use s: variable in typed command v8.2.1106
authorBram Moolenaar <Bram@vim.org>
Wed, 1 Jul 2020 12:38:12 +0000 (14:38 +0200)
committerBram Moolenaar <Bram@vim.org>
Wed, 1 Jul 2020 12:38:12 +0000 (14:38 +0200)
Problem:    Crash when trying to use s: variable in typed command.
Solution:   Don't use the script index when not set. (Ken Takata,
            closes #6366)

src/testdir/test_vimscript.vim
src/version.c
src/vim9compile.c

index 2ca4e752e4c89571f107901f229f4792dfe0b348..0a03445a08a9770c03ce0588bd0477d53ad380f7 100644 (file)
@@ -2007,6 +2007,7 @@ func Test_float_conversion_errors()
   endif
 endfunc
 
+" invalid function names               {{{1
 func Test_invalid_function_names()
   " function name not starting with capital
   let caught_e128 = 0
@@ -2067,7 +2068,7 @@ func Test_invalid_function_names()
   call delete('Xscript')
 endfunc
 
-" substring and variable name
+" substring and variable name              {{{1
 func Test_substring_var()
   let str = 'abcdef'
   let n = 3
@@ -2087,6 +2088,20 @@ func Test_substring_var()
   unlet b:nn
 endfunc
 
+" Test using s: with a typed command              {{{1
+func Test_typed_script_var()
+  CheckRunVimInTerminal
+
+  let buf = RunVimInTerminal('', {'rows': 6})
+
+  " Deep nesting of if ... endif
+  call term_sendkeys(buf, ":echo get(s:, 'foo', 'x')\n")
+  call TermWait(buf)
+  call WaitForAssert({-> assert_match('^E116:', term_getline(buf, 5))})
+
+  call StopVimInTerminal(buf)
+endfunc
+
 "-------------------------------------------------------------------------------
 " Modelines                                                                {{{1
 " vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
index a3dd0fb33019e7166cfd51debd057a0a18a4bf06..8f08cc5cf9026d78ec3153fe59eb6bbba8803b68 100644 (file)
@@ -754,6 +754,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1106,
 /**/
     1105,
 /**/
index d37c5c95d0e2da8b224ca5b2517e79731499dee7..fdb422bf28e8c3d71dcc89ecca377aa43a1d4b8b 100644 (file)
@@ -2339,6 +2339,9 @@ find_imported(char_u *name, size_t len, cctx_T *cctx)
     scriptitem_T    *si = SCRIPT_ITEM(current_sctx.sc_sid);
     int                    idx;
 
+    if (current_sctx.sc_sid <= 0)
+       return NULL;
+    si = SCRIPT_ITEM(current_sctx.sc_sid);
     if (cctx != NULL)
        for (idx = 0; idx < cctx->ctx_imports.ga_len; ++idx)
        {