diff options
| author | gingerBill <bill@gingerbill.org> | 2018-02-25 14:36:41 +0000 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2018-02-25 14:36:41 +0000 |
| commit | 27b7dc336ab7c108d711d6ce00686467f1f0319c (patch) | |
| tree | 3eba29cb2d38592470a480956ac8b997977fefaf /src/tokenizer.cpp | |
| parent | 60a7c68aa6071735e4576795989d1af6f59c28dc (diff) | |
Change parsing for floats and disallow `x.0`
Diffstat (limited to 'src/tokenizer.cpp')
| -rw-r--r-- | src/tokenizer.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/src/tokenizer.cpp b/src/tokenizer.cpp index 668c38cc8..0caa748c3 100644 --- a/src/tokenizer.cpp +++ b/src/tokenizer.cpp @@ -536,6 +536,9 @@ Token scan_number_to_token(Tokenizer *t, bool seen_decimal_point) { token.pos.column = t->curr-t->line+1; if (seen_decimal_point) { + token.string.text -= 1; + token.string.len += 1; + token.pos.column -= 1; token.kind = Token_Float; scan_mantissa(t, 10); goto exponent; @@ -906,7 +909,6 @@ Token tokenizer_get_token(Tokenizer *t) { } break; case '.': - token.kind = Token_Period; // Default if (t->curr_rune == '.') { // Could be an ellipsis advance_to_next_rune(t); token.kind = Token_HalfClosed; @@ -914,6 +916,10 @@ Token tokenizer_get_token(Tokenizer *t) { advance_to_next_rune(t); token.kind = Token_Ellipsis; } + } else if ('0' <= t->curr_rune && t->curr_rune <= '9') { + token = scan_number_to_token(t, true); + } else { + token.kind = Token_Period; } break; |