summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-12 19:15:46 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-02-12 19:15:46 +0000
commit4660cc6fb9bba765ca259bc636d59e8c3c4620b7 (patch)
tree4027ae0a4ba22ab9c6d5c7a1c37e135283791d24
parent4aa1d12937f17b03a4644ea548bdcded2bdf5afb (diff)
* parse.y (stmt, arg): reverted r15450. [ruby-core:15526]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15452 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--parse.y14
2 files changed, 9 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index 8d06e6433f..f0ae8dfb4e 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,6 +1,4 @@
-Wed Feb 13 03:12:54 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
-
- * parse.y (stmt, arg): concat opt_call_args only if non-null.
+Wed Feb 13 04:15:44 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* parse.y (arg_concat_gen, arg_append_gen): optimize for array push.
diff --git a/parse.y b/parse.y
index 593557f9ed..24fc338e51 100644
--- a/parse.y
+++ b/parse.y
@@ -1027,10 +1027,11 @@ stmt : keyword_alias fitem {lex_state = EXPR_FNAME;} fitem
| primary_value '[' opt_call_args rbracket tOP_ASGN command_call
{
/*%%%*/
- NODE *args = $6;
+ NODE *args;
- value_expr(args);
- if ($3) args = arg_concat(args, $3);
+ value_expr($6);
+ if (!$3) $3 = NEW_ZARRAY();
+ args = arg_concat($6, $3);
if ($5 == tOROP) {
$5 = 0;
}
@@ -1828,10 +1829,11 @@ arg : lhs '=' arg
| primary_value '[' opt_call_args rbracket tOP_ASGN arg
{
/*%%%*/
- NODE *args = $6;
+ NODE *args;
- value_expr(args);
- if ($3) args = arg_concat(args, $3);
+ value_expr($6);
+ if (!$3) $3 = NEW_ZARRAY();
+ args = arg_concat($6, $3);
if ($5 == tOROP) {
$5 = 0;
}