]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/compile: use correct variable when setting up dummy CallStmt in error
authorRobert Griesemer <gri@golang.org>
Mon, 26 Jun 2017 18:12:43 +0000 (11:12 -0700)
committerRobert Griesemer <gri@golang.org>
Mon, 26 Jun 2017 18:39:37 +0000 (18:39 +0000)
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>

src/cmd/compile/internal/syntax/parser.go
test/fixedbugs/issue20789.go [new file with mode: 0644]

index fee52c8c3619dd85f5d17c0756a6791f18c2f7a0..bcf56d5faacd99fae8c4cc9215bdcbfce6308704 100644 (file)
@@ -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 (file)
index 0000000..abc7725
--- /dev/null
@@ -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