diff options
author | mame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-03-10 12:29:50 +0000 |
---|---|---|
committer | mame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-03-10 12:29:50 +0000 |
commit | fec209551a1751de79b7f0257ae8533e1bdf3c7e (patch) | |
tree | 378f66863a1a3ab6954eafd06919d04f65472833 /enum.c | |
parent | 9eb49ff8d7f8f7740e012f5f1080d2dd5113ce80 (diff) | |
download | ruby-fec209551a1751de79b7f0257ae8533e1bdf3c7e.tar.gz |
* enum.c (min_ii, max_ii, minmax_ii): remove wrong optimization that
reuses array for yield parameter, which caused unexpected behavior.
[ruby-core:25989]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26866 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'enum.c')
-rw-r--r-- | enum.c | 53 |
1 files changed, 16 insertions, 37 deletions
@@ -1058,10 +1058,7 @@ min_ii(VALUE i, VALUE *memo, int argc, VALUE *argv) *memo = i; } else { - VALUE ary = memo[1]; - RARRAY_PTR(ary)[0] = i; - RARRAY_PTR(ary)[1] = *memo; - cmp = rb_yield(ary); + cmp = rb_yield_values(2, i, *memo); if (rb_cmpint(cmp, i, *memo) < 0) { *memo = i; } @@ -1087,18 +1084,16 @@ min_ii(VALUE i, VALUE *memo, int argc, VALUE *argv) static VALUE enum_min(VALUE obj) { - VALUE result[2]; + VALUE result = Qundef; - result[0] = Qundef; if (rb_block_given_p()) { - result[1] = rb_ary_new3(2, Qnil, Qnil); - rb_block_call(obj, id_each, 0, 0, min_ii, (VALUE)result); + rb_block_call(obj, id_each, 0, 0, min_ii, (VALUE)&result); } else { - rb_block_call(obj, id_each, 0, 0, min_i, (VALUE)result); + rb_block_call(obj, id_each, 0, 0, min_i, (VALUE)&result); } - if (result[0] == Qundef) return Qnil; - return result[0]; + if (result == Qundef) return Qnil; + return result; } static VALUE @@ -1131,10 +1126,7 @@ max_ii(VALUE i, VALUE *memo, int argc, VALUE *argv) *memo = i; } else { - VALUE ary = memo[1]; - RARRAY_PTR(ary)[0] = i; - RARRAY_PTR(ary)[1] = *memo; - cmp = rb_yield(ary); + cmp = rb_yield_values(2, i, *memo); if (rb_cmpint(cmp, i, *memo) > 0) { *memo = i; } @@ -1159,24 +1151,21 @@ max_ii(VALUE i, VALUE *memo, int argc, VALUE *argv) static VALUE enum_max(VALUE obj) { - VALUE result[2]; + VALUE result = Qundef; - result[0] = Qundef; if (rb_block_given_p()) { - result[1] = rb_ary_new3(2, Qnil, Qnil); - rb_block_call(obj, id_each, 0, 0, max_ii, (VALUE)result); + rb_block_call(obj, id_each, 0, 0, max_ii, (VALUE)&result); } else { - rb_block_call(obj, id_each, 0, 0, max_i, (VALUE)result); + rb_block_call(obj, id_each, 0, 0, max_i, (VALUE)&result); } - if (result[0] == Qundef) return Qnil; - return result[0]; + if (result == Qundef) return Qnil; + return result; } struct minmax_t { VALUE min; VALUE max; - VALUE ary; VALUE last; }; @@ -1242,17 +1231,11 @@ minmax_ii_update(VALUE i, VALUE j, struct minmax_t *memo) memo->max = j; } else { - VALUE ary = memo->ary; - - rb_ary_store(ary, 0, i); - rb_ary_store(ary, 1, memo->min); - n = rb_cmpint(rb_yield(ary), i, memo->min); + n = rb_cmpint(rb_yield_values(2, i, memo->min), i, memo->min); if (n < 0) { memo->min = i; } - rb_ary_store(ary, 0, j); - rb_ary_store(ary, 1, memo->max); - n = rb_cmpint(rb_yield(ary), j, memo->max); + n = rb_cmpint(rb_yield_values(2, j, memo->max), j, memo->max); if (n > 0) { memo->max = j; } @@ -1264,7 +1247,7 @@ minmax_ii(VALUE i, VALUE _memo, int argc, VALUE *argv) { struct minmax_t *memo = (struct minmax_t *)_memo; int n; - VALUE ary, j; + VALUE j; ENUM_WANT_SVALUE(); @@ -1275,10 +1258,7 @@ minmax_ii(VALUE i, VALUE _memo, int argc, VALUE *argv) j = memo->last; memo->last = Qundef; - ary = memo->ary; - rb_ary_store(ary, 0, j); - rb_ary_store(ary, 1, i); - n = rb_cmpint(rb_yield(ary), j, i); + n = rb_cmpint(rb_yield_values(2, j, i), j, i); if (n == 0) i = j; else if (n < 0) { @@ -1317,7 +1297,6 @@ enum_minmax(VALUE obj) memo.min = Qundef; memo.last = Qundef; if (rb_block_given_p()) { - memo.ary = ary; rb_block_call(obj, id_each, 0, 0, minmax_ii, (VALUE)&memo); if (memo.last != Qundef) minmax_ii_update(memo.last, memo.last, &memo); |