зеркало из https://github.com/github/ruby.git
process.c: try conversion at redirection
* io.c (rb_io_check_io): make public. * process.c (check_exec_redirect): try conversion to IO on redirect parameters. [ruby-core:44181] [Bug #6269] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@36551 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
a8aa1e2127
Коммит
c05e6a8cda
|
@ -1,3 +1,10 @@
|
|||
Fri Jul 27 18:25:51 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* io.c (rb_io_check_io): make public.
|
||||
|
||||
* process.c (check_exec_redirect): try conversion to IO on redirect
|
||||
parameters. [ruby-core:44181] [Bug #6269]
|
||||
|
||||
Fri Jul 27 17:58:12 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* configure.in (RUBY_CPPOUTFILE): get rid of variable conflict so
|
||||
|
|
|
@ -168,6 +168,7 @@ void rb_io_synchronized(rb_io_t*);
|
|||
void rb_io_check_initialized(rb_io_t*);
|
||||
void rb_io_check_closed(rb_io_t*);
|
||||
VALUE rb_io_get_io(VALUE io);
|
||||
VALUE rb_io_check_io(VALUE io);
|
||||
VALUE rb_io_get_write_io(VALUE io);
|
||||
VALUE rb_io_set_write_io(VALUE io, VALUE w);
|
||||
int rb_io_wait_readable(int);
|
||||
|
|
2
io.c
2
io.c
|
@ -590,7 +590,7 @@ rb_io_get_io(VALUE io)
|
|||
return rb_convert_type(io, T_FILE, "IO", "to_io");
|
||||
}
|
||||
|
||||
static VALUE
|
||||
VALUE
|
||||
rb_io_check_io(VALUE io)
|
||||
{
|
||||
return rb_check_convert_type(io, T_FILE, "IO", "to_io");
|
||||
|
|
|
@ -1456,6 +1456,7 @@ check_exec_redirect(VALUE key, VALUE val, struct rb_execarg *eargp)
|
|||
{
|
||||
VALUE param;
|
||||
VALUE path, flags, perm;
|
||||
VALUE tmp;
|
||||
ID id;
|
||||
|
||||
switch (TYPE(val)) {
|
||||
|
@ -1484,6 +1485,7 @@ check_exec_redirect(VALUE key, VALUE val, struct rb_execarg *eargp)
|
|||
break;
|
||||
|
||||
case T_FILE:
|
||||
io:
|
||||
val = check_exec_redirect_fd(val, 0);
|
||||
/* fall through */
|
||||
case T_FIXNUM:
|
||||
|
@ -1531,6 +1533,9 @@ check_exec_redirect(VALUE key, VALUE val, struct rb_execarg *eargp)
|
|||
break;
|
||||
|
||||
default:
|
||||
tmp = val;
|
||||
val = rb_io_check_io(tmp);
|
||||
if (!NIL_P(val)) goto io;
|
||||
rb_raise(rb_eArgError, "wrong exec redirect action");
|
||||
}
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
require 'test/unit'
|
||||
require 'tmpdir'
|
||||
require 'tempfile'
|
||||
require 'pathname'
|
||||
require 'timeout'
|
||||
require_relative 'envutil'
|
||||
|
@ -806,6 +806,18 @@ class TestProcess < Test::Unit::TestCase
|
|||
end
|
||||
end
|
||||
|
||||
def test_execopts_redirect_tempfile
|
||||
bug6269 = '[ruby-core:44181]'
|
||||
Tempfile.open("execopts") do |tmp|
|
||||
pid = assert_nothing_raised(ArgumentError, bug6269) do
|
||||
break spawn(RUBY, "-e", "print $$", out: tmp)
|
||||
end
|
||||
Process.wait(pid)
|
||||
tmp.rewind
|
||||
assert_equal(pid.to_s, tmp.read)
|
||||
end
|
||||
end
|
||||
|
||||
def test_execopts_duplex_io
|
||||
IO.popen("#{RUBY} -e ''", "r+") {|duplex|
|
||||
assert_raise(ArgumentError) { system("#{RUBY} -e ''", duplex=>STDOUT) }
|
||||
|
|
Загрузка…
Ссылка в новой задаче