diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-12-22 01:32:21 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-12-22 01:32:21 +0000 |
commit | c6b8f89c2e0e95d7e5a7ebcf88565478475f8ed7 (patch) | |
tree | a1255bc8df81063fac8fcafcf7f65f6663549607 | |
parent | 0fe66f38cc04ea3d5e813ababe93123f7a32faa6 (diff) | |
download | ruby-c6b8f89c2e0e95d7e5a7ebcf88565478475f8ed7.tar.gz |
* parse.y (reg_named_capture_assign_iter): captured name should
not be reserved word. a patch from Keita Yamaguchi
<keita.yamaguchi AT gmail.com> in [ruby-dev:32675].
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14450 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | parse.y | 3 |
2 files changed, 8 insertions, 1 deletions
@@ -1,3 +1,9 @@ +Sat Dec 22 10:25:44 2007 Yukihiro Matsumoto <matz@ruby-lang.org> + + * parse.y (reg_named_capture_assign_iter): captured name should + not be reserved word. a patch from Keita Yamaguchi + <keita.yamaguchi AT gmail.com> in [ruby-dev:32675]. + Sat Dec 22 10:19:08 2007 Yukihiro Matsumoto <matz@ruby-lang.org> * eval.c (rb_f_method_name): now __method__ and __callee__ are @@ -8516,7 +8516,8 @@ reg_named_capture_assign_iter(const OnigUChar *name, const OnigUChar *name_end, arg->fail_block = NEW_BEGIN(0); } - if (!(len && rb_enc_islower(*name, enc) && rb_enc_symname2_p(s, len, enc))) { + if (!(len && rb_enc_islower(*name, enc) && rb_enc_symname2_p(s, len, enc)) + || rb_reserved_word(name, len)) { compile_error(PARSER_ARG "named capture with a non local variable - %.*s", len, name); return ST_CONTINUE; |