merge: 合并OMC分支

This commit is contained in:
TsMask
2024-07-10 14:18:48 +08:00
parent 17c0011c6b
commit 625ed57a50
260 changed files with 9167 additions and 14857 deletions

View File

@@ -696,3 +696,33 @@ func IsRpmOrDebPackage(filePath string) int {
return fileType
}
func RecurseStructToMap(obj any) map[string]any {
out := make(map[string]any)
v := reflect.ValueOf(obj)
if v.Kind() == reflect.Ptr {
v = v.Elem()
}
// 递归函数,用于处理嵌套结构体
var recurse func(reflect.Value) any
recurse = func(value reflect.Value) any {
if value.Kind() == reflect.Struct {
nestedOut := make(map[string]any)
for i := 0; i < value.NumField(); i++ {
nestedOut[value.Type().Field(i).Name] = recurse(value.Field(i))
}
return nestedOut
} else if value.Kind() == reflect.Ptr {
return recurse(value.Elem())
}
return value.Interface()
}
t := v.Type()
for i := 0; i < v.NumField(); i++ {
f := v.Field(i)
out[t.Field(i).Name] = recurse(f)
}
return out
}