]> granicus.if.org Git - vim/commitdiff
patch 8.2.0227: compiling a few instructions not tested v8.2.0227
authorBram Moolenaar <Bram@vim.org>
Thu, 6 Feb 2020 21:41:16 +0000 (22:41 +0100)
committerBram Moolenaar <Bram@vim.org>
Thu, 6 Feb 2020 21:41:16 +0000 (22:41 +0100)
Problem:    Compiling a few instructions not tested.
Solution:   Add more test cases.

src/testdir/test_vim9_disassemble.vim
src/version.c

index d9a2ad455f4b1bbf4611a06be3853108da818cfb..b6edb0d6c39c6b65e288866ee67bfc9d9cb2fd11 100644 (file)
@@ -106,7 +106,7 @@ def s:ScriptFuncTry()
   catch /fail/
     echo 'no'
   finally
-    echo 'end'
+    throw 'end'
   endtry
 enddef
 
@@ -124,6 +124,7 @@ def Test_disassembleTry()
         \ .. ' CATCH.*'
         \ .. 'finally.*'
         \ .. ' PUSHS "end".*'
+        \ .. ' THROW.*'
         \ .. 'endtry.*'
         \ .. ' ENDTRY.*'
         \, res)
@@ -357,5 +358,81 @@ def Test_compile_for_loop()
         \, instr)
 enddef
 
+let g:number = 42
+
+def Computing()
+  let nr = 3
+  let nrres = nr + 7
+  nrres = nr - 7
+  nrres = nr * 7
+  nrres = nr / 7
+  nrres = nr % 7
+
+  let anyres = g:number + 7
+  anyres = g:number - 7
+  anyres = g:number * 7
+  anyres = g:number / 7
+  anyres = g:number % 7
+
+  if has('float')
+    let fl = 3.0
+    let flres = fl + 7.0
+    flres = fl - 7.0
+    flres = fl * 7.0
+    flres = fl / 7.0
+  endif
+enddef
+
+def Test_computing()
+  let instr = execute('disassemble Computing')
+  assert_match('Computing.*'
+        \ .. 'let nr = 3.*'
+        \ .. '\d STORE 3 in $0.*'
+        \ .. 'let nrres = nr + 7.*'
+        \ .. '\d LOAD $0.*'
+        \ .. '\d PUSHNR 7.*'
+        \ .. '\d OPNR +.*'
+        \ .. '\d STORE $1.*'
+        \ .. 'nrres = nr - 7.*'
+        \ .. '\d OPNR -.*'
+        \ .. 'nrres = nr \* 7.*'
+        \ .. '\d OPNR \*.*'
+        \ .. 'nrres = nr / 7.*'
+        \ .. '\d OPNR /.*'
+        \ .. 'nrres = nr % 7.*'
+        \ .. '\d OPNR %.*'
+        \ .. 'let anyres = g:number + 7.*'
+        \ .. '\d LOADG g:number.*'
+        \ .. '\d PUSHNR 7.*'
+        \ .. '\d OPANY +.*'
+        \ .. '\d STORE $2.*'
+        \ .. 'anyres = g:number - 7.*'
+        \ .. '\d OPANY -.*'
+        \ .. 'anyres = g:number \* 7.*'
+        \ .. '\d OPANY \*.*'
+        \ .. 'anyres = g:number / 7.*'
+        \ .. '\d OPANY /.*'
+        \ .. 'anyres = g:number % 7.*'
+        \ .. '\d OPANY %.*'
+        \, instr)
+  if has('float')
+    assert_match('Computing.*'
+        \ .. 'let fl = 3.0.*'
+        \ .. '\d PUSHF 3.0.*'
+        \ .. '\d STORE $3.*'
+        \ .. 'let flres = fl + 7.0.*'
+        \ .. '\d LOAD $3.*'
+        \ .. '\d PUSHF 7.0.*'
+        \ .. '\d OPFLOAT +.*'
+        \ .. '\d STORE $4.*'
+        \ .. 'flres = fl - 7.0.*'
+        \ .. '\d OPFLOAT -.*'
+        \ .. 'flres = fl \* 7.0.*'
+        \ .. '\d OPFLOAT \*.*'
+        \ .. 'flres = fl / 7.0.*'
+        \ .. '\d OPFLOAT /.*'
+        \, instr)
+  endif
+enddef
 
 " vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker
index 4b03add2a92c8648c10b0386ff5c446aba2e39bb..82f1003beb98b2abccf5eb88bf9fa1218bae62ad 100644 (file)
@@ -742,6 +742,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    227,
 /**/
     226,
 /**/