mirror of
https://github.com/gogf/gf.git
synced 2025-04-05 03:05:05 +08:00
Merge eb407045c79faef22dcf8144e932e432cb487801 into 1534abdb050acaa5aa6ef27f94e91bca97e6faa3
This commit is contained in:
commit
aaa63a28cd
@ -805,3 +805,38 @@ func Test_Issue3903(t *testing.T) {
|
||||
t.Assert(a.UserId, 100)
|
||||
})
|
||||
}
|
||||
|
||||
// https://github.com/gogf/gf/issues/4218
|
||||
func Test_Issue4218(t *testing.T) {
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
type SysMenuVo struct {
|
||||
MenuId int64 `json:"menuId" orm:"menu_id"`
|
||||
MenuName string `json:"menuName" orm:"menu_name"`
|
||||
Children []*SysMenuVo `json:"children" orm:"children"`
|
||||
ParentId int64 `json:"parentId" orm:"parent_id"`
|
||||
}
|
||||
menus := []*SysMenuVo{
|
||||
{
|
||||
MenuId: 1,
|
||||
MenuName: "系统管理",
|
||||
ParentId: 0,
|
||||
},
|
||||
{
|
||||
MenuId: 2,
|
||||
MenuName: "字典查询",
|
||||
ParentId: 1,
|
||||
},
|
||||
}
|
||||
var parent *SysMenuVo
|
||||
err := gconv.Scan(menus[0], &parent)
|
||||
t.AssertNil(err)
|
||||
t.Assert(parent.MenuId, 1)
|
||||
t.Assert(parent.ParentId, 0)
|
||||
|
||||
parent.Children = append(parent.Children, menus[1])
|
||||
|
||||
t.Assert(len(menus[0].Children), 1)
|
||||
t.Assert(menus[0].Children[0].MenuId, 2)
|
||||
t.Assert(menus[0].Children[0].ParentId, 1)
|
||||
})
|
||||
}
|
||||
|
@ -87,11 +87,14 @@ func (c *Converter) Scan(srcValue any, dstPointer any, option ...ScanOption) (er
|
||||
}
|
||||
|
||||
// Get the element type and kind of dstPointer
|
||||
var (
|
||||
dstPointerReflectValueElem = dstPointerReflectValue.Elem()
|
||||
dstPointerReflectValueElemKind = dstPointerReflectValueElem.Kind()
|
||||
)
|
||||
var dstPointerReflectValueElem = dstPointerReflectValue.Elem()
|
||||
// Check if srcValue and dstPointer are the same type, in which case direct assignment can be performed
|
||||
if ok := c.doConvertWithTypeCheck(srcValueReflectValue, dstPointerReflectValueElem); ok {
|
||||
return nil
|
||||
}
|
||||
|
||||
// Handle multiple level pointers
|
||||
var dstPointerReflectValueElemKind = dstPointerReflectValueElem.Kind()
|
||||
if dstPointerReflectValueElemKind == reflect.Ptr {
|
||||
if dstPointerReflectValueElem.IsNil() {
|
||||
// Create a new value for the pointer dereference
|
||||
@ -105,11 +108,6 @@ func (c *Converter) Scan(srcValue any, dstPointer any, option ...ScanOption) (er
|
||||
return c.Scan(srcValueReflectValue, dstPointerReflectValueElem, option...)
|
||||
}
|
||||
|
||||
// Check if srcValue and dstPointer are the same type, in which case direct assignment can be performed
|
||||
if ok := c.doConvertWithTypeCheck(srcValueReflectValue, dstPointerReflectValueElem); ok {
|
||||
return nil
|
||||
}
|
||||
|
||||
scanOption := c.getScanOption(option...)
|
||||
// Handle different destination types
|
||||
switch dstPointerReflectValueElemKind {
|
||||
|
Loading…
x
Reference in New Issue
Block a user