From 1cd0ddea1bee76e77e207e0e65c2a782e0cf21f2 Mon Sep 17 00:00:00 2001 From: nobu Date: Thu, 16 Jul 2009 09:30:23 +0000 Subject: [PATCH] * hash.c (rb_hash_aset, recursive_hash): rejects recursive hash. [ruby-core:22921] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24149 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ hash.c | 5 ++++- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 02eaf07770..14b3887de2 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Thu Jul 16 18:30:20 2009 Nobuyoshi Nakada + + * hash.c (rb_hash_aset, recursive_hash): rejects recursive hash. + [ruby-core:22921] + Thu Jul 16 18:28:09 2009 Nobuyoshi Nakada * id.c (Init_id), vm.c (vm_exec): @#__ThrowState__ is no longer diff --git a/hash.c b/hash.c index c65d24263e..da47b55bea 100644 --- a/hash.c +++ b/hash.c @@ -1016,6 +1016,9 @@ VALUE rb_hash_aset(VALUE hash, VALUE key, VALUE val) { rb_hash_modify(hash); + if (hash == key) { + rb_raise(rb_eArgError, "recursive key for hash"); + } if (RHASH(hash)->ntbl->type == &identhash || rb_obj_class(key) != rb_cString) { st_insert(RHASH(hash)->ntbl, key, val); } @@ -1546,7 +1549,7 @@ recursive_hash(VALUE hash, VALUE dummy, int recur) VALUE hval; if (recur) { - return LONG2FIX(0); + rb_raise(rb_eArgError, "recursive key for hash"); } if (!RHASH(hash)->ntbl) return LONG2FIX(0);