aboutsummaryrefslogtreecommitdiff
path: root/src/eval.c
diff options
context:
space:
mode:
authorStefan Hoffmann <stefan991@gmail.com>2014-04-25 18:46:50 +0200
committerStefan Hoffmann <stefan991@gmail.com>2014-05-09 15:49:33 +0200
commit9784dabb505f736907c17a92885756e4175bd513 (patch)
tree980892c6a206e03ecfd35d29eca650535dcf72cb /src/eval.c
parentd936bb82ad1833ce3b5170ee89fb6cd9f4b749d7 (diff)
downloadrneovim-9784dabb505f736907c17a92885756e4175bd513.tar.gz
rneovim-9784dabb505f736907c17a92885756e4175bd513.tar.bz2
rneovim-9784dabb505f736907c17a92885756e4175bd513.zip
implemented os_file_get_size()
Diffstat (limited to 'src/eval.c')
-rw-r--r--src/eval.c18
1 files changed, 9 insertions, 9 deletions
diff --git a/src/eval.c b/src/eval.c
index 59bd6d2975..b508d4257f 100644
--- a/src/eval.c
+++ b/src/eval.c
@@ -9687,25 +9687,25 @@ static void f_getfperm(typval_T *argvars, typval_T *rettv)
*/
static void f_getfsize(typval_T *argvars, typval_T *rettv)
{
- char_u *fname;
- struct stat st;
-
- fname = get_tv_string(&argvars[0]);
+ char *fname = (char *)get_tv_string(&argvars[0]);
rettv->v_type = VAR_NUMBER;
- if (mch_stat((char *)fname, &st) >= 0) {
- if (os_isdir(fname))
+ off_t file_size;
+ if (os_get_file_size(fname, &file_size)) {
+ if (os_isdir((char_u *)fname))
rettv->vval.v_number = 0;
else {
- rettv->vval.v_number = (varnumber_T)st.st_size;
+ rettv->vval.v_number = (varnumber_T)file_size;
/* non-perfect check for overflow */
- if ((off_t)rettv->vval.v_number != (off_t)st.st_size)
+ if ((off_t)rettv->vval.v_number != file_size) {
rettv->vval.v_number = -2;
+ }
}
- } else
+ } else {
rettv->vval.v_number = -1;
+ }
}
/*