mirror of
https://github.com/kubernetes/sample-controller.git
synced 2025-02-08 06:52:56 +08:00
c0feae0701
Automatic merge from submit-queue (batch tested with PRs 59965, 59115, 63076, 63059). If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. Upgrade dep json-iterator/go to fix base64 decode bug **What this PR does / why we need it**: upgrade dep `json-iterator/go` to fix base64 decode bug #62742 **Which issue(s) this PR fixes** *(optional, in `fixes #<issue number>(, fixes #<issue_number>, ...)` format, will close the issue(s) when PR gets merged)*: Fixes #62742 **Special notes for your reviewer**: Just upgrade `json-iterator/go` to latest which includes base64 decode fix https://github.com/json-iterator/go/pull/266 No other code changes **Release note**: ```release-note None ``` Kubernetes-commit: 3dbcd1ddcee786f443f89a82514bbd9c6ad06c99
66 lines
2.0 KiB
Go
66 lines
2.0 KiB
Go
package reflect2
|
|
|
|
import (
|
|
"reflect"
|
|
"unsafe"
|
|
)
|
|
|
|
type UnsafeArrayType struct {
|
|
unsafeType
|
|
elemRType unsafe.Pointer
|
|
pElemRType unsafe.Pointer
|
|
elemSize uintptr
|
|
likePtr bool
|
|
}
|
|
|
|
func newUnsafeArrayType(cfg *frozenConfig, type1 reflect.Type) *UnsafeArrayType {
|
|
return &UnsafeArrayType{
|
|
unsafeType: *newUnsafeType(cfg, type1),
|
|
elemRType: unpackEFace(type1.Elem()).data,
|
|
pElemRType: unpackEFace(reflect.PtrTo(type1.Elem())).data,
|
|
elemSize: type1.Elem().Size(),
|
|
likePtr: likePtrType(type1),
|
|
}
|
|
}
|
|
|
|
func (type2 *UnsafeArrayType) LikePtr() bool {
|
|
return type2.likePtr
|
|
}
|
|
|
|
func (type2 *UnsafeArrayType) Indirect(obj interface{}) interface{} {
|
|
objEFace := unpackEFace(obj)
|
|
assertType("Type.Indirect argument 1", type2.ptrRType, objEFace.rtype)
|
|
return type2.UnsafeIndirect(objEFace.data)
|
|
}
|
|
|
|
func (type2 *UnsafeArrayType) UnsafeIndirect(ptr unsafe.Pointer) interface{} {
|
|
if type2.likePtr {
|
|
return packEFace(type2.rtype, *(*unsafe.Pointer)(ptr))
|
|
}
|
|
return packEFace(type2.rtype, ptr)
|
|
}
|
|
|
|
func (type2 *UnsafeArrayType) SetIndex(obj interface{}, index int, elem interface{}) {
|
|
objEFace := unpackEFace(obj)
|
|
assertType("ArrayType.SetIndex argument 1", type2.ptrRType, objEFace.rtype)
|
|
elemEFace := unpackEFace(elem)
|
|
assertType("ArrayType.SetIndex argument 3", type2.pElemRType, elemEFace.rtype)
|
|
type2.UnsafeSetIndex(objEFace.data, index, elemEFace.data)
|
|
}
|
|
|
|
func (type2 *UnsafeArrayType) UnsafeSetIndex(obj unsafe.Pointer, index int, elem unsafe.Pointer) {
|
|
elemPtr := arrayAt(obj, index, type2.elemSize, "i < s.Len")
|
|
typedmemmove(type2.elemRType, elemPtr, elem)
|
|
}
|
|
|
|
func (type2 *UnsafeArrayType) GetIndex(obj interface{}, index int) interface{} {
|
|
objEFace := unpackEFace(obj)
|
|
assertType("ArrayType.GetIndex argument 1", type2.ptrRType, objEFace.rtype)
|
|
elemPtr := type2.UnsafeGetIndex(objEFace.data, index)
|
|
return packEFace(type2.pElemRType, elemPtr)
|
|
}
|
|
|
|
func (type2 *UnsafeArrayType) UnsafeGetIndex(obj unsafe.Pointer, index int) unsafe.Pointer {
|
|
return arrayAt(obj, index, type2.elemSize, "i < s.Len")
|
|
}
|