summaryrefslogtreecommitdiff
path: root/array.c
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-15 13:21:37 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-15 13:21:37 +0000
commit6c4895c78afa358f56099ed98679f106b82dff51 (patch)
tree898a7843106e947097861b8fe1cef5058c801d49 /array.c
parent5c9dd204f5c2b5501c8df10f7ab1da7f7f71992c (diff)
* array.c (RESIZE_CAPA): check whether len is longer than capacity.
* array.c (rb_ary_compact_bang): resize ary before changing capacity. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19793 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'array.c')
-rw-r--r--array.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/array.c b/array.c
index 4aa6dbef07..da513f96aa 100644
--- a/array.c
+++ b/array.c
@@ -125,6 +125,7 @@ memfill(register VALUE *mem, register long size, register VALUE val)
static void
RESIZE_CAPA(VALUE ary, long capacity)
{
+ assert(RARRAY_LEN(ary) <= capacity);
assert(!OBJ_FROZEN(ary));
assert(!ARY_SHARED_P(ary));
if (capacity > RARRAY_EMBED_LEN_MAX) {
@@ -2927,10 +2928,10 @@ rb_ary_compact_bang(VALUE ary)
if (RARRAY_LEN(ary) == n) {
return Qnil;
}
+ ARY_SET_LEN(ary, n);
if (n * 2 < ARY_CAPA(ary) && ARY_DEFAULT_SIZE * 2 < ARY_CAPA(ary)) {
RESIZE_CAPA(ary, n * 2);
}
- ARY_SET_LEN(ary, n);
return ary;
}