diff options
| author | Mel <einebeere@gmail.com> | 2022-04-19 23:53:30 +0200 |
|---|---|---|
| committer | Mel <einebeere@gmail.com> | 2022-04-19 23:53:30 +0200 |
| commit | 65fc6afb54190af91f1b66627dfdd097ee9e4fbc (patch) | |
| tree | 4eb3532b1e7a7c2f320e7da2011b0b0f3a82d464 /pkg | |
| parent | 2b8642aff15bc56751b32dea1057cb08827e7edc (diff) | |
| download | jinx-65fc6afb54190af91f1b66627dfdd097ee9e4fbc.tar.zst jinx-65fc6afb54190af91f1b66627dfdd097ee9e4fbc.zip | |
Scanner tight number fix
Diffstat (limited to 'pkg')
| -rw-r--r-- | pkg/lang/scanner/scanner.go | 6 | ||||
| -rw-r--r-- | pkg/lang/scanner/scanner_test.go | 21 |
2 files changed, 26 insertions, 1 deletions
diff --git a/pkg/lang/scanner/scanner.go b/pkg/lang/scanner/scanner.go index 08481d8..5a1c92a 100644 --- a/pkg/lang/scanner/scanner.go +++ b/pkg/lang/scanner/scanner.go @@ -270,7 +270,7 @@ func (s *Scanner) scanNumber() (token.Token, error) { var buf strings.Builder for { - c, eof, err := s.next() + c, eof, err := s.peek() if err != nil { return token.Token{}, err } @@ -279,6 +279,10 @@ func (s *Scanner) scanNumber() (token.Token, error) { break } + if _, _, err = s.next(); err != nil { + return token.Token{}, err + } + buf.WriteRune(c) } diff --git a/pkg/lang/scanner/scanner_test.go b/pkg/lang/scanner/scanner_test.go index cc19f8f..3af7fa4 100644 --- a/pkg/lang/scanner/scanner_test.go +++ b/pkg/lang/scanner/scanner_test.go @@ -97,3 +97,24 @@ func TestTightIdent(t *testing.T) { require.Equal(t, expected, tokens) } + +func TestTightNumber(t *testing.T) { + source := `1+2+3` + + s := scanner.New(strings.NewReader(source)) + + tokens, err := s.Scan() + require.NoError(t, err) + + expected := []token.Token{ + token.New(token.Int, token.NewLoc(0, 0), uint64(1)), + token.Simple(token.Plus, token.NewLoc(0, 1)), + token.New(token.Int, token.NewLoc(0, 2), uint64(2)), + token.Simple(token.Plus, token.NewLoc(0, 3)), + token.New(token.Int, token.NewLoc(0, 4), uint64(3)), + token.Simple(token.EOF, token.NewLoc(0, 5)), + } + + require.Equal(t, expected, tokens) +} + |
