mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
go/scanner: fall back to next() when encountering 0 bytes in parseIdentifier
CL 308611 optimized parseIdentifier for ASCII, but inadvertently skipped error handling for 0 bytes. Don't take the optimized path when encountering 0. Fixes #46855 Change-Id: Ic584e077eb74c012611fefa20eb71ca09c81b3c7 Reviewed-on: https://go-review.googlesource.com/c/go/+/329790 Trust: Robert Findley <rfindley@google.com> Run-TryBot: Robert Findley <rfindley@google.com> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Robert Griesemer <gri@golang.org>
This commit is contained in:
parent
44f9a3566c
commit
20bdfba325
2 changed files with 3 additions and 1 deletions
|
|
@ -373,7 +373,7 @@ func (s *Scanner) scanIdentifier() string {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
s.rdOffset += rdOffset
|
s.rdOffset += rdOffset
|
||||||
if b < utf8.RuneSelf {
|
if 0 < b && b < utf8.RuneSelf {
|
||||||
// Optimization: we've encountered an ASCII character that's not a letter
|
// Optimization: we've encountered an ASCII character that's not a letter
|
||||||
// or number. Avoid the call into s.next() and corresponding set up.
|
// or number. Avoid the call into s.next() and corresponding set up.
|
||||||
//
|
//
|
||||||
|
|
|
||||||
|
|
@ -812,6 +812,8 @@ var errors = []struct {
|
||||||
{"//\ufeff", token.COMMENT, 2, "//\ufeff", "illegal byte order mark"}, // only first BOM is ignored
|
{"//\ufeff", token.COMMENT, 2, "//\ufeff", "illegal byte order mark"}, // only first BOM is ignored
|
||||||
{"'\ufeff" + `'`, token.CHAR, 1, "'\ufeff" + `'`, "illegal byte order mark"}, // only first BOM is ignored
|
{"'\ufeff" + `'`, token.CHAR, 1, "'\ufeff" + `'`, "illegal byte order mark"}, // only first BOM is ignored
|
||||||
{`"` + "abc\ufeffdef" + `"`, token.STRING, 4, `"` + "abc\ufeffdef" + `"`, "illegal byte order mark"}, // only first BOM is ignored
|
{`"` + "abc\ufeffdef" + `"`, token.STRING, 4, `"` + "abc\ufeffdef" + `"`, "illegal byte order mark"}, // only first BOM is ignored
|
||||||
|
{"abc\x00def", token.IDENT, 3, "abc", "illegal character NUL"},
|
||||||
|
{"abc\x00", token.IDENT, 3, "abc", "illegal character NUL"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScanErrors(t *testing.T) {
|
func TestScanErrors(t *testing.T) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue