mirror of
https://github.com/go-gitea/gitea
synced 2024-11-02 00:04:25 +00:00
1790f01dd9
* Upgrade xorm to v1.2.2 (#16663) Backport #16663 Fix #16683 * Add test to ensure that dumping of login sources remains correct (#16847) #16831 has occurred because of a missed regression. This PR adds a simple test to try to prevent this occuring again. Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
38 lines
1005 B
Go
Vendored
38 lines
1005 B
Go
Vendored
package decoder
|
|
|
|
import (
|
|
"unsafe"
|
|
|
|
"github.com/goccy/go-json/internal/runtime"
|
|
)
|
|
|
|
type anonymousFieldDecoder struct {
|
|
structType *runtime.Type
|
|
offset uintptr
|
|
dec Decoder
|
|
}
|
|
|
|
func newAnonymousFieldDecoder(structType *runtime.Type, offset uintptr, dec Decoder) *anonymousFieldDecoder {
|
|
return &anonymousFieldDecoder{
|
|
structType: structType,
|
|
offset: offset,
|
|
dec: dec,
|
|
}
|
|
}
|
|
|
|
func (d *anonymousFieldDecoder) DecodeStream(s *Stream, depth int64, p unsafe.Pointer) error {
|
|
if *(*unsafe.Pointer)(p) == nil {
|
|
*(*unsafe.Pointer)(p) = unsafe_New(d.structType)
|
|
}
|
|
p = *(*unsafe.Pointer)(p)
|
|
return d.dec.DecodeStream(s, depth, unsafe.Pointer(uintptr(p)+d.offset))
|
|
}
|
|
|
|
func (d *anonymousFieldDecoder) Decode(ctx *RuntimeContext, cursor, depth int64, p unsafe.Pointer) (int64, error) {
|
|
if *(*unsafe.Pointer)(p) == nil {
|
|
*(*unsafe.Pointer)(p) = unsafe_New(d.structType)
|
|
}
|
|
p = *(*unsafe.Pointer)(p)
|
|
return d.dec.Decode(ctx, cursor, depth, unsafe.Pointer(uintptr(p)+d.offset))
|
|
}
|