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)
|
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
|
// Get the element type and kind of dstPointer
|
||||||
var (
|
var dstPointerReflectValueElem = dstPointerReflectValue.Elem()
|
||||||
dstPointerReflectValueElem = dstPointerReflectValue.Elem()
|
// Check if srcValue and dstPointer are the same type, in which case direct assignment can be performed
|
||||||
dstPointerReflectValueElemKind = dstPointerReflectValueElem.Kind()
|
if ok := c.doConvertWithTypeCheck(srcValueReflectValue, dstPointerReflectValueElem); ok {
|
||||||
)
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// Handle multiple level pointers
|
// Handle multiple level pointers
|
||||||
|
var dstPointerReflectValueElemKind = dstPointerReflectValueElem.Kind()
|
||||||
if dstPointerReflectValueElemKind == reflect.Ptr {
|
if dstPointerReflectValueElemKind == reflect.Ptr {
|
||||||
if dstPointerReflectValueElem.IsNil() {
|
if dstPointerReflectValueElem.IsNil() {
|
||||||
// Create a new value for the pointer dereference
|
// 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...)
|
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...)
|
scanOption := c.getScanOption(option...)
|
||||||
// Handle different destination types
|
// Handle different destination types
|
||||||
switch dstPointerReflectValueElemKind {
|
switch dstPointerReflectValueElemKind {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user