summaryrefslogtreecommitdiff
path: root/io.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-11-26 06:27:45 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-11-26 06:27:45 +0000
commit6d0f22ebc6cf0c3ad5d542bf5bfd140a0f7c98cf (patch)
tree0667288c09d3d10b93dc36917220eb887b33c984 /io.c
parentc97c3590530f9742ca0e49d36b3c953763d0224a (diff)
* io.c (rb_io_initialize): [ruby-dev:24963]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7385 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r--io.c30
1 files changed, 13 insertions, 17 deletions
diff --git a/io.c b/io.c
index 0875fb552f..33c2cfca72 100644
--- a/io.c
+++ b/io.c
@@ -3970,36 +3970,32 @@ rb_io_initialize(argc, argv, io)
orig = rb_io_check_io(fnum);
if (NIL_P(orig)) {
fd = NUM2INT(fnum);
- }
- else {
- GetOpenFile(orig, ofp);
- if (ofp->refcnt == LONG_MAX) {
- VALUE s = rb_inspect(orig);
- rb_raise(rb_eIOError, "too many shared IO for %s", StringValuePtr(s));
- }
- }
- if (argc != 2) {
+ if (argc != 2) {
#if defined(HAVE_FCNTL) && defined(F_GETFL)
- flags = fcntl(fd, F_GETFL);
- if (flags == -1) rb_sys_fail(0);
+ flags = fcntl(fd, F_GETFL);
+ if (flags == -1) rb_sys_fail(0);
#else
- flags = O_RDONLY;
+ flags = O_RDONLY;
#endif
- }
- fmode = rb_io_modenum_flags(flags);
- if (!ofp) {
+ }
MakeOpenFile(io, fp);
- fp->mode = fmode;
+ fp->mode = rb_io_modenum_flags(flags);
fp->f = rb_fdopen(fd, rb_io_modenum_mode(flags));
}
else {
+ GetOpenFile(orig, ofp);
+ if (ofp->refcnt == LONG_MAX) {
+ VALUE s = rb_inspect(orig);
+ rb_raise(rb_eIOError, "too many shared IO for %s", StringValuePtr(s));
+ }
if (argc == 2) {
+ fmode = rb_io_modenum_flags(flags);
if ((ofp->mode ^ fmode) & (FMODE_READWRITE|FMODE_BINMODE)) {
if (FIXNUM_P(mode)) {
rb_raise(rb_eArgError, "incompatible mode 0%o", flags);
}
else {
- rb_raise(rb_eArgError, "incompatible mode %s", RSTRING(mode)->ptr);
+ rb_raise(rb_eArgError, "incompatible mode \"%s\"", RSTRING(mode)->ptr);
}
}
}