summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-06-23 18:10:59 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-06-23 18:10:59 +0000
commit1fb587ddec95d23675a2ff919d5f4f11339ae247 (patch)
tree5f58fdc72ebab97fc0bd854423b82fa1ec567b28
parent3f2fe372005b0bd1f6535ffaaf23ff8ea4f8271f (diff)
* enum.c (enum_minmax): fix SEGV by [].minmax.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12591 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--enum.c7
2 files changed, 9 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 4295152c5a..68b7860819 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Sun Jun 24 03:05:00 2007 Tanaka Akira <akr@fsij.org>
+
+ * enum.c (enum_minmax): fix SEGV by [].minmax.
+
Sat Jun 23 17:18:19 2007 Tanaka Akira <akr@fsij.org>
* re.c (match_inspect): MatchData#inspect implemented.
diff --git a/enum.c b/enum.c
index 97f020392d..1cde4145ff 100644
--- a/enum.c
+++ b/enum.c
@@ -1126,8 +1126,10 @@ enum_minmax(VALUE obj)
else {
rb_block_call(obj, id_each, 0, 0, minmax_i, (VALUE)result);
}
- RARRAY_PTR(ary)[0] = result[0];
- RARRAY_PTR(ary)[1] = result[1];
+ if (result[0] != Qundef) {
+ RARRAY_PTR(ary)[0] = result[0];
+ RARRAY_PTR(ary)[1] = result[1];
+ }
return ary;
}
@@ -1563,6 +1565,7 @@ Init_Enumerable(void)
rb_define_method(rb_mEnumerable,"max", enum_max, 0);
rb_define_method(rb_mEnumerable,"minmax", enum_minmax, 0);
rb_define_method(rb_mEnumerable,"min_by", enum_min_by, 0);
+ rb_define_method(rb_mEnumerable,"max_by", enum_max_by, 0);
rb_define_method(rb_mEnumerable,"minmax_by", enum_minmax_by, 0);
rb_define_method(rb_mEnumerable,"member?", enum_member, 1);
rb_define_method(rb_mEnumerable,"include?", enum_member, 1);