summaryrefslogtreecommitdiff
path: root/parse.y
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-07-10 01:08:15 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-07-10 01:08:15 +0000
commit672549bb47cdf3ccbd6d91697941dadf7328617e (patch)
tree8edb1a59d129300539245135b80194271cf63870 /parse.y
parent021336c36f9154b71bcd4a3cd9f18dcf73e1e6c9 (diff)
* eval.c (proc_invoke): should not overwrite block information in
current frame. [ruby-dev:28957] * eval.c (rb_yield_0): retrieve proper block object from the frame record. * eval.c (proc_alloc): return preserved block object if it's available. * st.h (st_data_t): use pointer sized integer for st_data_t. [ruby-dev:28988] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@10497 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'parse.y')
-rw-r--r--parse.y31
1 files changed, 29 insertions, 2 deletions
diff --git a/parse.y b/parse.y
index 727bfb5189..e26fc1eb66 100644
--- a/parse.y
+++ b/parse.y
@@ -2921,7 +2921,16 @@ block_param : block_param0
$$ = NEW_BLOCK_PARAM($9, NEW_MASGN($1, NEW_POSTARG($4,$6)));
/*%
$$ = blockvar_add_star(blockvar_new($1), $4);
- $$ = blockvar_add_block($$, $6);
+ $$ = blockvar_add_block($$, $9);
+ %*/
+ }
+ | block_param0 ',' tSTAR lhs ',' tAMPER lhs
+ {
+ /*%%%*/
+ $$ = NEW_BLOCK_PARAM($7, NEW_MASGN($1, $4));
+ /*%
+ $$ = blockvar_add_star(blockvar_new($1), $4);
+ $$ = blockvar_add_block($$, $7);
%*/
}
| block_param0 ',' tSTAR ',' tAMPER lhs
@@ -2939,7 +2948,7 @@ block_param : block_param0
$$ = NEW_BLOCK_PARAM($8, NEW_MASGN($1, NEW_POSTARG(-1,$5)));
/*%
$$ = blockvar_add_star(blockvar_new($1), Qnil);
- $$ = blockvar_add_block($$, $5);
+ $$ = blockvar_add_block($$, $8);
%*/
}
| block_param0 ',' tSTAR lhs
@@ -3008,6 +3017,15 @@ block_param : block_param0
$$ = blockvar_add_star(blockvar_new(Qnil), $2);
%*/
}
+ | tSTAR lhs ',' mlhs_post ',' tAMPER lhs
+ {
+ /*%%%*/
+ $$ = NEW_BLOCK_PARAM($7, NEW_MASGN(0, NEW_POSTARG($2,$4)));
+ /*%
+ $$ = blockvar_add_star(blockvar_new(Qnil), Qnil);
+ $$ = blockvar_add_block($$, $7);
+ %*/
+ }
| tSTAR
{
/*%%%*/
@@ -3024,6 +3042,15 @@ block_param : block_param0
$$ = blockvar_add_star(blockvar_new(Qnil), Qnil);
%*/
}
+ | tSTAR ',' mlhs_post ',' tAMPER lhs
+ {
+ /*%%%*/
+ $$ = NEW_BLOCK_PARAM($6, NEW_MASGN(0, NEW_POSTARG(-1,$3)));
+ /*%
+ $$ = blockvar_add_star(blockvar_new(Qnil), Qnil);
+ $$ = blockvar_add_block($$, $6);
+ %*/
+ }
| tAMPER lhs
{
/*%%%*/