mirror of https://github.com/golang/go.git
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>
This commit is contained in:
parent
03305a9e0c
commit
6d594342c6
|
|
@ -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()
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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"
|
||||
Loading…
Reference in New Issue