Skip to content

Commit

Permalink
* array.c (rb_ary_zip): performance improvement by avoiding
Browse files Browse the repository at this point in the history
  array creation if rb_block_arity() > 1.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42336 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
glass committed Aug 2, 2013
1 parent 54c3b1b commit 5339293
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 13 deletions.
5 changes: 5 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
Fri Aug 2 23:54:11 2013 Masaki Matsushita <glass.saga@gmail.com>

* array.c (rb_ary_zip): performance improvement by avoiding
array creation if rb_block_arity() > 1.

Fri Aug 2 23:50:53 2013 Tanaka Akira <akr@fsij.org>

* bignum.c (power_cache_get_power): Appry bigtrunc to the result of
Expand Down
42 changes: 29 additions & 13 deletions array.c
Original file line number Diff line number Diff line change
Expand Up @@ -3146,32 +3146,48 @@ take_items(VALUE obj, long n)
static VALUE
rb_ary_zip(int argc, VALUE *argv, VALUE ary)
{
int i, j;
int i, j, block_given, arity = 0;
long len;
VALUE result = Qnil;

len = RARRAY_LEN(ary);
for (i=0; i<argc; i++) {
argv[i] = take_items(argv[i], len);
}
if (!rb_block_given_p()) {

block_given = rb_block_given_p();
if (block_given)
arity = rb_block_arity();
else
result = rb_ary_new2(len);
}

for (i=0; i<RARRAY_LEN(ary); i++) {
VALUE tmp = rb_ary_new2(argc+1);
if (block_given && arity > 1) {
int yield_argc = argc + 1;
VALUE *yield_argv = ALLOC_N(VALUE, yield_argc);

rb_ary_push(tmp, rb_ary_elt(ary, i));
for (j=0; j<argc; j++) {
rb_ary_push(tmp, rb_ary_elt(argv[j], i));
}
if (NIL_P(result)) {
rb_yield(tmp);
for (i=0; i<RARRAY_LEN(ary); i++) {
yield_argv[0] = RARRAY_AREF(ary, i);
for (j=0; j<argc; j++) {
yield_argv[j+1] = rb_ary_elt(argv[j], i);
}
rb_yield_values2(yield_argc, yield_argv);
}
else {
rb_ary_push(result, tmp);
}
else {
for (i=0; i<RARRAY_LEN(ary); i++) {
VALUE tmp = rb_ary_new2(argc+1);

rb_ary_push(tmp, RARRAY_AREF(ary, i));
for (j=0; j<argc; j++) {
rb_ary_push(tmp, rb_ary_elt(argv[j], i));
}
if (block_given)
rb_yield(tmp);
else
rb_ary_push(result, tmp);
}
}

return result;
}

Expand Down

0 comments on commit 5339293

Please sign in to comment.