diff options
| author | Robert Griesemer <gri@golang.org> | 2019-03-28 13:32:31 -0700 |
|---|---|---|
| committer | Robert Griesemer <gri@golang.org> | 2019-04-03 23:01:13 +0000 |
| commit | 4145c5da1f533fafd928769d18d5be60968cb9dc (patch) | |
| tree | c4e27fbfaed5069ef881a3068f2e6fbd3d7d5f64 /src/cmd/compile/internal/syntax/parser.go | |
| parent | 9da6530faab0a58c4c4e02b2f3f4a5c754dcbd4e (diff) | |
| download | go-4145c5da1f533fafd928769d18d5be60968cb9dc.tar.xz | |
cmd/compile: better recovery after := (rather than =) in declarations
Before this fix, a mistaken := in a (const/type/var) declaration
ended that declaration with an error from which the parser didn't
recover well. This low-cost change will provide a better error
message and lets the parser recover perfectly.
Fixes #31092.
Change-Id: Ic4f94dc5e29dd00b7ef6d53a80dded638e3cea80
Reviewed-on: https://go-review.googlesource.com/c/go/+/169958
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
Diffstat (limited to 'src/cmd/compile/internal/syntax/parser.go')
| -rw-r--r-- | src/cmd/compile/internal/syntax/parser.go | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/src/cmd/compile/internal/syntax/parser.go b/src/cmd/compile/internal/syntax/parser.go index e1cd8f9f5a..d4e9bf2f96 100644 --- a/src/cmd/compile/internal/syntax/parser.go +++ b/src/cmd/compile/internal/syntax/parser.go @@ -170,6 +170,20 @@ func (p *parser) want(tok token) { } } +// gotAssign is like got(_Assign) but it also accepts ":=" +// (and reports an error) for better parser error recovery. +func (p *parser) gotAssign() bool { + switch p.tok { + case _Define: + p.syntaxError("expecting =") + fallthrough + case _Assign: + p.next() + return true + } + return false +} + // ---------------------------------------------------------------------------- // Error handling @@ -514,7 +528,7 @@ func (p *parser) constDecl(group *Group) Decl { d.NameList = p.nameList(p.name()) if p.tok != _EOF && p.tok != _Semi && p.tok != _Rparen { d.Type = p.typeOrNil() - if p.got(_Assign) { + if p.gotAssign() { d.Values = p.exprList() } } @@ -533,7 +547,7 @@ func (p *parser) typeDecl(group *Group) Decl { d.pos = p.pos() d.Name = p.name() - d.Alias = p.got(_Assign) + d.Alias = p.gotAssign() d.Type = p.typeOrNil() if d.Type == nil { d.Type = p.bad() @@ -556,11 +570,11 @@ func (p *parser) varDecl(group *Group) Decl { d.pos = p.pos() d.NameList = p.nameList(p.name()) - if p.got(_Assign) { + if p.gotAssign() { d.Values = p.exprList() } else { d.Type = p.type_() - if p.got(_Assign) { + if p.gotAssign() { d.Values = p.exprList() } } |
