compiler: support for byte arrays as keys in maps
Этот коммит содержится в:
родитель
f8a1e5f449
коммит
504c82a0e7
4 изменённых файлов: 25 добавлений и 0 удалений
|
@ -120,6 +120,10 @@ func hashmapIsBinaryKey(keyType types.Type) bool {
|
|||
}
|
||||
}
|
||||
return true
|
||||
case *types.Array:
|
||||
return hashmapIsBinaryKey(keyType.Elem())
|
||||
case *types.Named:
|
||||
return hashmapIsBinaryKey(keyType.Underlying())
|
||||
default:
|
||||
return false
|
||||
}
|
||||
|
|
|
@ -451,6 +451,13 @@ func (v *MapValue) Value() llvm.Value {
|
|||
keyBuf[i] = byte(n)
|
||||
n >>= 8
|
||||
}
|
||||
} else if key.Type().TypeKind() == llvm.ArrayTypeKind &&
|
||||
key.Type().ElementType().TypeKind() == llvm.IntegerTypeKind &&
|
||||
key.Type().ElementType().IntTypeWidth() == 8 {
|
||||
keyBuf = make([]byte, v.Eval.TargetData.TypeAllocSize(key.Type()))
|
||||
for i := range keyBuf {
|
||||
keyBuf[i] = byte(llvm.ConstExtractValue(llvmKey, []uint32{uint32(i)}).ZExtValue())
|
||||
}
|
||||
} else {
|
||||
panic("interp: map key type not implemented: " + key.Type().String())
|
||||
}
|
||||
|
|
12
testdata/map.go
предоставленный
12
testdata/map.go
предоставленный
|
@ -15,6 +15,13 @@ var testmap2 = map[string]int{
|
|||
"eleven": 11,
|
||||
"twelve": 12,
|
||||
}
|
||||
|
||||
type ArrayKey [4]byte
|
||||
|
||||
var testMapArrayKey = map[ArrayKey]int{
|
||||
ArrayKey([4]byte{1, 2, 3, 4}): 1234,
|
||||
ArrayKey([4]byte{4, 3, 2, 1}): 4321,
|
||||
}
|
||||
var testmapIntInt = map[int]int{1: 1, 2: 4, 3: 9}
|
||||
|
||||
func main() {
|
||||
|
@ -35,6 +42,11 @@ func main() {
|
|||
println(testmapIntInt[2])
|
||||
testmapIntInt[2] = 42
|
||||
println(testmapIntInt[2])
|
||||
|
||||
arrKey := ArrayKey([4]byte{4, 3, 2, 1})
|
||||
println(testMapArrayKey[arrKey])
|
||||
testMapArrayKey[arrKey] = 5555
|
||||
println(testMapArrayKey[arrKey])
|
||||
}
|
||||
|
||||
func readMap(m map[string]int, key string) {
|
||||
|
|
2
testdata/map.txt
предоставленный
2
testdata/map.txt
предоставленный
|
@ -52,3 +52,5 @@ false true 2
|
|||
true false 0
|
||||
4
|
||||
42
|
||||
4321
|
||||
5555
|
||||
|
|
Загрузка…
Создание таблицы
Сослаться в новой задаче