* io.c (+setup_narg): factor out length calculation logic.

* io.c (rb_io_ctl): ditto.



git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@33713 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
kosaki 2011-11-12 02:09:56 +00:00
Родитель 6ed2a4dfb3
Коммит eec252e2e5
2 изменённых файлов: 27 добавлений и 11 удалений

Просмотреть файл

@ -1,3 +1,8 @@
Sat Nov 12 10:56:43 2011 KOSAKI Motohiro <kosaki.motohiro@gmail.com>
* io.c (+setup_narg): factor out length calculation logic.
* io.c (rb_io_ctl): ditto.
Sat Nov 12 10:52:17 2011 KOSAKI Motohiro <kosaki.motohiro@gmail.com> Sat Nov 12 10:52:17 2011 KOSAKI Motohiro <kosaki.motohiro@gmail.com>
* io.c (+ioctl_narg_len) new helper function. * io.c (+ioctl_narg_len) new helper function.

33
io.c
Просмотреть файл

@ -7928,16 +7928,11 @@ ioctl_narg_len(int cmd)
return len; return len;
} }
static VALUE static long
rb_io_ctl(VALUE io, VALUE req, VALUE arg, int io_p) setup_narg(int cmd, VALUE *argp, int io_p)
{ {
int cmd = NUM2INT(req);
rb_io_t *fptr;
long len = 0;
long narg = 0; long narg = 0;
int retval; VALUE arg = *argp;
rb_secure(2);
if (NIL_P(arg) || arg == Qfalse) { if (NIL_P(arg) || arg == Qfalse) {
narg = 0; narg = 0;
@ -7955,10 +7950,11 @@ rb_io_ctl(VALUE io, VALUE req, VALUE arg, int io_p)
narg = NUM2LONG(arg); narg = NUM2LONG(arg);
} }
else { else {
arg = tmp; long len;
*argp = arg = tmp;
if (io_p) if (io_p)
ioctl_narg_len(cmd); len = ioctl_narg_len(cmd);
else else
len = 256; len = 256;
rb_str_modify(arg); rb_str_modify(arg);
@ -7973,10 +7969,25 @@ rb_io_ctl(VALUE io, VALUE req, VALUE arg, int io_p)
narg = (long)(SIGNED_VALUE)RSTRING_PTR(arg); narg = (long)(SIGNED_VALUE)RSTRING_PTR(arg);
} }
} }
return narg;
}
static VALUE
rb_io_ctl(VALUE io, VALUE req, VALUE arg, int io_p)
{
int cmd = NUM2INT(req);
rb_io_t *fptr;
long narg;
int retval;
rb_secure(2);
narg = setup_narg(cmd, &arg, io_p);
GetOpenFile(io, fptr); GetOpenFile(io, fptr);
retval = io_cntl(fptr->fd, cmd, narg, io_p); retval = io_cntl(fptr->fd, cmd, narg, io_p);
if (retval < 0) rb_sys_fail_path(fptr->pathv); if (retval < 0) rb_sys_fail_path(fptr->pathv);
if (RB_TYPE_P(arg, T_STRING) && RSTRING_PTR(arg)[len] != 17) { if (RB_TYPE_P(arg, T_STRING) && RSTRING_PTR(arg)[RSTRING_LEN(arg)-1] != 17) {
rb_raise(rb_eArgError, "return value overflowed string"); rb_raise(rb_eArgError, "return value overflowed string");
} }