mirror of
https://github.com/ruby/ruby.git
synced 2025-09-19 18:43:59 +02:00
* include/ruby/intern.h (rb_fd_set_cloexec): declared.
* io.c (rb_fd_set_cloexec): new function. (ruby_dup): call rb_fd_set_cloexec to set close-on-exec flag. (rb_sysopen_internal): ditto. (rb_pipe): ditto. (io_reopen): ditto. (io_cntl): ditto. * process.c (rb_f_exec): change the default :close_others option to true. (rb_f_system): ditto. (move_fds_to_avoid_crash): call rb_fd_set_cloexec to set close-on-exec flag. (ruby_setsid): ditto. (rb_daemon): ditto. * thread_pthread.c (rb_thread_create_timer_thread): call rb_fd_set_cloexec to set close-on-exec flag. * ruby.c (load_file_internal): ditto. * file.c (rb_file_s_truncate): ditto. (file_load_ok): ditto. * random.c (fill_random_seed): ditto. * ext/pty/pty.c (chfunc): ditto. (get_device_once): ditto. * ext/openssl/ossl_bio.c (ossl_obj2bio): ditto. * ext/socket/init.c (rsock_socket): ditto. (rsock_s_accept_nonblock): ditto. (rsock_s_accept): ditto. * ext/socket/socket.c (rsock_sock_s_socketpair): ditto. * ext/socket/ancdata.c (discard_cmsg): ditto. (make_io_for_unix_rights): ditto. * ext/socket/unixsocket.c (unix_recv_io): ditto. * ext/io/console/console.c (console_dev): ditto. [ruby-core:38140] [Feature #5041] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@33507 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
00715f4c5a
commit
b574a4d4a1
18 changed files with 133 additions and 46 deletions
|
@ -603,7 +603,7 @@ class TestProcess < Test::Unit::TestCase
|
|||
def test_fd_inheritance
|
||||
skip "inheritance of fd other than stdin,stdout and stderr is not supported" if windows?
|
||||
with_pipe {|r, w|
|
||||
system(RUBY, '-e', 'IO.new(ARGV[0].to_i, "w").puts(:ba)', w.fileno.to_s)
|
||||
system(RUBY, '-e', 'IO.new(ARGV[0].to_i, "w").puts(:ba)', w.fileno.to_s, w=>w)
|
||||
w.close
|
||||
assert_equal("ba\n", r.read)
|
||||
}
|
||||
|
@ -619,8 +619,9 @@ class TestProcess < Test::Unit::TestCase
|
|||
write_file("s", <<-"End")
|
||||
exec(#{RUBY.dump}, '-e',
|
||||
'IO.new(ARGV[0].to_i, "w").puts("bu") rescue nil',
|
||||
#{w.fileno.to_s.dump})
|
||||
#{w.fileno.to_s.dump}, :close_others=>false)
|
||||
End
|
||||
w.close_on_exec = false
|
||||
Process.wait spawn(RUBY, "s", :close_others=>false)
|
||||
w.close
|
||||
assert_equal("bu\n", r.read)
|
||||
|
@ -660,6 +661,7 @@ class TestProcess < Test::Unit::TestCase
|
|||
File.unlink("err")
|
||||
}
|
||||
with_pipe {|r, w|
|
||||
w.close_on_exec = false
|
||||
Process.wait spawn(RUBY, '-e', 'IO.new(ARGV[0].to_i, "w").puts("bi")', w.fileno.to_s, :close_others=>false)
|
||||
w.close
|
||||
assert_equal("bi\n", r.read)
|
||||
|
@ -686,6 +688,7 @@ class TestProcess < Test::Unit::TestCase
|
|||
Process.wait
|
||||
}
|
||||
with_pipe {|r, w|
|
||||
w.close_on_exec = false
|
||||
io = IO.popen([RUBY, "-e", "STDERR.reopen(STDOUT); IO.new(#{w.fileno}, 'w').puts('mo')", :close_others=>false])
|
||||
w.close
|
||||
errmsg = io.read
|
||||
|
@ -694,6 +697,7 @@ class TestProcess < Test::Unit::TestCase
|
|||
Process.wait
|
||||
}
|
||||
with_pipe {|r, w|
|
||||
w.close_on_exec = false
|
||||
io = IO.popen([RUBY, "-e", "STDERR.reopen(STDOUT); IO.new(#{w.fileno}, 'w').puts('mo')", :close_others=>nil])
|
||||
w.close
|
||||
errmsg = io.read
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue