diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-05-01 00:15:25 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-05-01 00:15:25 +0000 |
commit | 1f06b2abd6c79d66ddd63e1620defa5a0898ea33 (patch) | |
tree | 50c146cbdc02f846fe736accf4573c58403e873f | |
parent | 7079083f2dbb4484c7e9c4e3ca66b8af9a8114b2 (diff) | |
download | ruby-1f06b2abd6c79d66ddd63e1620defa5a0898ea33.tar.gz ruby-1f06b2abd6c79d66ddd63e1620defa5a0898ea33.tar.xz ruby-1f06b2abd6c79d66ddd63e1620defa5a0898ea33.zip |
* eval.c (rb_eval), parse.y (arg): reduce fixnum range literal at
parser. fixed: [ruby-dev:26113]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@8401 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | eval.c | 10 | ||||
-rw-r--r-- | parse.y | 18 |
3 files changed, 20 insertions, 13 deletions
@@ -1,8 +1,11 @@ -Sun May 1 09:13:23 2005 Nobuyoshi Nakada <nobu@ruby-lang.org> +Sun May 1 09:15:17 2005 Nobuyoshi Nakada <nobu@ruby-lang.org> * ruby.c (process_sflag): replace '-' in variable names with '_'. [ruby-dev:26107] + * eval.c (rb_eval), parse.y (arg): reduce fixnum range literal at + parser. fixed: [ruby-dev:26113] + Sat Apr 30 11:59:25 2005 Nobuyoshi Nakada <nobu@ruby-lang.org> * configure.in (RUBY_FUNC_ATTRIBUTE): check for function attribute. @@ -3226,16 +3226,6 @@ rb_eval(self, n) result = rb_range_new(rb_eval(self, node->nd_beg), rb_eval(self, node->nd_end), nd_type(node) == NODE_DOT3); - if (node->nd_state) break; - if (nd_type(node->nd_beg) == NODE_LIT && FIXNUM_P(node->nd_beg->nd_lit) && - nd_type(node->nd_end) == NODE_LIT && FIXNUM_P(node->nd_end->nd_lit)) - { - nd_set_type(node, NODE_LIT); - node->nd_lit = result; - } - else { - node->nd_state = 1; - } break; case NODE_FLIP2: /* like AWK */ @@ -1760,7 +1760,14 @@ arg : lhs '=' arg /*%%%*/ value_expr($1); value_expr($3); - $$ = NEW_DOT2($1, $3); + if (nd_type($1) == NODE_LIT && FIXNUM_P($1->nd_lit) && + nd_type($3) == NODE_LIT && FIXNUM_P($3->nd_lit)) { + $1->nd_lit = rb_range_new($1->nd_lit, $3->nd_lit, Qfalse); + $$ = $1; + } + else { + $$ = NEW_DOT2($1, $3); + } /*% $$ = dispatch2(dot2, $1, $3); %*/ @@ -1770,7 +1777,14 @@ arg : lhs '=' arg /*%%%*/ value_expr($1); value_expr($3); - $$ = NEW_DOT3($1, $3); + if (nd_type($1) == NODE_LIT && FIXNUM_P($1->nd_lit) && + nd_type($3) == NODE_LIT && FIXNUM_P($3->nd_lit)) { + $1->nd_lit = rb_range_new($1->nd_lit, $3->nd_lit, Qtrue); + $$ = $1; + } + else { + $$ = NEW_DOT3($1, $3); + } /*% $$ = dispatch2(dot3, $1, $3); %*/ |