diff options
| author | Paolo Bosetti <[email protected]> | 2013-10-02 13:05:12 +0200 |
|---|---|---|
| committer | Paolo Bosetti <[email protected]> | 2013-10-02 13:05:12 +0200 |
| commit | c608c26ab47eb226cfed310c4cf16ed31be7fa0d (patch) | |
| tree | 8a7027459758c8bdb98cdb85a60e68af9d99808d /src/file.c | |
| parent | 49494a736733e94b88e20b2b2fe9769c90862b5a (diff) | |
| parent | 8b48e2b4a42c9e1c697f94d3bb362a12484fe2e7 (diff) | |
| download | mruby-c608c26ab47eb226cfed310c4cf16ed31be7fa0d.tar.gz mruby-c608c26ab47eb226cfed310c4cf16ed31be7fa0d.zip | |
Merge branch 'master' of https://github.com/iij/mruby-io
Diffstat (limited to 'src/file.c')
| -rw-r--r-- | src/file.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/src/file.c b/src/file.c index 0fed5b21a..5c46aa965 100644 --- a/src/file.c +++ b/src/file.c @@ -36,6 +36,9 @@ #define STAT(p, s) stat(p, s) +extern mrb_value mrb_io_fileno(mrb_state *mrb, mrb_value io); + + mrb_value mrb_file_s_umask(mrb_state *mrb, mrb_value klass) { @@ -262,6 +265,36 @@ mrb_file__gethome(mrb_state *mrb, mrb_value klass) return mrb_str_new_cstr(mrb, home); } +mrb_value +mrb_file_flock(mrb_state *mrb, mrb_value self) +{ + mrb_int operation; + int fd; + + mrb_get_args(mrb, "i", &operation); + fd = mrb_fixnum(mrb_io_fileno(mrb, self)); + + while (flock(fd, operation) == -1) { + switch (errno) { + case EINTR: + /* retry */ + break; + case EAGAIN: /* NetBSD */ +#if defined(EWOULDBLOCK) && EWOULDBLOCK != EAGAIN + case EWOULDBLOCK: /* FreeBSD OpenBSD Linux */ +#endif + if (operation & LOCK_NB) { + return mrb_false_value(); + } + /* FALLTHRU - should not happen */ + default: + mrb_sys_fail(mrb, "flock failed"); + break; + } + } + return mrb_fixnum_value(0); +} + void mrb_init_file(mrb_state *mrb) { @@ -282,6 +315,8 @@ mrb_init_file(mrb_state *mrb) mrb_define_class_method(mrb, file, "_getwd", mrb_file__getwd, MRB_ARGS_NONE()); mrb_define_class_method(mrb, file, "_gethome", mrb_file__gethome, MRB_ARGS_OPT(1)); + mrb_define_method(mrb, file, "flock", mrb_file_flock, MRB_ARGS_REQ(1)); + cnst = mrb_define_module_under(mrb, file, "Constants"); mrb_define_const(mrb, cnst, "LOCK_SH", mrb_fixnum_value(LOCK_SH)); mrb_define_const(mrb, cnst, "LOCK_EX", mrb_fixnum_value(LOCK_EX)); |
