summaryrefslogtreecommitdiff
path: root/range.c
diff options
context:
space:
mode:
Diffstat (limited to 'range.c')
-rw-r--r--range.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/range.c b/range.c
index b18a25ea35..946da0c4de 100644
--- a/range.c
+++ b/range.c
@@ -2151,6 +2151,34 @@ range_count(int argc, VALUE *argv, VALUE range)
}
}
+/*
+ * call-seq:
+ * overlap?(range) -> true or false
+ *
+ * Returns +true+ if +range+ overlaps with +self+, +false+ otherwise:
+ *
+ * (0..2).overlap?(1..3) #=> true
+ * (0..2).overlap?(3..4) #=> false
+ * (0..).overlap?(..0) #=> true
+ *
+ * Related: Range#cover?.
+ */
+
+static VALUE
+range_overlap(VALUE range, VALUE other)
+{
+ if (!rb_obj_is_kind_of(other, rb_cRange)) {
+ rb_raise(rb_eTypeError, "argument must be Range");
+ }
+
+ VALUE beg_self, beg_other;
+
+ beg_self = RANGE_BEG(range);
+ beg_other = RANGE_BEG(other);
+
+ return RBOOL(rb_equal(beg_self, beg_other) || range_cover(range, beg_other) || range_cover(other, beg_self));
+}
+
/* A \Range object represents a collection of values
* that are between given begin and end values.
*
@@ -2417,4 +2445,5 @@ Init_Range(void)
rb_define_method(rb_cRange, "include?", range_include, 1);
rb_define_method(rb_cRange, "cover?", range_cover, 1);
rb_define_method(rb_cRange, "count", range_count, -1);
+ rb_define_method(rb_cRange, "overlap?", range_overlap, 1);
}