string.c: always fixed value
* string.c (rb_str_cmp_m): return fixed value, one of -1,0,+1 always. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38042 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
981f9c52c6
commit
1dbc720c0d
12
ChangeLog
12
ChangeLog
@ -1,3 +1,15 @@
|
||||
Fri Nov 30 17:43:39 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* string.c (rb_str_cmp_m): return fixed value, one of -1,0,+1 always.
|
||||
|
||||
* string.c (rb_str_cmp_m): try to compare with to_str result if
|
||||
possible before calling <=> method. [ruby-core:49279] [Bug #7342]
|
||||
|
||||
* string.c (rb_str_cmp_m): use rb_check_funcall instead of respond_to
|
||||
and call.
|
||||
|
||||
* string.c (rb_str_cmp_m): return fixed value, one of -1,0,+1 always.
|
||||
|
||||
Fri Nov 30 16:19:14 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* vm_dump.c (rb_vm_bugreport): get rid of calling methods in sigsegv
|
||||
|
9
string.c
9
string.c
@ -2382,7 +2382,7 @@ rb_str_eql(VALUE str1, VALUE str2)
|
||||
static VALUE
|
||||
rb_str_cmp_m(VALUE str1, VALUE str2)
|
||||
{
|
||||
long result;
|
||||
int result;
|
||||
|
||||
if (!RB_TYPE_P(str2, T_STRING)) {
|
||||
if (!rb_respond_to(str2, rb_intern("to_str"))) {
|
||||
@ -2395,16 +2395,13 @@ rb_str_cmp_m(VALUE str1, VALUE str2)
|
||||
VALUE tmp = rb_funcall(str2, rb_intern("<=>"), 1, str1);
|
||||
|
||||
if (NIL_P(tmp)) return Qnil;
|
||||
if (!FIXNUM_P(tmp)) {
|
||||
return rb_funcall(LONG2FIX(0), '-', 1, tmp);
|
||||
}
|
||||
result = -FIX2LONG(tmp);
|
||||
result = -rb_cmpint(tmp, str1, str2);
|
||||
}
|
||||
}
|
||||
else {
|
||||
result = rb_str_cmp(str1, str2);
|
||||
}
|
||||
return LONG2NUM(result);
|
||||
return INT2FIX(result);
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -181,7 +181,7 @@ class TestString < Test::Unit::TestCase
|
||||
|
||||
class << o;remove_method :<=>;end
|
||||
def o.<=>(x); 2**100; end
|
||||
assert_equal(-(2**100), "foo" <=> o)
|
||||
assert_equal(-1, "foo" <=> o)
|
||||
end
|
||||
|
||||
def test_EQUAL # '=='
|
||||
|
Loading…
x
Reference in New Issue
Block a user