forked from Shiloh/githaven
62e6c9bc6c
* Add a storage layer for attachments * Fix some bug * fix test * Fix copyright head and lint * Fix bug * Add setting for minio and flags for migrate-storage * Add documents * fix lint * Add test for minio store type on attachments * fix test * fix test * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Add warning when storage migrated successfully * Fix drone * fix test * rebase * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * refactor the codes * add trace * Fix test * remove log on xorm * Fi download bug * Add a storage layer for attachments * Add setting for minio and flags for migrate-storage * fix lint * Add test for minio store type on attachments * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Fix drone * fix test * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * refactor the codes * add trace * Fix test * Add URL function to serve attachments directly from S3/Minio * Add ability to enable/disable redirection in attachment configuration * Fix typo * Add a storage layer for attachments * Add setting for minio and flags for migrate-storage * fix lint * Add test for minio store type on attachments * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Fix drone * fix test * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * don't change unrelated files * Fix lint * Fix build * update go.mod and go.sum * Use github.com/minio/minio-go/v6 * Remove unused function * Upgrade minio to v7 and some other improvements * fix lint * Fix go mod Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: Tyler <tystuyfzand@gmail.com>
75 lines
2.1 KiB
Go
Vendored
75 lines
2.1 KiB
Go
Vendored
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")
|
|
}
|