summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-07-14 21:00:41 +0200
committerBram Moolenaar <Bram@vim.org>2021-07-14 21:00:41 +0200
commitc816a2c22667108fcd61f445de2c926f78ff9fa7 (patch)
treef6b7fe9ee819ac64e1c2602a52c5c66ae1a0390d
parent4a0b85ad0193ac162e2d8458e4b1c5ad2e2b0193 (diff)
patch 8.2.3161: Vim9: no error when reltime() has invalid argumentsv8.2.3161
Problem: Vim9: no error when reltime() has invalid arguments. Solution: Add an error. (closes #8562)
-rw-r--r--src/testdir/test_vim9_builtin.vim13
-rw-r--r--src/time.c12
-rw-r--r--src/version.c2
3 files changed, 27 insertions, 0 deletions
diff --git a/src/testdir/test_vim9_builtin.vim b/src/testdir/test_vim9_builtin.vim
index 03bc3fbe30..f5315f91f1 100644
--- a/src/testdir/test_vim9_builtin.vim
+++ b/src/testdir/test_vim9_builtin.vim
@@ -1652,6 +1652,11 @@ def Test_readfile()
enddef
def Test_reltime()
+ CheckFeature reltime
+
+ CheckDefExecAndScriptFailure(['[]->reltime()'], 'E474:')
+ CheckDefExecAndScriptFailure(['[]->reltime([])'], 'E474:')
+
CheckDefFailure(['reltime("x")'], 'E1013: Argument 1: type mismatch, expected list<number> but got string')
CheckDefFailure(['reltime(["x", "y"])'], 'E1013: Argument 1: type mismatch, expected list<number> but got list<string>')
CheckDefFailure(['reltime([1, 2], 10)'], 'E1013: Argument 2: type mismatch, expected list<number> but got number')
@@ -1663,12 +1668,20 @@ def Test_reltime()
enddef
def Test_reltimefloat()
+ CheckFeature reltime
+
+ CheckDefExecAndScriptFailure(['[]->reltimefloat()'], 'E474:')
+
CheckDefFailure(['reltimefloat("x")'], 'E1013: Argument 1: type mismatch, expected list<number> but got string')
CheckDefFailure(['reltimefloat([1.1])'], 'E1013: Argument 1: type mismatch, expected list<number> but got list<float>')
assert_true(type(reltimefloat(reltime())) == v:t_float)
enddef
def Test_reltimestr()
+ CheckFeature reltime
+
+ CheckDefExecAndScriptFailure(['[]->reltimestr()'], 'E474:')
+
CheckDefFailure(['reltimestr(true)'], 'E1013: Argument 1: type mismatch, expected list<number> but got bool')
CheckDefFailure(['reltimestr([true])'], 'E1013: Argument 1: type mismatch, expected list<number> but got list<bool>')
assert_true(type(reltimestr(reltime())) == v:t_string)
diff --git a/src/time.c b/src/time.c
index 6d4ad5d51e..02c5da9dd1 100644
--- a/src/time.c
+++ b/src/time.c
@@ -178,7 +178,11 @@ f_reltime(typval_T *argvars UNUSED, typval_T *rettv UNUSED)
else if (argvars[1].v_type == VAR_UNKNOWN)
{
if (list2proftime(&argvars[0], &res) == FAIL)
+ {
+ if (in_vim9script())
+ emsg(_(e_invarg));
return;
+ }
profile_end(&res);
}
else
@@ -186,7 +190,11 @@ f_reltime(typval_T *argvars UNUSED, typval_T *rettv UNUSED)
// Two arguments: compute the difference.
if (list2proftime(&argvars[0], &start) == FAIL
|| list2proftime(&argvars[1], &res) == FAIL)
+ {
+ if (in_vim9script())
+ emsg(_(e_invarg));
return;
+ }
profile_sub(&res, &start);
}
@@ -223,6 +231,8 @@ f_reltimefloat(typval_T *argvars UNUSED, typval_T *rettv)
# ifdef FEAT_RELTIME
if (list2proftime(&argvars[0], &tm) == OK)
rettv->vval.v_float = profile_float(&tm);
+ else if (in_vim9script())
+ emsg(_(e_invarg));
# endif
}
# endif
@@ -242,6 +252,8 @@ f_reltimestr(typval_T *argvars UNUSED, typval_T *rettv)
# ifdef FEAT_RELTIME
if (list2proftime(&argvars[0], &tm) == OK)
rettv->vval.v_string = vim_strsave((char_u *)profile_msg(&tm));
+ else if (in_vim9script())
+ emsg(_(e_invarg));
# endif
}
diff --git a/src/version.c b/src/version.c
index e20a32c612..7e3455d907 100644
--- a/src/version.c
+++ b/src/version.c
@@ -756,6 +756,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 3161,
+/**/
3160,
/**/
3159,