Commit d4476138 authored by Matthew Dempsky's avatar Matthew Dempsky

cmd/compile: simplify typehash

We never need a type hash for a method type, so skip trying to
overwrite Thistuple.

Change-Id: I8de6480ba5fd321dfa134facf7661461d298840e
Reviewed-on: https://go-review.googlesource.com/20795Reviewed-by: default avatarRuss Cox <rsc@golang.org>
parent f6bca3f3
...@@ -1219,30 +1219,15 @@ func syslook(name string) *Node { ...@@ -1219,30 +1219,15 @@ func syslook(name string) *Node {
return s.Def return s.Def
} }
// compute a hash value for type t. // typehash computes a hash value for type t to use in type switch
// if t is a method type, ignore the receiver // statements.
// so that the hash can be used in interface checks.
// %T already contains
// all the necessary logic to generate a representation
// of the type that completely describes it.
// using smprint here avoids duplicating that code.
// using md5 here is overkill, but i got tired of
// accidental collisions making the runtime think
// two types are equal when they really aren't.
func typehash(t *Type) uint32 { func typehash(t *Type) uint32 {
var p string // Tconv already contains all the necessary logic to generate
// a representation that completely describes the type, so using
// it here avoids duplicating that code.
p := Tconv(t, FmtLeft|FmtUnsigned)
if t.Thistuple != 0 { // Using MD5 is overkill, but reduces accidental collisions.
// hide method receiver from Tpretty
t.Thistuple = 0
p = Tconv(t, FmtLeft|FmtUnsigned)
t.Thistuple = 1
} else {
p = Tconv(t, FmtLeft|FmtUnsigned)
}
//print("typehash: %s\n", p);
h := md5.Sum([]byte(p)) h := md5.Sum([]byte(p))
return binary.LittleEndian.Uint32(h[:4]) return binary.LittleEndian.Uint32(h[:4])
} }
......
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