about summary refs log tree commit diff
path: root/pkg
diff options
context:
space:
mode:
authorMel <einebeere@gmail.com>2022-04-19 23:53:30 +0200
committerMel <einebeere@gmail.com>2022-04-19 23:53:30 +0200
commit65fc6afb54190af91f1b66627dfdd097ee9e4fbc (patch)
tree4eb3532b1e7a7c2f320e7da2011b0b0f3a82d464 /pkg
parent2b8642aff15bc56751b32dea1057cb08827e7edc (diff)
downloadjinx-65fc6afb54190af91f1b66627dfdd097ee9e4fbc.tar.zst
jinx-65fc6afb54190af91f1b66627dfdd097ee9e4fbc.zip
Scanner tight number fix
Diffstat (limited to 'pkg')
-rw-r--r--pkg/lang/scanner/scanner.go6
-rw-r--r--pkg/lang/scanner/scanner_test.go21
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)
+}
+