diff options
author | Yegappan Lakshmanan <yegappan@yahoo.com> | 2021-07-27 22:00:44 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2021-07-27 22:00:44 +0200 |
commit | 4490ec4e839e45a2e6923c265c7e9e64c240b805 (patch) | |
tree | 3ef2dc127890ac6a644f38ae7932b7e70071544a /src/ex_getln.c | |
parent | 5d7c2df536c17db4a9c61e0760bdcf78d0db7330 (diff) | |
download | vim-git-4490ec4e839e45a2e6923c265c7e9e64c240b805.tar.gz |
patch 8.2.3229: Vim9: runtime and compile time type checks are not the samev8.2.3229
Problem: Vim9: runtime and compile time type checks are not the same.
Solution: Add more runtime type checks for builtin functions. (Yegappan
Lakshmanan, closes #8646)
Diffstat (limited to 'src/ex_getln.c')
-rw-r--r-- | src/ex_getln.c | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/src/ex_getln.c b/src/ex_getln.c index 40b8886a0..ad0f07e3f 100644 --- a/src/ex_getln.c +++ b/src/ex_getln.c @@ -4061,8 +4061,12 @@ set_cmdline_pos( void f_setcmdpos(typval_T *argvars, typval_T *rettv) { - int pos = (int)tv_get_number(&argvars[0]) - 1; + int pos; + if (in_vim9script() && check_for_number_arg(argvars, 0) == FAIL) + return; + + pos = (int)tv_get_number(&argvars[0]) - 1; if (pos >= 0) rettv->vval.v_number = set_cmdline_pos(pos); } @@ -4517,7 +4521,7 @@ get_user_input( int inputdialog, int secret) { - char_u *prompt = tv_get_string_chk(&argvars[0]); + char_u *prompt; char_u *p = NULL; int c; char_u buf[NUMBUFLEN]; @@ -4531,6 +4535,15 @@ get_user_input( if (input_busy) return; // this doesn't work recursively. + if (in_vim9script() + && (check_for_string_arg(argvars, 0) == FAIL + || check_for_opt_string_arg(argvars, 1) == FAIL + || (argvars[1].v_type != VAR_UNKNOWN + && check_for_opt_string_arg(argvars, 2) == FAIL))) + return; + + prompt = tv_get_string_chk(&argvars[0]); + #ifdef NO_CONSOLE_INPUT // While starting up, there is no place to enter text. When running tests // with --not-a-term we assume feedkeys() will be used. |