summaryrefslogtreecommitdiff
path: root/src/filepath.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2020-12-09 12:41:50 +0100
committerBram Moolenaar <Bram@vim.org>2020-12-09 12:41:50 +0100
commit7bb4e74c38642682cfdd0cb4052adfa5efdd7dd1 (patch)
tree87b6644c08d544bae227365d78c1a7c11c611a6d /src/filepath.c
parent2c78a772fdb5f6a16d16a47e7f218051c4dcb845 (diff)
downloadvim-git-7bb4e74c38642682cfdd0cb4052adfa5efdd7dd1.tar.gz
patch 8.2.2117: some functions use any value as a stringv8.2.2117
Problem: Some functions use any value as a string. Solution: Check that the value is a non-empty string.
Diffstat (limited to 'src/filepath.c')
-rw-r--r--src/filepath.c29
1 files changed, 23 insertions, 6 deletions
diff --git a/src/filepath.c b/src/filepath.c
index 717727525..89fafe313 100644
--- a/src/filepath.c
+++ b/src/filepath.c
@@ -861,10 +861,11 @@ f_delete(typval_T *argvars, typval_T *rettv)
void
f_executable(typval_T *argvars, typval_T *rettv)
{
- char_u *name = tv_get_string(&argvars[0]);
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
// Check in $PATH and also check directly if there is a directory name.
- rettv->vval.v_number = mch_can_exe(name, NULL, TRUE);
+ rettv->vval.v_number = mch_can_exe(tv_get_string(&argvars[0]), NULL, TRUE);
}
/*
@@ -875,6 +876,8 @@ f_exepath(typval_T *argvars, typval_T *rettv)
{
char_u *p = NULL;
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
(void)mch_can_exe(tv_get_string(&argvars[0]), &p, TRUE);
rettv->v_type = VAR_STRING;
rettv->vval.v_string = p;
@@ -890,6 +893,8 @@ f_filereadable(typval_T *argvars, typval_T *rettv)
char_u *p;
int n;
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
#ifndef O_NONBLOCK
# define O_NONBLOCK 0
#endif
@@ -913,6 +918,8 @@ f_filereadable(typval_T *argvars, typval_T *rettv)
void
f_filewritable(typval_T *argvars, typval_T *rettv)
{
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
rettv->vval.v_number = filewritable(tv_get_string(&argvars[0]));
}
@@ -935,6 +942,8 @@ findfilendir(
rettv->vval.v_string = NULL;
rettv->v_type = VAR_STRING;
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
#ifdef FEAT_SEARCHPATH
fname = tv_get_string(&argvars[0]);
@@ -1014,6 +1023,9 @@ f_fnamemodify(typval_T *argvars, typval_T *rettv)
char_u *fbuf = NULL;
char_u buf[NUMBUFLEN];
+ if (in_vim9script() && (check_for_string(&argvars[0]) == FAIL
+ || check_for_string(&argvars[1]) == FAIL))
+ return;
fname = tv_get_string_chk(&argvars[0]);
mods = tv_get_string_buf_chk(&argvars[1], buf);
if (fname == NULL || mods == NULL)
@@ -1122,6 +1134,8 @@ f_getfperm(typval_T *argvars, typval_T *rettv)
char_u *perm = NULL;
char_u permbuf[] = "---------";
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
fname = tv_get_string(&argvars[0]);
rettv->v_type = VAR_STRING;
@@ -1139,10 +1153,10 @@ f_getfsize(typval_T *argvars, typval_T *rettv)
char_u *fname;
stat_T st;
- fname = tv_get_string(&argvars[0]);
-
- rettv->v_type = VAR_NUMBER;
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
+ fname = tv_get_string(&argvars[0]);
if (mch_stat((char *)fname, &st) >= 0)
{
if (mch_isdir(fname))
@@ -1169,8 +1183,9 @@ f_getftime(typval_T *argvars, typval_T *rettv)
char_u *fname;
stat_T st;
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
fname = tv_get_string(&argvars[0]);
-
if (mch_stat((char *)fname, &st) >= 0)
rettv->vval.v_number = (varnumber_T)st.st_mtime;
else
@@ -1214,6 +1229,8 @@ f_getftype(typval_T *argvars, typval_T *rettv)
stat_T st;
char_u *type = NULL;
+ if (in_vim9script() && check_for_string(&argvars[0]) == FAIL)
+ return;
fname = tv_get_string(&argvars[0]);
rettv->v_type = VAR_STRING;