summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--struct.c25
2 files changed, 23 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog
index c877140053..42ee98d735 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Fri Jul 17 18:11:32 2009 Tanaka Akira <akr@fsij.org>
+
+ * struct.c (recursive_hash): extracted from rb_struct_hash. reject
+ recursive key.
+ (rb_struct_hash): use recursive_hash.
+
Fri Jul 17 16:45:22 2009 Tanaka Akira <akr@fsij.org>
* array.c (recursive_hash): reject recursive key.
diff --git a/struct.c b/struct.c
index a93ed65f7d..e4b6da0e76 100644
--- a/struct.c
+++ b/struct.c
@@ -802,20 +802,16 @@ rb_struct_equal(VALUE s, VALUE s2)
return Qtrue;
}
-/*
- * call-seq:
- * struct.hash => fixnum
- *
- * Return a hash value based on this struct's contents.
- */
-
static VALUE
-rb_struct_hash(VALUE s)
+recursive_hash(VALUE s, VALUE dummy, int recur)
{
long i;
unsigned long 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]);
@@ -826,6 +822,19 @@ rb_struct_hash(VALUE s)
}
/*
+ * call-seq:
+ * struct.hash => fixnum
+ *
+ * Return a hash value based on this struct's contents.
+ */
+
+static VALUE
+rb_struct_hash(VALUE s)
+{
+ return rb_exec_recursive(recursive_hash, s, 0);
+}
+
+/*
* code-seq:
* struct.eql?(other) => true or false
*