summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-12-24 03:08:15 +0000
committermarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-12-24 03:08:15 +0000
commit30793b7ca6cccaaac5d87a0f4c4cc152db841ff9 (patch)
treed7b634b179b6a8e0303b8722bdac59ced525c573
parentf07fdd7661ffcee20816a20e152074d6f1a2594a (diff)
downloadruby-30793b7ca6cccaaac5d87a0f4c4cc152db841ff9.tar.gz
ruby-30793b7ca6cccaaac5d87a0f4c4cc152db841ff9.tar.xz
ruby-30793b7ca6cccaaac5d87a0f4c4cc152db841ff9.zip
* lib/delegate.rb (marshal_dump/load): dump & load instance variables by default [ruby-core:24211]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@26163 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--lib/delegate.rb8
2 files changed, 12 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 593925999..5e63c49cd 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Thu Dec 24 12:08:00 2009 Marc-Andre Lafortune <ruby-core@marc-andre.ca>
+
+ * lib/delegate.rb (marshal_dump/load): dump & load instance variables
+ by default [ruby-core:24211]
+
Thu Dec 24 10:31:50 2009 Marc-Andre Lafortune <ruby-core@marc-andre.ca>
* lib/object.c (rb_obj_cmp): Default <=> operator returns 0 if
diff --git a/lib/delegate.rb b/lib/delegate.rb
index 77804e47f..f8a71f186 100644
--- a/lib/delegate.rb
+++ b/lib/delegate.rb
@@ -183,10 +183,16 @@ class Delegator
# Serialization support for the object returned by \_\_getobj\_\_.
def marshal_dump
- __getobj__
+ [
+ instance_variables,
+ instance_variables.map{|var| instance_variable_get(var)},
+ __getobj__
+ ]
end
# Reinitializes delegation from a serialized object.
def marshal_load(obj)
+ vars, values, obj = obj
+ vars.each_with_index{|var, i| instance_variable_set(var, values[i])}
__setobj__(obj)
end