summaryrefslogtreecommitdiffhomepage
path: root/src/parse.y
diff options
context:
space:
mode:
authorYukihiro Matsumoto <[email protected]>2012-05-17 13:21:01 +0900
committerYukihiro Matsumoto <[email protected]>2012-05-17 13:21:01 +0900
commit103ef78e59348d5aef4775759cfb651ae1b340ee (patch)
tree66e66ebe3a4bb03a6ebda9dfa0ed410c889057fa /src/parse.y
parentb68e69aa326c98fbe9676e00aea211a49c6ae361 (diff)
downloadmruby-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.y9
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: