summaryrefslogtreecommitdiff
path: root/marshal.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-03-02 01:53:11 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-03-02 01:53:11 +0000
commit6e7e726b8f36a60d10f7100e1714cf0b64004687 (patch)
treec2a121ac42a3c3cb86e9b7e7267647422a6e6bbb /marshal.c
parent0dea8a71c9d802625e49c4b708bf710e6a984ee9 (diff)
* marshal.c (mark_dump_arg): mark destination string. patch by
Vit Ondruch. [Bug #4339] * marshal.c (clear_dump_arg, clear_load_arg): clean up also data tables as same as symbols tables. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@34866 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'marshal.c')
-rw-r--r--marshal.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/marshal.c b/marshal.c
index 005e88b50a..143f11f408 100644
--- a/marshal.c
+++ b/marshal.c
@@ -118,6 +118,7 @@ mark_dump_arg(ptr)
if (!p->symbols)
return;
rb_mark_set(p->data);
+ rb_gc_mark(p->str);
}
static void
@@ -716,6 +717,7 @@ clear_dump_arg(arg)
st_free_table(arg->symbols);
arg->symbols = 0;
st_free_table(arg->data);
+ arg->data = 0;
if (arg->taint) {
OBJ_TAINT(arg->str);
}
@@ -1428,6 +1430,7 @@ clear_load_arg(arg)
st_free_table(arg->symbols);
arg->symbols = 0;
st_free_table(arg->data);
+ arg->data = 0;
}
/*