diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-07-26 14:05:34 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-07-26 14:05:34 +0000 |
commit | 41f864faab6f1cdd8ad7e88c9c89fea200d030d2 (patch) | |
tree | ed3dcef06a52d57644cdbb9d642a9c38db07ea7f | |
parent | 2d9a4afb137d18bf16ec99f5a841b0f232b05a16 (diff) |
parse.y: separate numeric literal
* parse.y (parser_yylex): separate numeric literal from succeeding
token, and treat 'e' as floating point number only if followed by
exponent part.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42197 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | parse.y | 14 | ||||
-rw-r--r-- | test/ruby/test_syntax.rb | 7 |
3 files changed, 22 insertions, 5 deletions
@@ -1,3 +1,9 @@ +Fri Jul 26 23:05:27 2013 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * parse.y (parser_yylex): separate numeric literal from succeeding + token, and treat 'e' as floating point number only if followed by + exponent part. + Fri Jul 26 22:14:10 2013 Nobuyoshi Nakada <nobu@ruby-lang.org> * vm_exec.h (CHECK_VM_STACK_OVERFLOW_FOR_INSN): surround with @@ -7542,14 +7542,18 @@ parser_yylex(struct parser_params *parser) if (seen_e) { goto decode_num; } - tokadd(c); - seen_e++; - is_float++; nondigit = c; c = nextc(); - if (c != '-' && c != '+') continue; + if (c != '-' && c != '+' && !ISDIGIT(c)) { + pushback(c); + nondigit = 0; + goto decode_num; + } + tokadd(nondigit); + seen_e++; + is_float++; tokadd(c); - nondigit = c; + nondigit = (c == '-' || c == '+') ? c : 0; break; case '_': /* `_' in number just ignored */ diff --git a/test/ruby/test_syntax.rb b/test/ruby/test_syntax.rb index 34bd1e0191..9daa0e4d49 100644 --- a/test/ruby/test_syntax.rb +++ b/test/ruby/test_syntax.rb @@ -363,6 +363,13 @@ eom assert_constant_reassignment_toplevel("11", "+", %w[53], already) end + def test_integer_suffix + ["1if true", "begin 1end"].each do |src| + assert_valid_syntax(src) + assert_equal(1, eval(src), src) + end + end + private def not_label(x) @result = x; @not_label ||= nil end |