aboutsummaryrefslogtreecommitdiff
path: root/src/go/parser/parser.go
diff options
context:
space:
mode:
authorRobert Griesemer <gri@golang.org>2015-09-14 12:01:04 -0700
committerRobert Griesemer <gri@golang.org>2015-09-14 23:37:18 +0000
commit8fab2929dd97b8fb8fe1837b886115e24e814572 (patch)
treeb2741a0b0bd053dd190f394fc4d7ab87cc0fdcf0 /src/go/parser/parser.go
parentffd7d31787c7d08f61fc31feef154f0e8627bd44 (diff)
downloadgo-8fab2929dd97b8fb8fe1837b886115e24e814572.tar.gz
go-8fab2929dd97b8fb8fe1837b886115e24e814572.zip
go/parser: better error message for unexpected ',' in struct type
Fixes #12437. Change-Id: I5463970a6259527003eb0e12903a338cc78e0683 Reviewed-on: https://go-review.googlesource.com/14564 Reviewed-by: Chris Manghane <cmang@golang.org>
Diffstat (limited to 'src/go/parser/parser.go')
-rw-r--r--src/go/parser/parser.go9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/go/parser/parser.go b/src/go/parser/parser.go
index e82c0bd122..855caa3daa 100644
--- a/src/go/parser/parser.go
+++ b/src/go/parser/parser.go
@@ -410,9 +410,14 @@ func (p *parser) expectClosing(tok token.Token, context string) token.Pos {
func (p *parser) expectSemi() {
// semicolon is optional before a closing ')' or '}'
if p.tok != token.RPAREN && p.tok != token.RBRACE {
- if p.tok == token.SEMICOLON {
+ switch p.tok {
+ case token.COMMA:
+ // permit a ',' instead of a ';' but complain
+ p.errorExpected(p.pos, "';'")
+ fallthrough
+ case token.SEMICOLON:
p.next()
- } else {
+ default:
p.errorExpected(p.pos, "';'")
syncStmt(p)
}