summaryrefslogtreecommitdiffstatshomepage
path: root/unix/file.c
diff options
context:
space:
mode:
authorblmorris <bryan.morrissey@gmail.com>2014-07-15 12:28:49 -0400
committerblmorris <bryan.morrissey@gmail.com>2014-07-15 12:28:49 -0400
commit0429d35f37532d2a981e704f014a248da9b157d8 (patch)
tree89b46c4453ba89072ac6926b930acf1276a79b7b /unix/file.c
parent847a6b30b17493853322532a40f48afb1d975d2e (diff)
parentdce8876dbe272d34d8d28aac21b4a4c3bdea0317 (diff)
downloadmicropython-0429d35f37532d2a981e704f014a248da9b157d8.tar.gz
micropython-0429d35f37532d2a981e704f014a248da9b157d8.zip
Merge https://github.com/micropython/micropython
Diffstat (limited to 'unix/file.c')
-rw-r--r--unix/file.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/unix/file.c b/unix/file.c
index 62e3253b7d..056a7b6e84 100644
--- a/unix/file.c
+++ b/unix/file.c
@@ -82,6 +82,17 @@ STATIC mp_int_t fdfile_write(mp_obj_t o_in, const void *buf, mp_uint_t size, int
return r;
}
+STATIC mp_obj_t fdfile_flush(mp_obj_t self_in) {
+#ifndef _WIN32
+ mp_obj_fdfile_t *self = self_in;
+ fsync(self->fd);
+#else
+ //TODO
+#endif
+ return mp_const_none;
+}
+STATIC MP_DEFINE_CONST_FUN_OBJ_1(fdfile_flush_obj, fdfile_flush);
+
STATIC mp_obj_t fdfile_close(mp_obj_t self_in) {
mp_obj_fdfile_t *self = self_in;
close(self->fd);
@@ -166,6 +177,7 @@ STATIC const mp_map_elem_t rawfile_locals_dict_table[] = {
{ MP_OBJ_NEW_QSTR(MP_QSTR_readline), (mp_obj_t)&mp_stream_unbuffered_readline_obj},
{ MP_OBJ_NEW_QSTR(MP_QSTR_readlines), (mp_obj_t)&mp_stream_unbuffered_readlines_obj},
{ MP_OBJ_NEW_QSTR(MP_QSTR_write), (mp_obj_t)&mp_stream_write_obj },
+ { MP_OBJ_NEW_QSTR(MP_QSTR_flush), (mp_obj_t)&fdfile_flush_obj },
{ MP_OBJ_NEW_QSTR(MP_QSTR_close), (mp_obj_t)&fdfile_close_obj },
{ MP_OBJ_NEW_QSTR(MP_QSTR___enter__), (mp_obj_t)&mp_identity_obj },
{ MP_OBJ_NEW_QSTR(MP_QSTR___exit__), (mp_obj_t)&fdfile___exit___obj },