diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-06-13 14:28:53 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-06-13 14:28:53 +0000 |
commit | a7b0b52f09b63e8ffe28b0040b54ae71a4a829e4 (patch) | |
tree | 4dc5ccf1790b9efe273b6a5195f2b253b5e2a9e2 | |
parent | bcfc22b10e30771e692f7716a1fec7577373963e (diff) | |
download | ruby-a7b0b52f09b63e8ffe28b0040b54ae71a4a829e4.tar.gz |
* ext/io/console/console.c (console_dev): take care of no-ctty
case.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@32065 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | ext/io/console/console.c | 25 | ||||
-rw-r--r-- | test/io/console/test_io_console.rb | 10 |
3 files changed, 32 insertions, 8 deletions
@@ -1,3 +1,8 @@ +Mon Jun 13 23:28:50 2011 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * ext/io/console/console.c (console_dev): take care of no-ctty + case. + Mon Jun 13 23:06:12 2011 KOSAKI Motohiro <kosaki.motohiro@gmail.com> * thread_pthread.c: rewrite GVL completely. diff --git a/ext/io/console/console.c b/ext/io/console/console.c index cc4ab11380..c2660d2ac9 100644 --- a/ext/io/console/console.c +++ b/ext/io/console/console.c @@ -557,27 +557,36 @@ console_dev(VALUE klass) VALUE out; rb_io_t *ofptr; #endif + int fd, mode; - args[1] = INT2FIX(O_RDWR); #ifdef CONSOLE_DEVICE_FOR_WRITING - args[0] = rb_str_new2(CONSOLE_DEVICE_FOR_WRITING); + fd = open(CONSOLE_DEVICE_FOR_WRITING, O_WRONLY); + if (fd < 0) return Qnil; + args[1] = INT2FIX(O_WRONLY); + args[0] = INT2NUM(fd); out = rb_class_new_instance(2, args, klass); #endif - args[0] = rb_str_new2(CONSOLE_DEVICE_FOR_READING); - con = rb_class_new_instance(2, args, klass); + fd = open(CONSOLE_DEVICE_FOR_READING, O_RDWR); + if (fd < 0) { #ifdef CONSOLE_DEVICE_FOR_WRITING + rb_io_close(out); +#endif + return Qnil; + } + args[1] = INT2FIX(O_RDWR); + args[0] = INT2NUM(fd); + con = rb_class_new_instance(2, args, klass); GetOpenFile(con, fptr); + fptr->pathv = rb_obj_freeze(rb_str_new2(CONSOLE_DEVICE)); +#ifdef CONSOLE_DEVICE_FOR_WRITING GetOpenFile(out, ofptr); # ifdef HAVE_RB_IO_GET_WRITE_IO -# ifdef _WIN32 - ofptr->pathv = fptr->pathv = rb_str_new2(CONSOLE_DEVICE); -# endif + ofptr->pathv = fptr->pathv; fptr->tied_io_for_writing = out; # else fptr->f2 = ofptr->f; ofptr->f = 0; # endif - fptr->mode |= FMODE_WRITABLE; #endif rb_const_set(klass, id_console, con); } diff --git a/test/io/console/test_io_console.rb b/test/io/console/test_io_console.rb index 030dcd38ed..5475a93fa3 100644 --- a/test/io/console/test_io_console.rb +++ b/test/io/console/test_io_console.rb @@ -160,3 +160,13 @@ class TestIO_Console < Test::Unit::TestCase s.close if s end end if defined?(PTY) and defined?(IO::console) + +class TestIO_Console < Test::Unit::TestCase + require_relative '../../ruby/envutil' + + def test_noctty + assert_in_out_err(["-rio/console"], + "Process.daemon(true, true); p IO.console", + ["nil"]) + end +end if defined?(Process.daemon) and defined?(IO::console) |