diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2001-11-01 04:51:22 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2001-11-01 04:51:22 +0000 |
commit | a313c30d9c05d125b035a546bd3aa835bb7b88be (patch) | |
tree | da962495aa536dd18a163c71813259a2d2103d28 /gc.c | |
parent | a8c4400d1a6c96710fb0253b96113f9a9bdf86b7 (diff) |
* gc.c (gc_mark_children): should NOT treat last element of
structs and arrays specially.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@1809 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 12 |
1 files changed, 2 insertions, 10 deletions
@@ -630,17 +630,13 @@ gc_mark_children(ptr) case T_ARRAY: { - int i, len = obj->as.array.len - 1; + int i, len = obj->as.array.len; VALUE *ptr = obj->as.array.ptr; for (i=0; i < len; i++) { PUSH_MARK(*ptr); ptr++; } - if (len >= 0) { - obj = RANY(*ptr); - goto Again; - } } break; @@ -698,17 +694,13 @@ gc_mark_children(ptr) case T_STRUCT: { - int i, len = obj->as.rstruct.len - 1; + int i, len = obj->as.rstruct.len; VALUE *ptr = obj->as.rstruct.ptr; for (i=0; i < len; i++) { PUSH_MARK(*ptr); ptr++; } - if (len >= 0) { - obj = RANY(ptr); - goto Again; - } } break; |