| // Copyright 2023 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 abi |
| |
| import ( |
| "unsafe" |
| ) |
| |
| // Map constants common to several packages |
| // runtime/runtime-gdb.py:MapTypePrinter contains its own copy |
| const ( |
| // Maximum number of key/elem pairs a bucket can hold. |
| OldMapBucketCountBits = 3 // log2 of number of elements in a bucket. |
| OldMapBucketCount = 1 << OldMapBucketCountBits |
| |
| // Maximum key or elem size to keep inline (instead of mallocing per element). |
| // Must fit in a uint8. |
| // Note: fast map functions cannot handle big elems (bigger than MapMaxElemBytes). |
| OldMapMaxKeyBytes = 128 |
| OldMapMaxElemBytes = 128 // Must fit in a uint8. |
| ) |
| |
| type OldMapType struct { |
| Type |
| Key *Type |
| Elem *Type |
| Bucket *Type // internal type representing a hash bucket |
| // function for hashing keys (ptr to key, seed) -> hash |
| Hasher func(unsafe.Pointer, uintptr) uintptr |
| KeySize uint8 // size of key slot |
| ValueSize uint8 // size of elem slot |
| BucketSize uint16 // size of bucket |
| Flags uint32 |
| } |
| |
| // Note: flag values must match those used in the TMAP case |
| // in ../cmd/compile/internal/reflectdata/reflect.go:writeType. |
| func (mt *OldMapType) IndirectKey() bool { // store ptr to key instead of key itself |
| return mt.Flags&1 != 0 |
| } |
| func (mt *OldMapType) IndirectElem() bool { // store ptr to elem instead of elem itself |
| return mt.Flags&2 != 0 |
| } |
| func (mt *OldMapType) ReflexiveKey() bool { // true if k==k for all keys |
| return mt.Flags&4 != 0 |
| } |
| func (mt *OldMapType) NeedKeyUpdate() bool { // true if we need to update key on an overwrite |
| return mt.Flags&8 != 0 |
| } |
| func (mt *OldMapType) HashMightPanic() bool { // true if hash function might panic |
| return mt.Flags&16 != 0 |
| } |