summaryrefslogtreecommitdiffstats
path: root/io.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2000-05-10 02:58:41 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2000-05-10 02:58:41 +0000
commit23d67024ca56858b2fd6bfb95156f2355bc0a2b5 (patch)
treef3907ca91e049d42dd7cc1f4bf9b63a8aef71514 /io.c
parentba5f283be0dfdf0f18178dfce2af4cd117e6652e (diff)
downloadruby-23d67024ca56858b2fd6bfb95156f2355bc0a2b5.tar.gz
ruby-23d67024ca56858b2fd6bfb95156f2355bc0a2b5.tar.xz
ruby-23d67024ca56858b2fd6bfb95156f2355bc0a2b5.zip
2000-05-10
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@684 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r--io.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/io.c b/io.c
index 5beae00bc..380e7d411 100644
--- a/io.c
+++ b/io.c
@@ -1557,9 +1557,9 @@ rb_io_s_popen(argc, argv, self)
VALUE self;
{
char *mode;
- VALUE pname, pmode, port;
+ VALUE pname, pmode, port, proc;
- if (rb_scan_args(argc, argv, "11", &pname, &pmode) == 1) {
+ if (rb_scan_args(argc, argv, "12", &pname, &pmode, &proc) == 1) {
mode = "r";
}
else {
@@ -1573,7 +1573,12 @@ rb_io_s_popen(argc, argv, self)
Check_SafeStr(pname);
port = pipe_open(RSTRING(pname)->ptr, mode);
if (NIL_P(port)) {
- rb_yield(port);
+ if (!NIL_P(proc)) {
+ rb_eval_cmd(proc, rb_ary_new2(0));
+ }
+ else {
+ rb_yield(port);
+ }
}
else if (rb_iterator_p()) {
return rb_ensure(rb_yield, port, rb_io_close, port);
@@ -2275,6 +2280,9 @@ rb_io_initialize(argc, argv, io)
fp->f = rb_fdopen(NUM2INT(fnum), m);
fp->mode = rb_io_mode_flags(m);
+ if (rb_iterator_p()) {
+ return rb_ensure(rb_yield, io, rb_io_close, io);
+ }
return io;
}