diff options
author | Nobuyoshi Nakada <[email protected]> | 2024-03-04 21:02:08 +0900 |
---|---|---|
committer | Nobuyoshi Nakada <[email protected]> | 2024-03-04 21:02:08 +0900 |
commit | b176315827d1082f43628013a7d89fda02724d33 () | |
tree | 6c953c38ede5cb26e6b5a624ec9e2022ccf3d1e4 | |
parent | ef5af32799b04da61bbd1bdaf464012a755c4936 (diff) |
[Bug #20324] Uncomparable ranges are not overlapping
-rw-r--r-- | range.c | 12 | ||||
-rw-r--r-- | test/ruby/test_range.rb | 2 |
2 files changed, 12 insertions, 2 deletions
@@ -2373,8 +2373,16 @@ range_overlap(VALUE range, VALUE other) if (empty_region_p(self_beg, other_end, other_excl)) return Qfalse; if (empty_region_p(other_beg, self_end, self_excl)) return Qfalse; - /* if both begin values are equal, no more comparisons needed */ - if (rb_equal(self_beg, other_beg)) return Qtrue; if (empty_region_p(self_beg, self_end, self_excl)) return Qfalse; if (empty_region_p(other_beg, other_end, other_excl)) return Qfalse; @@ -1265,6 +1265,8 @@ class TestRange < Test::Unit::TestCase assert_operator(0.., :overlap?, 1..) assert_not_operator((1..3), :overlap?, ('a'..'d')) assert_raise(TypeError) { (0..).overlap?(1) } assert_raise(TypeError) { (0..).overlap?(nil) } |