summaryrefslogtreecommitdiff
path: root/range.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-15 15:21:51 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-15 15:21:51 +0000
commit9c0be2d5165286703e2627e80fdd216a63da9215 (patch)
tree76433e5fb5369f75be2e37befaec8559a9bd9f4a /range.c
parent41ca14e8ac90f64b05192020375dee852d0667eb (diff)
* range.c (rb_range_beg_len): check if responds to "begin" and "end"
methods for non-Range object. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15490 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'range.c')
-rw-r--r--range.c12
1 files changed, 4 insertions, 8 deletions
diff --git a/range.c b/range.c
index b72a4531fc..e3dd44290a 100644
--- a/range.c
+++ b/range.c
@@ -597,12 +597,10 @@ rb_range_beg_len(VALUE range, long *begp, long *lenp, long len, int err)
excl = EXCL(range);
}
else {
- b = rb_check_to_integer(range, "begin");
- if (NIL_P(b))
- return Qfalse;
- e = rb_check_to_integer(range, "end");
- if (NIL_P(e))
- return Qfalse;
+ if (!rb_respond_to(range, id_beg)) return Qfalse;
+ if (!rb_respond_to(range, id_end)) return Qfalse;
+ b = rb_funcall(range, id_beg, 0);
+ e = rb_funcall(range, id_end, 0);
excl = RTEST(rb_funcall(range, rb_intern("exclude_end?"), 0));
}
beg = NUM2LONG(b);
@@ -751,8 +749,6 @@ range_include(VALUE range, VALUE val)
}
else if (TYPE(beg) == T_STRING && TYPE(end) == T_STRING &&
RSTRING_LEN(beg) == 1 && RSTRING_LEN(end) == 1) {
- rb_encoding *enc = rb_enc_check(beg, end);
-
if (NIL_P(val)) return Qfalse;
if (TYPE(val) == T_STRING) {
if (RSTRING_LEN(val) == 0 || RSTRING_LEN(val) > 1)