File: issue37716.go

package info (click to toggle)
golang-1.24 1.24.4-3
  • links: PTS, VCS
  • area: main
  • in suites: experimental, sid
  • size: 167,820 kB
  • sloc: asm: 154,901; ansic: 7,009; sh: 2,267; javascript: 1,705; perl: 1,052; python: 421; makefile: 110; cpp: 39; f90: 8; awk: 7; objc: 4
file content (32 lines) | stat: -rw-r--r-- 872 bytes parent folder | download | duplicates (25)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// 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")
	}
}