summaryrefslogtreecommitdiff
path: root/marshal.c
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-31 06:10:56 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-01-31 06:10:56 +0000
commitb0a18f4d9fb6125549776fe29a188e749a0a8073 (patch)
treedf157c26b2061d2b4307443b12b36edeee20611f /marshal.c
parentd2bb8975e18ca089819145bf4b3c1c228973ce0d (diff)
* marshal.c (r_object0): call r_entry/r_leave to call proc when TYPE_FIXNUM,
TYPE_NIL, TYPE_TRUE, TYPE_FALSE, TYPE_SYMBOL. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15356 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'marshal.c')
-rw-r--r--marshal.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/marshal.c b/marshal.c
index 77205a45a6..724f420d71 100644
--- a/marshal.c
+++ b/marshal.c
@@ -1208,14 +1208,20 @@ r_object0(struct load_arg *arg, int *ivp, VALUE extmod)
case TYPE_NIL:
v = Qnil;
+ v = r_entry(v, arg);
+ v = r_leave(v, arg);
break;
case TYPE_TRUE:
v = Qtrue;
+ v = r_entry(v, arg);
+ v = r_leave(v, arg);
break;
case TYPE_FALSE:
v = Qfalse;
+ v = r_entry(v, arg);
+ v = r_leave(v, arg);
break;
case TYPE_FIXNUM:
@@ -1223,6 +1229,8 @@ r_object0(struct load_arg *arg, int *ivp, VALUE extmod)
long i = r_long(arg);
v = LONG2FIX(i);
}
+ v = r_entry(v, arg);
+ v = r_leave(v, arg);
break;
case TYPE_FLOAT:
@@ -1497,6 +1505,8 @@ r_object0(struct load_arg *arg, int *ivp, VALUE extmod)
case TYPE_SYMBOL:
v = ID2SYM(r_symreal(arg));
+ v = r_entry(v, arg);
+ v = r_leave(v, arg);
break;
case TYPE_SYMLINK: