summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-07-19 03:33:33 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-07-19 03:33:33 +0000
commit87d8a3b9ce775529f8fee6d39061cd958092bf1e (patch)
tree1c9221ac39acbfd4ac7aa2744f18c480314e17ec
parent4d5eee3602b8e6ed342d184b07c416f3c685da90 (diff)
* array.c (rb_ary_clear): should not unshare embedded array, and
should make unshared array embedded. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@28680 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--array.c5
2 files changed, 9 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index a4e7b7dc29..e8c0fc5fbb 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Mon Jul 19 12:33:29 2010 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * array.c (rb_ary_clear): should not unshare embedded array, and
+ should make unshared array embedded.
+
Mon Jul 19 09:00:58 2010 Nobuyoshi Nakada <nobu@ruby-lang.org>
* NEWS (Kernel#instance_eval): add an incompatible change since
diff --git a/array.c b/array.c
index 4cb0cb7731..c2a4e8563e 100644
--- a/array.c
+++ b/array.c
@@ -2775,7 +2775,10 @@ rb_ary_clear(VALUE ary)
rb_ary_modify_check(ary);
ARY_SET_LEN(ary, 0);
if (ARY_SHARED_P(ary)) {
- rb_ary_unshare(ary);
+ if (!ARY_EMBED_P(ary)) {
+ rb_ary_unshare(ary);
+ FL_SET_EMBED(ary);
+ }
}
else if (ARY_DEFAULT_SIZE * 2 < ARY_CAPA(ary)) {
ary_resize_capa(ary, ARY_DEFAULT_SIZE * 2);