summaryrefslogtreecommitdiffstats
path: root/marshal.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-01 09:57:38 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-01 09:57:38 +0000
commit5b41e7ceb6b6f1994974f24974773b9c899f3338 (patch)
tree4025807c0703522e3d0c3a86c6e78c82711bc32f /marshal.c
parent9b83ad7ae826cddeead375ba36400b3257d39d93 (diff)
downloadruby-5b41e7ceb6b6f1994974f24974773b9c899f3338.tar.gz
ruby-5b41e7ceb6b6f1994974f24974773b9c899f3338.tar.xz
ruby-5b41e7ceb6b6f1994974f24974773b9c899f3338.zip
* marshal.c (marshal_dump): initializes dump_arg before any funcall.
[ruby-dev:36648] git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@19652 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'marshal.c')
-rw-r--r--marshal.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/marshal.c b/marshal.c
index 352ab443e..557bb353e 100644
--- a/marshal.c
+++ b/marshal.c
@@ -865,29 +865,30 @@ marshal_dump(int argc, VALUE *argv)
else port = a1;
}
arg.dest = 0;
+ arg.symbols = st_init_numtable();
+ arg.data = st_init_numtable();
+ arg.taint = Qfalse;
+ arg.untrust = Qfalse;
+ arg.compat_tbl = st_init_numtable();
+ arg.encodings = 0;
+ arg.str = rb_str_buf_new(0);
+ RBASIC(arg.str)->klass = 0;
+ arg.wrapper = Data_Wrap_Struct(rb_cData, mark_dump_arg, 0, &arg);
if (!NIL_P(port)) {
if (!rb_respond_to(port, s_write)) {
type_error:
rb_raise(rb_eTypeError, "instance of IO needed");
}
- arg.str = rb_str_buf_new(0);
arg.dest = port;
if (rb_respond_to(port, s_binmode)) {
rb_funcall2(port, s_binmode, 0, 0);
+ check_dump_arg(&arg, s_dump_data);
}
}
else {
- port = rb_str_buf_new(0);
- arg.str = port;
+ port = arg.str;
}
- arg.symbols = st_init_numtable();
- arg.data = st_init_numtable();
- arg.taint = Qfalse;
- arg.untrust = Qfalse;
- arg.compat_tbl = st_init_numtable();
- arg.wrapper = Data_Wrap_Struct(rb_cData, mark_dump_arg, 0, &arg);
- arg.encodings = 0;
c_arg.obj = obj;
c_arg.arg = &arg;
c_arg.limit = limit;
@@ -896,6 +897,7 @@ marshal_dump(int argc, VALUE *argv)
w_byte(MARSHAL_MINOR, &arg);
rb_ensure(dump, (VALUE)&c_arg, dump_ensure, (VALUE)&arg);
+ RBASIC(arg.str)->klass = rb_cString;
return port;
}