diff options
author | Robert Griesemer <gri@golang.org> | 2017-06-26 11:12:43 -0700 |
---|---|---|
committer | Robert Griesemer <gri@golang.org> | 2017-06-26 18:39:37 +0000 |
commit | 6d594342c6fbbdc3673748b00bb8f2faaf63a0a4 (patch) | |
tree | 58dfea5026005857fca1b7818433131312e473cf | |
parent | 03305a9e0c786dab67a373106a81df56dda21e25 (diff) | |
download | go-6d594342c6fbbdc3673748b00bb8f2faaf63a0a4.tar.gz go-6d594342c6fbbdc3673748b00bb8f2faaf63a0a4.zip |
cmd/compile: use correct variable when setting up dummy CallStmt in error
Fixes crash when printing a related error message later on.
Fixes #20789.
Change-Id: I6d2c35aafcaeda26a211fc6c8b7dfe4a095a3efe
Reviewed-on: https://go-review.googlesource.com/46713
Run-TryBot: Robert Griesemer <gri@golang.org>
Reviewed-by: Josh Bleecher Snyder <josharian@gmail.com>
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
-rw-r--r-- | src/cmd/compile/internal/syntax/parser.go | 2 | ||||
-rw-r--r-- | test/fixedbugs/issue20789.go | 13 |
2 files changed, 14 insertions, 1 deletions
diff --git a/src/cmd/compile/internal/syntax/parser.go b/src/cmd/compile/internal/syntax/parser.go index fee52c8c36..bcf56d5faa 100644 --- a/src/cmd/compile/internal/syntax/parser.go +++ b/src/cmd/compile/internal/syntax/parser.go @@ -654,7 +654,7 @@ func (p *parser) callStmt() *CallStmt { if !ok { p.error(fmt.Sprintf("expression in %s must be function call", s.Tok)) // already progressed, no need to advance - cx := new(CallExpr) + cx = new(CallExpr) cx.pos = x.Pos() cx.Fun = p.bad() } diff --git a/test/fixedbugs/issue20789.go b/test/fixedbugs/issue20789.go new file mode 100644 index 0000000000..abc7725ca0 --- /dev/null +++ b/test/fixedbugs/issue20789.go @@ -0,0 +1,13 @@ +// errorcheck + +// Copyright 2017 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// Make sure this doesn't crash the compiler. +// (This test should be part of the internal/syntax +// package, but we don't have a general test framework +// there yet, so put it here for now. See also #20800. + +package e +func([<-chan<-[func u){go // ERROR "unexpected u", ERROR "must be function call"
\ No newline at end of file |