diff options
author | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2015-10-18 00:45:31 +0300 |
---|---|---|
committer | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2015-10-18 01:21:23 +0300 |
commit | c3000b6f6934bdd2a9b672e8caca6c24c216cc64 (patch) | |
tree | a13cb31d528dba98b019f6f9b01464cf91a55c62 /unix/modos.c | |
parent | 6ec6f51326bdf60b3e1ac4b401d616651a74fd20 (diff) | |
download | micropython-c3000b6f6934bdd2a9b672e8caca6c24c216cc64.tar.gz micropython-c3000b6f6934bdd2a9b672e8caca6c24c216cc64.zip |
unix/modos: Add statvfs() function.
Another function (like stat) which is problematic to deal with on ABI level
(FFI), as struct statvfs layout may differ unpredictably between OSes and
even different versions of a same OS. So, implement it in C, returning a
10-element tuple of f_bsize, f_frsize, f_blocks, f_bfree, f_bavail, f_files,
f_ffree, f_favail, f_flag, f_namemax. This is exactly the order described
in Python3 docs, https://docs.python.org/3/library/os.html#os.statvfs
(but note that os.statvfs() should make these values available as
attributes).
Diffstat (limited to 'unix/modos.c')
-rw-r--r-- | unix/modos.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/unix/modos.c b/unix/modos.c index 21b9c6f6a1..02d7e37e02 100644 --- a/unix/modos.c +++ b/unix/modos.c @@ -30,6 +30,7 @@ #include <unistd.h> #include <errno.h> #include <stdlib.h> +#include <sys/statvfs.h> #include "py/nlr.h" #include "py/runtime.h" @@ -62,6 +63,31 @@ STATIC mp_obj_t mod_os_stat(mp_obj_t path_in) { } STATIC MP_DEFINE_CONST_FUN_OBJ_1(mod_os_stat_obj, mod_os_stat); +#if MICROPY_PY_OS_STATVFS +STATIC mp_obj_t mod_os_statvfs(mp_obj_t path_in) { + struct statvfs sb; + mp_uint_t len; + const char *path = mp_obj_str_get_data(path_in, &len); + + int res = statvfs(path, &sb); + RAISE_ERRNO(res, errno); + + mp_obj_tuple_t *t = mp_obj_new_tuple(10, NULL); + t->items[0] = MP_OBJ_NEW_SMALL_INT(sb.f_bsize); + t->items[1] = MP_OBJ_NEW_SMALL_INT(sb.f_frsize); + t->items[2] = MP_OBJ_NEW_SMALL_INT(sb.f_blocks); + t->items[3] = MP_OBJ_NEW_SMALL_INT(sb.f_bfree); + t->items[4] = MP_OBJ_NEW_SMALL_INT(sb.f_bavail); + t->items[5] = MP_OBJ_NEW_SMALL_INT(sb.f_files); + t->items[6] = MP_OBJ_NEW_SMALL_INT(sb.f_ffree); + t->items[7] = MP_OBJ_NEW_SMALL_INT(sb.f_favail); + t->items[8] = MP_OBJ_NEW_SMALL_INT(sb.f_flag); + t->items[9] = MP_OBJ_NEW_SMALL_INT(sb.f_namemax); + return t; +} +STATIC MP_DEFINE_CONST_FUN_OBJ_1(mod_os_statvfs_obj, mod_os_statvfs); +#endif + STATIC mp_obj_t mod_os_unlink(mp_obj_t path_in) { mp_uint_t len; const char *path = mp_obj_str_get_data(path_in, &len); @@ -88,6 +114,9 @@ STATIC MP_DEFINE_CONST_FUN_OBJ_1(mod_os_system_obj, mod_os_system); STATIC const mp_map_elem_t mp_module_os_globals_table[] = { { MP_OBJ_NEW_QSTR(MP_QSTR___name__), MP_OBJ_NEW_QSTR(MP_QSTR__os) }, { MP_OBJ_NEW_QSTR(MP_QSTR_stat), (mp_obj_t)&mod_os_stat_obj }, + #if MICROPY_PY_OS_STATVFS + { MP_OBJ_NEW_QSTR(MP_QSTR_statvfs), (mp_obj_t)&mod_os_statvfs_obj }, + #endif { MP_OBJ_NEW_QSTR(MP_QSTR_system), (mp_obj_t)&mod_os_system_obj }, { MP_OBJ_NEW_QSTR(MP_QSTR_unlink),(mp_obj_t)&mod_os_unlink_obj}, }; |