cmd/compile: fix internal error on complex comparison

Complex type is the only TIDEAL that lack of support for all comparison
operators. When rewriting constant comparison into literal node, that
missing cause compiler raise an internal error.

Checking the operator is available for complex type before that fix the
problem.

We can make this check works more generally if there's more type lack of
supporting all comparison operators added, but it does not seem to be
happened, so just check explicitly for complex only.

Fixes #32723

Change-Id: I4938b1bdcbcdae9a9d87436024984bd2ab12995e
Reviewed-on: https://go-review.googlesource.com/c/go/+/183459
Run-TryBot: Cuong Manh Le <cuong.manhle.vn@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
This commit is contained in:
LE Manh Cuong 2019-06-24 14:23:38 +07:00 committed by Matthew Dempsky
parent b136267b87
commit 24c6dd9823
2 changed files with 29 additions and 0 deletions

View File

@ -763,6 +763,13 @@ func typecheck1(n *Node, top int) (res *Node) {
t = l.Type
if iscmp[n.Op] {
// TIDEAL includes complex constant, but only OEQ and ONE are defined for complex,
// so check that the n.op is available for complex here before doing evconst.
if !okfor[n.Op][TCOMPLEX128] && (Isconst(l, CTCPLX) || Isconst(r, CTCPLX)) {
yyerror("invalid operation: %v (operator %v not defined on untyped complex)", n, n.Op)
n.Type = nil
return n
}
evconst(n)
t = types.Idealbool
if n.Op != OLITERAL {

View File

@ -0,0 +1,22 @@
// errorcheck
// Copyright 2019 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.
// Complex literal comparison
package p
const x = 1i
const y = 1i < 2i // ERROR "invalid operation: .*not defined on untyped complex"
const z = x < 2i // ERROR "invalid operation: .*not defined on untyped complex"
func f() {
_ = 1i < 2i // ERROR "invalid operation: .*not defined on untyped complex"
_ = 1i < 2 // ERROR "invalid operation: .*not defined on untyped complex"
_ = 1 < 2i // ERROR "invalid operation: .*not defined on untyped complex"
c := 1i
_ = c < 2i // ERROR "invalid operation: .*not defined on complex128"
}