From c2a9b62fd2f5c107fcff2e21052e4e9e2294e8ce Mon Sep 17 00:00:00 2001 From: matz Date: Sat, 30 Oct 2004 15:33:03 +0000 Subject: * string.c (rb_str_locktmp): lock string temporarily. * string.c (str_independent): add tmplock check. * io.c (io_write): lock output string temporarily. [ruby-dev:24649] * io.c (io_write): use rb_str_locktmp(). * io.c (read_all): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@7149 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- enum.c | 3 +++ 1 file changed, 3 insertions(+) (limited to 'enum.c') diff --git a/enum.c b/enum.c index 2f931c7d8b..a745a6e604 100644 --- a/enum.c +++ b/enum.c @@ -494,6 +494,9 @@ enum_sort_by(obj) if (RARRAY(ary)->len > 1) { qsort(RARRAY(ary)->ptr, RARRAY(ary)->len, sizeof(VALUE), sort_by_cmp, 0); } + if (RBASIC(ary)->klass) { + rb_raise(rb_eRuntimeError, "sort_by reentered"); + } for (i=0; ilen; i++) { RARRAY(ary)->ptr[i] = RNODE(RARRAY(ary)->ptr[i])->u2.value; } -- cgit v1.2.3