summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--io.c10
-rw-r--r--version.h4
3 files changed, 13 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index 3edcb6b8bf..0148cb2bf4 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Wed Jan 14 12:35:20 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * io.c (rb_io_s_pipe): reduced nest of rb_ensure of main block.
+
Tue Jan 13 22:56:57 2009 Tanaka Akira <akr@fsij.org>
* ext/socket/addrinfo.h (AI_NUMERICSERV): defined.
diff --git a/io.c b/io.c
index 1a445df2ef..733d978c05 100644
--- a/io.c
+++ b/io.c
@@ -7028,9 +7028,10 @@ io_encoding_set(rb_io_t *fptr, VALUE v1, VALUE v2, VALUE opt)
}
static VALUE
-pipe_yield(VALUE rw)
+pipe_pair_close(VALUE rw)
{
- return rb_ensure(rb_yield, rw, io_close, rb_ary_entry(rw, 1));
+ VALUE *rwp = (VALUE *)rw;
+ return rb_ensure(io_close, rwp[0], io_close, rwp[1]);
}
/*
@@ -7135,7 +7136,10 @@ rb_io_s_pipe(int argc, VALUE *argv, VALUE klass)
ret = rb_assoc_new(r, w);
if (rb_block_given_p()) {
- return rb_ensure(pipe_yield, ret, io_close, r);
+ VALUE rw[2];
+ rw[0] = r;
+ rw[1] = w;
+ return rb_ensure(rb_yield, ret, pipe_pair_close, (VALUE)rw);
}
return ret;
}
diff --git a/version.h b/version.h
index d5d69f4aab..0b176b9709 100644
--- a/version.h
+++ b/version.h
@@ -1,5 +1,5 @@
#define RUBY_VERSION "1.9.1"
-#define RUBY_RELEASE_DATE "2009-01-13"
+#define RUBY_RELEASE_DATE "2009-01-14"
#define RUBY_PATCHLEVEL 5000
#define RUBY_BRANCH_NAME "trunk"
@@ -8,7 +8,7 @@
#define RUBY_VERSION_TEENY 1
#define RUBY_RELEASE_YEAR 2009
#define RUBY_RELEASE_MONTH 1
-#define RUBY_RELEASE_DAY 13
+#define RUBY_RELEASE_DAY 14
#ifdef RUBY_EXTERN
RUBY_EXTERN const char ruby_version[];