mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* enum.c (sort_by_cmp): check if reentered. [ruby-dev:24291]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@12784 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
7b8c142696
commit
d9ef35c83f
2 changed files with 12 additions and 2 deletions
|
|
@ -1,3 +1,7 @@
|
|||
Sat Jul 14 14:04:06 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* enum.c (sort_by_cmp): check if reentered. [ruby-dev:24291]
|
||||
|
||||
Sat Jul 14 12:44:14 2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>
|
||||
|
||||
* test/openssl/test_pkcs7.rb: reverted the previous patch. it should
|
||||
|
|
|
|||
10
enum.c
10
enum.c
|
|
@ -391,12 +391,17 @@ sort_by_i(i, ary)
|
|||
}
|
||||
|
||||
static int
|
||||
sort_by_cmp(aa, bb)
|
||||
sort_by_cmp(aa, bb, data)
|
||||
NODE **aa, **bb;
|
||||
void *data;
|
||||
{
|
||||
VALUE a = aa[0]->u1.value;
|
||||
VALUE b = bb[0]->u1.value;
|
||||
VALUE ary = (VALUE)data;
|
||||
|
||||
if (RBASIC(ary)->klass) {
|
||||
rb_raise(rb_eRuntimeError, "sort_by reentered");
|
||||
}
|
||||
return rb_cmpint(rb_funcall(a, id_cmp, 1, b), a, b);
|
||||
}
|
||||
|
||||
|
|
@ -485,7 +490,8 @@ enum_sort_by(obj)
|
|||
RBASIC(ary)->klass = 0;
|
||||
rb_iterate(rb_each, obj, sort_by_i, ary);
|
||||
if (RARRAY(ary)->len > 1) {
|
||||
qsort(RARRAY(ary)->ptr, RARRAY(ary)->len, sizeof(VALUE), sort_by_cmp, 0);
|
||||
qsort(RARRAY(ary)->ptr, RARRAY(ary)->len, sizeof(VALUE),
|
||||
sort_by_cmp, (void *)ary);
|
||||
}
|
||||
if (RBASIC(ary)->klass) {
|
||||
rb_raise(rb_eRuntimeError, "sort_by reentered");
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue