From 77887cf01c1ddfcfc471462fb87b805b2d5c4498 Mon Sep 17 00:00:00 2001 From: ko1 Date: Fri, 19 Jul 2013 06:34:18 +0000 Subject: * array.c (rb_ary_store): use RARRAY_PTR_USE() intead of RARRAY_PTR(). Clearing memory space doesn't need WBs. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42064 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ array.c | 4 +++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index dde8448c5d..3deb996f41 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Fri Jul 19 15:32:57 2013 Koichi Sasada + + * array.c (rb_ary_store): use RARRAY_PTR_USE() intead of RARRAY_PTR(). + Clearing memory space doesn't need WBs. + Fri Jul 19 15:19:37 2013 Koichi Sasada * array.c (ary_ensure_room_for_push): use RARRAY_RAWPTR() instead of diff --git a/array.c b/array.c index 46f37944a0..f3f1b2e960 100644 --- a/array.c +++ b/array.c @@ -797,8 +797,10 @@ rb_ary_store(VALUE ary, long idx, VALUE val) ary_double_capa(ary, idx); } if (idx > RARRAY_LEN(ary)) { - rb_mem_clear(RARRAY_PTR(ary) + RARRAY_LEN(ary), + RARRAY_PTR_USE(ary, ptr, { + rb_mem_clear(ptr + RARRAY_LEN(ary), idx-RARRAY_LEN(ary) + 1); + }); } if (idx >= RARRAY_LEN(ary)) { -- cgit v1.2.3