aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-11-24 10:59:35 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-11-24 10:59:35 +0000
commit4632363ea5453593ab6582d3d2793aa5445d5ac4 (patch)
tree74a7f2d8224e9074c8550c2a70c17164248c60a1
parent269b568291cd0ab7cd4015c0dbe64602bc264370 (diff)
downloadruby-4632363ea5453593ab6582d3d2793aa5445d5ac4.tar.gz
marshal.c: negative limit
* marshal.c (w_object): should not decrement negative limit which means unlimited. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56893 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--marshal.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/marshal.c b/marshal.c
index 3560cb5d80..152b29671a 100644
--- a/marshal.c
+++ b/marshal.c
@@ -591,16 +591,18 @@ encoding_name(VALUE obj, struct dump_arg *arg)
static void
w_encoding(VALUE encname, struct dump_call_arg *arg)
{
+ int limit = arg->limit;
+ if (limit >= 0) ++limit;
switch (encname) {
case Qfalse:
case Qtrue:
w_symbol(ID2SYM(rb_intern("E")), arg->arg);
- w_object(encname, arg->arg, arg->limit + 1);
+ w_object(encname, arg->arg, limit);
case Qnil:
return;
}
w_symbol(ID2SYM(rb_id_encoding()), arg->arg);
- w_object(encname, arg->arg, arg->limit + 1);
+ w_object(encname, arg->arg, limit);
}
static st_index_t
@@ -659,7 +661,7 @@ w_object(VALUE obj, struct dump_arg *arg, int limit)
rb_raise(rb_eArgError, "exceed depth limit");
}
- limit--;
+ if (limit > 0) limit--;
c_arg.limit = limit;
c_arg.arg = arg;