summaryrefslogtreecommitdiffhomepage
path: root/src/gc.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2012-06-24 06:11:28 -0700
committerYukihiro "Matz" Matsumoto <[email protected]>2012-06-24 06:11:28 -0700
commit97c9c859d166a952f1f8cdcc3187cd005c4bebcf (patch)
tree1113d4e8b9a6ab8bb454ae555814c90d03dafe35 /src/gc.c
parent8121e0d354b83b3fa9d1363470e280dc98112289 (diff)
parent7778b5ca1c82062e29eb41b22839a1d174dd82e1 (diff)
downloadmruby-97c9c859d166a952f1f8cdcc3187cd005c4bebcf.tar.gz
mruby-97c9c859d166a952f1f8cdcc3187cd005c4bebcf.zip
Merge pull request #313 from masamitsu-murase/fix_struct_new
Fix Struct#new and GC
Diffstat (limited to 'src/gc.c')
-rw-r--r--src/gc.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/src/gc.c b/src/gc.c
index 42c4e3fdb..bf45ffcd3 100644
--- a/src/gc.c
+++ b/src/gc.c
@@ -430,6 +430,18 @@ gc_mark_children(mrb_state *mrb, struct RBasic *obj)
break;
#endif
+#ifdef ENABLE_STRUCT
+ case MRB_TT_STRUCT:
+ {
+ struct RStruct *s = (struct RStruct*)obj;
+ long i;
+ for (i=0; i<s->len; i++){
+ mrb_gc_mark_value(mrb, s->ptr[i]);
+ }
+ }
+ break;
+#endif
+
default:
break;
}