Commit d62c6c3c authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

cmd/compile: suppress duplicate type errors

If we've already complained about a type T,
don't complain again about further expressions
involving it.

Fixes #20245 and hopefully all of its ilk.

Change-Id: Ic0abe8235d52e8a7ac40e3615aea8f3a54fd7cec
Reviewed-on: https://go-review.googlesource.com/42690
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
parent 39c07ce9
...@@ -2156,7 +2156,9 @@ OpSwitch: ...@@ -2156,7 +2156,9 @@ OpSwitch:
evconst(n) evconst(n)
if n.Op == OTYPE && top&Etype == 0 { if n.Op == OTYPE && top&Etype == 0 {
yyerror("type %v is not an expression", n.Type) if !n.Type.Broke() {
yyerror("type %v is not an expression", n.Type)
}
n.Type = nil n.Type = nil
return n return n
} }
......
...@@ -15,7 +15,7 @@ type I interface { ...@@ -15,7 +15,7 @@ type I interface {
} }
func n() { func n() {
(I) // ERROR "type I is not an expression" (I)
} }
func m() { func m() {
......
...@@ -8,4 +8,4 @@ ...@@ -8,4 +8,4 @@
package p package p
var f = func(...A) // ERROR "type func(....*) is not an expression" ERROR "undefined: A" var f = func(...A) // ERROR "undefined: A"
// 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.
// Issue 20245: panic while formatting an error message
package p
var e = interface{ I1 } // ERROR "undefined: I1"
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment