mirror of
https://github.com/kubernetes/sample-controller.git
synced 2025-02-01 01:12:52 +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
75 lines
2.1 KiB
Go
75 lines
2.1 KiB
Go
package reflect2
|
|
|
|
import (
|
|
"reflect"
|
|
"unsafe"
|
|
)
|
|
|
|
type UnsafeStructField struct {
|
|
reflect.StructField
|
|
structType *UnsafeStructType
|
|
rtype unsafe.Pointer
|
|
ptrRType unsafe.Pointer
|
|
}
|
|
|
|
func newUnsafeStructField(structType *UnsafeStructType, structField reflect.StructField) *UnsafeStructField {
|
|
return &UnsafeStructField{
|
|
StructField: structField,
|
|
rtype: unpackEFace(structField.Type).data,
|
|
ptrRType: unpackEFace(reflect.PtrTo(structField.Type)).data,
|
|
structType: structType,
|
|
}
|
|
}
|
|
|
|
func (field *UnsafeStructField) Offset() uintptr {
|
|
return field.StructField.Offset
|
|
}
|
|
|
|
func (field *UnsafeStructField) Name() string {
|
|
return field.StructField.Name
|
|
}
|
|
|
|
func (field *UnsafeStructField) PkgPath() string {
|
|
return field.StructField.PkgPath
|
|
}
|
|
|
|
func (field *UnsafeStructField) Type() Type {
|
|
return field.structType.cfg.Type2(field.StructField.Type)
|
|
}
|
|
|
|
func (field *UnsafeStructField) Tag() reflect.StructTag {
|
|
return field.StructField.Tag
|
|
}
|
|
|
|
func (field *UnsafeStructField) Index() []int {
|
|
return field.StructField.Index
|
|
}
|
|
|
|
func (field *UnsafeStructField) Anonymous() bool {
|
|
return field.StructField.Anonymous
|
|
}
|
|
|
|
func (field *UnsafeStructField) Set(obj interface{}, value interface{}) {
|
|
objEFace := unpackEFace(obj)
|
|
assertType("StructField.SetIndex argument 1", field.structType.ptrRType, objEFace.rtype)
|
|
valueEFace := unpackEFace(value)
|
|
assertType("StructField.SetIndex argument 2", field.ptrRType, valueEFace.rtype)
|
|
field.UnsafeSet(objEFace.data, valueEFace.data)
|
|
}
|
|
|
|
func (field *UnsafeStructField) UnsafeSet(obj unsafe.Pointer, value unsafe.Pointer) {
|
|
fieldPtr := add(obj, field.StructField.Offset, "same as non-reflect &v.field")
|
|
typedmemmove(field.rtype, fieldPtr, value)
|
|
}
|
|
|
|
func (field *UnsafeStructField) Get(obj interface{}) interface{} {
|
|
objEFace := unpackEFace(obj)
|
|
assertType("StructField.GetIndex argument 1", field.structType.ptrRType, objEFace.rtype)
|
|
value := field.UnsafeGet(objEFace.data)
|
|
return packEFace(field.ptrRType, value)
|
|
}
|
|
|
|
func (field *UnsafeStructField) UnsafeGet(obj unsafe.Pointer) unsafe.Pointer {
|
|
return add(obj, field.StructField.Offset, "same as non-reflect &v.field")
|
|
}
|