summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--range.c3
-rw-r--r--test/ruby/test_range.rb6
3 files changed, 13 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 54dc62c429..47f3321d18 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Fri Jul 13 11:33:09 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * range.c (range_max, range_min): return nil for empty set as well as
+ 1.8 and Enumerable. [ruby-dev:31198]
+
Fri Jul 13 11:28:37 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
* parse.y (bvar): semicolon was lost for ripper description.
diff --git a/range.c b/range.c
index a63919d0d9..15615a46bc 100644
--- a/range.c
+++ b/range.c
@@ -468,7 +468,7 @@ range_min(VALUE range)
VALUE e = rb_ivar_get(range, id_end);
int c = rb_cmpint(rb_funcall(b, id_cmp, 1, e), b, e);
- if (c > 0)
+ if (c > 0 || (c == 0 && EXCL(range)))
return Qnil;
return b;
}
@@ -502,6 +502,7 @@ range_max(VALUE range)
if (c > 0)
return Qnil;
if (EXCL(range)) {
+ if (c == 0) return Qnil;
if (FIXNUM_P(e)) {
return LONG2NUM(FIX2LONG(e) - 1);
}
diff --git a/test/ruby/test_range.rb b/test/ruby/test_range.rb
index 3c24215c6a..030aeb977b 100644
--- a/test/ruby/test_range.rb
+++ b/test/ruby/test_range.rb
@@ -40,6 +40,9 @@ class TestRange < Test::Unit::TestCase
assert_equal(1.0, (1.0..2.0).min)
assert_equal(nil, (2.0..1.0).min)
assert_equal(1, (1.0...2.0).min)
+
+ assert_equal(0, (0..0).min)
+ assert_equal(nil, (0...0).min)
end
def test_max
@@ -52,5 +55,8 @@ class TestRange < Test::Unit::TestCase
assert_raise(TypeError) { (1.0...2.0).max }
assert_equal(-0x80000002, ((-0x80000002)...(-0x80000001)).max)
+
+ assert_equal(0, (0..0).max)
+ assert_equal(nil, (0...0).max)
end
end