| // run |
| |
| // Copyright 2020 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. |
| |
| package main |
| |
| import "reflect" |
| |
| // complicated enough to require a compile-generated hash function |
| type K struct { |
| a, b int32 // these get merged by the compiler into a single field, something typehash doesn't do |
| c float64 |
| } |
| |
| func main() { |
| k := K{a: 1, b: 2, c: 3} |
| |
| // Make a reflect map. |
| m := reflect.MakeMap(reflect.MapOf(reflect.TypeOf(K{}), reflect.TypeOf(true))) |
| m.SetMapIndex(reflect.ValueOf(k), reflect.ValueOf(true)) |
| |
| // The binary must not contain the type map[K]bool anywhere, or reflect.MapOf |
| // will use that type instead of making a new one. So use an equivalent named type. |
| type M map[K]bool |
| var x M |
| reflect.ValueOf(&x).Elem().Set(m) |
| if !x[k] { |
| panic("key not found") |
| } |
| } |