internal/unsafe: fix vet warnings about SliceHeader use

Signed-off-by: Elias Naur <mail@eliasnaur.com>
This commit is contained in:
Elias Naur
2020-12-10 18:33:02 +01:00
parent 679bf092cb
commit 2dce8a0155
+11 -11
View File
@@ -12,11 +12,12 @@ func BytesView(s interface{}) []byte {
v := reflect.ValueOf(s)
first := v.Index(0)
sz := int(first.Type().Size())
return *(*[]byte)(unsafe.Pointer(&reflect.SliceHeader{
Data: uintptr(unsafe.Pointer((*reflect.SliceHeader)(unsafe.Pointer(first.UnsafeAddr())))),
Len: v.Len() * sz,
Cap: v.Cap() * sz,
}))
var res []byte
h := (*reflect.SliceHeader)(unsafe.Pointer(&res))
h.Data = first.UnsafeAddr()
h.Cap = v.Cap() * sz
h.Len = v.Len() * sz
return res
}
// SliceOf returns a slice from a (native) pointer.
@@ -24,12 +25,11 @@ func SliceOf(s uintptr) []byte {
if s == 0 {
return nil
}
sh := reflect.SliceHeader{
Data: s,
Len: 1 << 30,
Cap: 1 << 30,
}
return *(*[]byte)(unsafe.Pointer(&sh))
var res []byte
h := (*reflect.SliceHeader)(unsafe.Pointer(&res))
h.Data = s
h.Cap = 1 << 30
return res
}
// GoString convert a NUL-terminated C string