mirror of
https://github.com/ruby/ruby.git
synced 2025-08-15 13:39:04 +02:00
* thread.c (rb_exec_recursive_outer, rb_exec_recursive): Added method to short-circuit to the outermost level in case of recursion
* test/ruby/test_thread.rb (test_recursive_outer): Test for above * hash.c (rb_hash_hash): Return a sensible hash for in case of recursion [ruby-core:24648] * range.c (rb_range_hash): ditto * struct.c (rb_struct_hash): ditto * array.c (rb_array_hash): ditto * test/ruby/test_array.rb (test_hash2): test for above git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24943 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
6a54d4b6fe
commit
1796522f10
9 changed files with 133 additions and 45 deletions
13
struct.c
13
struct.c
|
@ -810,13 +810,12 @@ recursive_hash(VALUE s, VALUE dummy, int recur)
|
|||
st_index_t h;
|
||||
VALUE n;
|
||||
|
||||
if (recur) {
|
||||
rb_raise(rb_eArgError, "recursive key for hash");
|
||||
}
|
||||
h = rb_hash_start(rb_hash(rb_obj_class(s)));
|
||||
for (i = 0; i < RSTRUCT_LEN(s); i++) {
|
||||
n = rb_hash(RSTRUCT_PTR(s)[i]);
|
||||
h = rb_hash_uint(h, NUM2LONG(n));
|
||||
if (!recur) {
|
||||
for (i = 0; i < RSTRUCT_LEN(s); i++) {
|
||||
n = rb_hash(RSTRUCT_PTR(s)[i]);
|
||||
h = rb_hash_uint(h, NUM2LONG(n));
|
||||
}
|
||||
}
|
||||
h = rb_hash_end(h);
|
||||
return INT2FIX(h);
|
||||
|
@ -832,7 +831,7 @@ recursive_hash(VALUE s, VALUE dummy, int recur)
|
|||
static VALUE
|
||||
rb_struct_hash(VALUE s)
|
||||
{
|
||||
return rb_exec_recursive(recursive_hash, s, 0);
|
||||
return rb_exec_recursive_outer(recursive_hash, s, 0);
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue