Skip to content

Commit

Permalink
cmd/compile: suppress duplicate type errors
Browse files Browse the repository at this point in the history
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: Robert Griesemer <gri@golang.org>
  • Loading branch information
josharian committed May 4, 2017
1 parent 39c07ce commit d62c6c3
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 3 deletions.
4 changes: 3 additions & 1 deletion src/cmd/compile/internal/gc/typecheck.go
Expand Up @@ -2156,7 +2156,9 @@ OpSwitch:

evconst(n)
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
return n
}
Expand Down
2 changes: 1 addition & 1 deletion test/fixedbugs/issue11614.go
Expand Up @@ -15,7 +15,7 @@ type I interface {
}

func n() {
(I) // ERROR "type I is not an expression"
(I)
}

func m() {
Expand Down
2 changes: 1 addition & 1 deletion test/fixedbugs/issue20233.go
Expand Up @@ -8,4 +8,4 @@

package p

var f = func(...A) // ERROR "type func(....*) is not an expression" ERROR "undefined: A"
var f = func(...A) // ERROR "undefined: A"
11 changes: 11 additions & 0 deletions test/fixedbugs/issue20245.go
@@ -0,0 +1,11 @@
// 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"

0 comments on commit d62c6c3

Please sign in to comment.