From 7c3b57b5d15e3a9a1a82523478f1b4f7035d405d Mon Sep 17 00:00:00 2001 From: tadf Date: Tue, 16 Sep 2008 10:21:23 +0000 Subject: * complex.c (nucomp_marshal_{dump,load}): preserve instance variables. * rational.c (nurat_marshal_{dump,load}): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19382 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- rational.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'rational.c') diff --git a/rational.c b/rational.c index 5669a7beb6..a592ae31e9 100644 --- a/rational.c +++ b/rational.c @@ -1125,8 +1125,12 @@ nurat_inspect(VALUE self) static VALUE nurat_marshal_dump(VALUE self) { + VALUE a; get_dat1(self); - return rb_assoc_new(dat->num, dat->den); + + a = rb_assoc_new(dat->num, dat->den); + rb_copy_generic_ivar(a, self); + return a; } static VALUE @@ -1135,6 +1139,7 @@ nurat_marshal_load(VALUE self, VALUE a) get_dat1(self); dat->num = RARRAY_PTR(a)[0]; dat->den = RARRAY_PTR(a)[1]; + rb_copy_generic_ivar(self, a); if (f_zero_p(dat->den)) rb_raise_zerodiv(); -- cgit v1.2.3