summaryrefslogtreecommitdiffstats
path: root/range.c
diff options
context:
space:
mode:
authormarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-09-15 21:30:50 +0000
committermarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-09-15 21:30:50 +0000
commit128c696c505bfd4ecf0a01bae546bfc720787fc2 (patch)
tree8efee8e6cc94d15eb0206a5837830290e4cfee22 /range.c
parent03c6b39e8ea9a13663c485129a053fadd0cc148d (diff)
downloadruby-128c696c505bfd4ecf0a01bae546bfc720787fc2.tar.gz
ruby-128c696c505bfd4ecf0a01bae546bfc720787fc2.tar.xz
ruby-128c696c505bfd4ecf0a01bae546bfc720787fc2.zip
* 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: http://svn.ruby-lang.org/repos/ruby/trunk@24943 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'range.c')
-rw-r--r--range.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/range.c b/range.c
index 739831536..a394f00b6 100644
--- a/range.c
+++ b/range.c
@@ -207,14 +207,13 @@ recursive_hash(VALUE range, VALUE dummy, int recur)
st_index_t hash = EXCL(range);
VALUE v;
- if (recur) {
- rb_raise(rb_eArgError, "recursive key for hash");
- }
hash = rb_hash_start(hash);
- v = rb_hash(RANGE_BEG(range));
- hash = rb_hash_uint(hash, NUM2LONG(v));
- v = rb_hash(RANGE_END(range));
- hash = rb_hash_uint(hash, NUM2LONG(v));
+ if (!recur) {
+ v = rb_hash(RANGE_BEG(range));
+ hash = rb_hash_uint(hash, NUM2LONG(v));
+ v = rb_hash(RANGE_END(range));
+ hash = rb_hash_uint(hash, NUM2LONG(v));
+ }
hash = rb_hash_uint(hash, EXCL(range) << 24);
hash = rb_hash_end(hash);
@@ -233,7 +232,7 @@ recursive_hash(VALUE range, VALUE dummy, int recur)
static VALUE
range_hash(VALUE range)
{
- return rb_exec_recursive(recursive_hash, range, 0);
+ return rb_exec_recursive_outer(recursive_hash, range, 0);
}
static void