diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-10-07 14:35:19 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-10-07 14:35:19 +0000 |
commit | b067aef7c0a26a6d689f214bff66ee318fa9ad17 (patch) | |
tree | 0176c034317d071fa80815b55f1c5087c09a888c /eval.c | |
parent | 4632511aa9723ecf1de5d255f58d6537f6006438 (diff) |
* eval.c (formal_assign): packed post splat arguments may conflict
with normal arguments. [ruby-core:09021]
* eval.c (rb_call0): ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11103 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 7 |
1 files changed, 5 insertions, 2 deletions
@@ -5678,6 +5678,7 @@ formal_assign(VALUE recv, NODE *node, int argc, const VALUE *argv, VALUE *local_ v = rb_ary_new4(argc,argv); n += npost; i += n*256; + i = -i; } else { v = rb_ary_new2(0); @@ -5719,11 +5720,13 @@ rb_call0(VALUE klass, VALUE recv, ID id, ID oid, stack_check(); rb_gc_finalize_deferred(); } - if (argc >= 256) { + if (argc < 0) { VALUE tmp; VALUE *nargv; - int n = argc / 256 - 1; + int n; + argc = -argc; + n = argc / 256 - 1; argc %= 256; tmp = svalue_to_avalue(argv[argc]); nargv = TMP_ALLOC(argc + RARRAY_LEN(tmp) + n); |