* parse.y (parser_yylex): EXPR_BEG by keywords is a start point of
commands. [ruby-dev:45563][Bug #6347] * parse.y (superclass): ditto for superclass. * parse.y (parser_parse_string, parser_here_document): ditto for string interpolation. * parse.y (parser_yylex): ditto for singleton class. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35457 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
4f2b00429e
commit
5f34227718
12
ChangeLog
12
ChangeLog
@ -1,3 +1,15 @@
|
|||||||
|
Tue Apr 24 16:04:39 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* parse.y (parser_yylex): EXPR_BEG by keywords is a start point of
|
||||||
|
commands. [ruby-dev:45563][Bug #6347]
|
||||||
|
|
||||||
|
* parse.y (superclass): ditto for superclass.
|
||||||
|
|
||||||
|
* parse.y (parser_parse_string, parser_here_document): ditto for
|
||||||
|
string interpolation.
|
||||||
|
|
||||||
|
* parse.y (parser_yylex): ditto for singleton class.
|
||||||
|
|
||||||
Tue Apr 24 15:51:41 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
Tue Apr 24 15:51:41 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
* lib/optparse.rb (OptionParser#to_a): should split by end-of-line
|
* lib/optparse.rb (OptionParser#to_a): should split by end-of-line
|
||||||
|
9
parse.y
9
parse.y
@ -4407,6 +4407,7 @@ superclass : term
|
|||||||
| '<'
|
| '<'
|
||||||
{
|
{
|
||||||
lex_state = EXPR_BEG;
|
lex_state = EXPR_BEG;
|
||||||
|
command_start = TRUE;
|
||||||
}
|
}
|
||||||
expr_value term
|
expr_value term
|
||||||
{
|
{
|
||||||
@ -6144,6 +6145,7 @@ parser_parse_string(struct parser_params *parser, NODE *quote)
|
|||||||
pushback(c);
|
pushback(c);
|
||||||
return tSTRING_DVAR;
|
return tSTRING_DVAR;
|
||||||
case '{':
|
case '{':
|
||||||
|
command_start = TRUE;
|
||||||
return tSTRING_DBEG;
|
return tSTRING_DBEG;
|
||||||
}
|
}
|
||||||
tokadd('#');
|
tokadd('#');
|
||||||
@ -6369,6 +6371,7 @@ parser_here_document(struct parser_params *parser, NODE *here)
|
|||||||
pushback(c);
|
pushback(c);
|
||||||
return tSTRING_DVAR;
|
return tSTRING_DVAR;
|
||||||
case '{':
|
case '{':
|
||||||
|
command_start = TRUE;
|
||||||
return tSTRING_DBEG;
|
return tSTRING_DBEG;
|
||||||
}
|
}
|
||||||
tokadd('#');
|
tokadd('#');
|
||||||
@ -7009,6 +7012,8 @@ parser_yylex(struct parser_params *parser)
|
|||||||
switch (lex_state) {
|
switch (lex_state) {
|
||||||
case EXPR_FNAME: case EXPR_DOT:
|
case EXPR_FNAME: case EXPR_DOT:
|
||||||
lex_state = EXPR_ARG; break;
|
lex_state = EXPR_ARG; break;
|
||||||
|
case EXPR_CLASS:
|
||||||
|
command_start = TRUE;
|
||||||
default:
|
default:
|
||||||
lex_state = EXPR_BEG; break;
|
lex_state = EXPR_BEG; break;
|
||||||
}
|
}
|
||||||
@ -7997,8 +8002,10 @@ parser_yylex(struct parser_params *parser)
|
|||||||
set_yylval_name(rb_intern(kw->name));
|
set_yylval_name(rb_intern(kw->name));
|
||||||
return kw->id[0];
|
return kw->id[0];
|
||||||
}
|
}
|
||||||
if (kw->id[0] == keyword_do) {
|
if (lex_state == EXPR_BEG) {
|
||||||
command_start = TRUE;
|
command_start = TRUE;
|
||||||
|
}
|
||||||
|
if (kw->id[0] == keyword_do) {
|
||||||
if (lpar_beg && lpar_beg == paren_nest) {
|
if (lpar_beg && lpar_beg == paren_nest) {
|
||||||
lpar_beg = 0;
|
lpar_beg = 0;
|
||||||
--paren_nest;
|
--paren_nest;
|
||||||
|
@ -103,8 +103,40 @@ class TestSyntax < Test::Unit::TestCase
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_cmd_symbol_after_keyword
|
||||||
|
bug6347 = '[ruby-dev:45563]'
|
||||||
|
assert_not_label(:foo, 'if true then not_label:foo end', bug6347)
|
||||||
|
assert_not_label(:foo, 'if false; else not_label:foo end', bug6347)
|
||||||
|
assert_not_label(:foo, 'begin not_label:foo end', bug6347)
|
||||||
|
assert_not_label(:foo, 'begin ensure not_label:foo end', bug6347)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_cmd_symbol_in_string
|
||||||
|
bug6347 = '[ruby-dev:45563]'
|
||||||
|
assert_not_label(:foo, '"#{not_label:foo}"', bug6347)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_cmd_symbol_singleton_class
|
||||||
|
bug6347 = '[ruby-dev:45563]'
|
||||||
|
@not_label = self
|
||||||
|
assert_not_label(:foo, 'class << not_label:foo; end', bug6347)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_cmd_symbol_superclass
|
||||||
|
bug6347 = '[ruby-dev:45563]'
|
||||||
|
@not_label = Object
|
||||||
|
assert_not_label(:foo, 'class Foo < not_label:foo; end', bug6347)
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
|
def not_label(x) @result = x; @not_label ||= nil end
|
||||||
|
def assert_not_label(expected, src, message = nil)
|
||||||
|
@result = nil
|
||||||
|
assert_nothing_raised(SyntaxError, message) {eval(src)}
|
||||||
|
assert_equal(expected, @result, message)
|
||||||
|
end
|
||||||
|
|
||||||
def make_tmpsrc(f, src)
|
def make_tmpsrc(f, src)
|
||||||
f.open
|
f.open
|
||||||
f.truncate(0)
|
f.truncate(0)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user