range.c (range_last): disable optimization when each is redefined
Do not use the optimized version of Range#last when Range#each is redefined. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66749 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
8371a9a4ce
commit
2b9c6e1a8a
3
range.c
3
range.c
@ -1088,7 +1088,8 @@ range_last(int argc, VALUE *argv, VALUE range)
|
|||||||
|
|
||||||
b = RANGE_BEG(range);
|
b = RANGE_BEG(range);
|
||||||
e = RANGE_END(range);
|
e = RANGE_END(range);
|
||||||
if (RB_INTEGER_TYPE_P(b) && RB_INTEGER_TYPE_P(e)) {
|
if (RB_INTEGER_TYPE_P(b) && RB_INTEGER_TYPE_P(e) &&
|
||||||
|
RB_LIKELY(rb_method_basic_definition_p(rb_cRange, idEach))) {
|
||||||
return rb_int_range_last(argc, argv, range);
|
return rb_int_range_last(argc, argv, range);
|
||||||
}
|
}
|
||||||
return rb_ary_last(argc, argv, rb_Array(range));
|
return rb_ary_last(argc, argv, rb_Array(range));
|
||||||
|
@ -450,6 +450,18 @@ class TestRange < Test::Unit::TestCase
|
|||||||
assert_raise(ArgumentError) { (0..10).last(-1) }
|
assert_raise(ArgumentError) { (0..10).last(-1) }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_last_with_redefine_each
|
||||||
|
assert_in_out_err([], <<-'end;', ['true'], [])
|
||||||
|
class Range
|
||||||
|
remove_method :each
|
||||||
|
def each(&b)
|
||||||
|
[1, 2, 3, 4, 5].each(&b)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
puts [3, 4, 5] == (1..10).last(3)
|
||||||
|
end;
|
||||||
|
end
|
||||||
|
|
||||||
def test_to_s
|
def test_to_s
|
||||||
assert_equal("0..1", (0..1).to_s)
|
assert_equal("0..1", (0..1).to_s)
|
||||||
assert_equal("0...1", (0...1).to_s)
|
assert_equal("0...1", (0...1).to_s)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user