diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-01-20 14:32:05 -0800 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-01-20 14:32:05 -0800 |
| commit | aaf5f3a0f556626bd401519846cca58d31c99716 (patch) | |
| tree | 8c693e198bf9f6a944ea2862da4aa763c8344a8d /src | |
| parent | ebdb8e985db5afab8f1fe22c53dfe2cf6a9ce7e3 (diff) | |
| parent | f04d9b1c50427870df3391fd1cfb83c2b1ee5a17 (diff) | |
| download | mruby-aaf5f3a0f556626bd401519846cca58d31c99716.tar.gz mruby-aaf5f3a0f556626bd401519846cca58d31c99716.zip | |
Merge pull request #753 from masamitsu-murase/modify_handling_of_quoted_string_literal
Modify handling of quoted non-expanded string literal
Diffstat (limited to 'src')
| -rw-r--r-- | src/parse.y | 60 |
1 files changed, 32 insertions, 28 deletions
diff --git a/src/parse.y b/src/parse.y index a9201a79b..1cb8741f2 100644 --- a/src/parse.y +++ b/src/parse.y @@ -3434,36 +3434,39 @@ parse_string(parser_state *p, int term) } static node* -qstring_node(parser_state *p, int term) +qstring_node(parser_state *p, int beg, int end) { int c; + int nest_level = 0; newtok(p); - while ((c = nextc(p)) != term) { + while ((c = nextc(p)) != end || nest_level != 0) { if (c == -1) { yyerror(p, "unterminated string meets end of file"); return 0; } - if (c == '\\') { + else if (c == beg) { + nest_level++; + } + else if (c == end) { + nest_level--; + } + else if (c == '\\') { c = nextc(p); - switch (c) { - case '\n': - p->lineno++; - p->column = 0; - continue; - - case '\\': - c = '\\'; - break; - - case '\'': - if (term == '\'') { - c = '\''; - break; - } - /* fall through */ - default: - tokadd(p, '\\'); + if (c != beg && c != end) { + switch (c) { + case '\n': + p->lineno++; + p->column = 0; + continue; + + case '\\': + c = '\\'; + break; + + default: + tokadd(p, '\\'); + } } } tokadd(p, c); @@ -3475,12 +3478,12 @@ qstring_node(parser_state *p, int term) } static int -parse_qstring(parser_state *p, int term) +parse_qstring(parser_state *p, int beg, int end) { - node *nd = qstring_node(p, term); + node *nd = qstring_node(p, beg, end); if (nd) { - yylval.nd = new_str(p, tok(p), toklen(p)); + yylval.nd = nd; return tSTRING; } return 0; @@ -3714,7 +3717,7 @@ parser_yylex(parser_state *p) return tSTRING_BEG; case '\'': - return parse_qstring(p, c); + return parse_qstring(p, '\'', '\''); case '?': if (IS_END()) { @@ -4317,7 +4320,7 @@ parser_yylex(parser_state *p) case '%': if (IS_BEG()) { - int term; + int beg = 0, term; #if 0 int paren; #endif @@ -4329,7 +4332,7 @@ parser_yylex(parser_state *p) c = 'Q'; } else { - term = nextc(p); + beg = term = nextc(p); if (isalnum(term)) { yyerror(p, "unknown type of %string"); return 0; @@ -4362,7 +4365,8 @@ parser_yylex(parser_state *p) #if 0 p->lex_strterm = new_strterm(p, str_squote, term, paren); #endif - return tSTRING_BEG; + p->sterm = 0; + return parse_qstring(p, beg, term); case 'W': #if 0 |
