diff options
| author | Yukihiro Matsumoto <[email protected]> | 2012-05-17 13:21:01 +0900 |
|---|---|---|
| committer | Yukihiro Matsumoto <[email protected]> | 2012-05-17 13:21:01 +0900 |
| commit | 103ef78e59348d5aef4775759cfb651ae1b340ee (patch) | |
| tree | 66e66ebe3a4bb03a6ebda9dfa0ed410c889057fa /src/parse.y | |
| parent | b68e69aa326c98fbe9676e00aea211a49c6ae361 (diff) | |
| download | mruby-103ef78e59348d5aef4775759cfb651ae1b340ee.tar.gz mruby-103ef78e59348d5aef4775759cfb651ae1b340ee.zip | |
no SEGV for nth_ref & back_ref; close #152
Diffstat (limited to 'src/parse.y')
| -rw-r--r-- | src/parse.y | 9 |
1 files changed, 3 insertions, 6 deletions
diff --git a/src/parse.y b/src/parse.y index e6d980d1c..b8fb54c84 100644 --- a/src/parse.y +++ b/src/parse.y @@ -4406,7 +4406,6 @@ parser_yylex(parser_state *p) case '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9': - tokadd(p, '$'); do { tokadd(p, c); c = nextc(p); @@ -4414,7 +4413,7 @@ parser_yylex(parser_state *p) pushback(p, c); if (last_state == EXPR_FNAME) goto gvar; tokfix(p); - yylval.node = new_nth_ref(p, atoi(tok(p)+1)); + yylval.node = new_nth_ref(p, atoi(tok(p))); return tNTH_REF; default: @@ -5239,13 +5238,11 @@ parser_dump(mrb_state *mrb, node *tree, int offset) break; case NODE_BACK_REF: - printf("NODE_BACK_REF:\n"); - parser_dump(mrb, tree, offset+1); + printf("NODE_BACK_REF: $%c\n", (int)tree); break; case NODE_NTH_REF: - printf("NODE_NTH_REF:\n"); - parser_dump(mrb, tree, offset+1); + printf("NODE_NTH_REF: $%d\n", (int)tree); break; case NODE_ARG: |
