From 46deaa297bcf76438ae17b070ef351d5b91d3d59 Mon Sep 17 00:00:00 2001 From: Russ Cox Date: Tue, 6 Dec 2011 10:48:17 -0500 Subject: [PATCH] gc: disallow map/func equality via interface comparison Missed when I removed direct map/func equality. R=ken2 CC=golang-dev https://golang.org/cl/5452052 --- src/cmd/gc/subr.c | 3 +-- src/pkg/reflect/all_test.go | 4 ++-- test/interface/noeq.go | 39 +++++++++++++++++++++++++++++++++++++ 3 files changed, 42 insertions(+), 4 deletions(-) create mode 100644 test/interface/noeq.go diff --git a/src/cmd/gc/subr.c b/src/cmd/gc/subr.c index 8bdfaf7b0cc..5584f78e2f9 100644 --- a/src/cmd/gc/subr.c +++ b/src/cmd/gc/subr.c @@ -499,8 +499,7 @@ algtype(Type *t) { int a; - if(issimple[t->etype] || isptr[t->etype] || - t->etype == TCHAN || t->etype == TFUNC || t->etype == TMAP) { + if(issimple[t->etype] || isptr[t->etype] || t->etype == TCHAN) { if(t->width == 1) a = AMEM8; else if(t->width == 2) diff --git a/src/pkg/reflect/all_test.go b/src/pkg/reflect/all_test.go index a9e5d1cade4..e43260196fe 100644 --- a/src/pkg/reflect/all_test.go +++ b/src/pkg/reflect/all_test.go @@ -468,8 +468,8 @@ func TestInterfaceValue(t *testing.T) { func TestFunctionValue(t *testing.T) { var x interface{} = func() {} v := ValueOf(x) - if v.Interface() != v.Interface() || v.Interface() != x { - t.Fatalf("TestFunction != itself") + if fmt.Sprint(v.Interface()) != fmt.Sprint(x) { + t.Fatalf("TestFunction returned wrong pointer") } assert(t, v.Type().String(), "func()") } diff --git a/test/interface/noeq.go b/test/interface/noeq.go new file mode 100644 index 00000000000..be368218d7b --- /dev/null +++ b/test/interface/noeq.go @@ -0,0 +1,39 @@ +// $G $D/$F.go && $L $F.$A && ./$A.out || echo BUG: interface/noeq + +// Copyright 2011 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. + +// Interface values containing types that cannot be compared for equality. + +package main + +func main() { + cmp(1) + + var ( + m map[int]int + s struct{} + f func() + ) + noCmp(m) + noCmp(s) + noCmp(f) +} + +func cmp(x interface{}) bool { + return x == x +} + +func noCmp(x interface{}) { + shouldPanic(func() { cmp(x) }) +} + +func shouldPanic(f func()) { + defer func() { + if recover() == nil { + panic("function should panic") + } + }() + f() +}