seaweedfs/weed/mq/schema/struct_to_schema.go

69 lines
1.5 KiB
Go
Raw Normal View History

2024-04-29 02:14:13 +08:00
package schema
import (
"github.com/seaweedfs/seaweedfs/weed/pb/schema_pb"
"reflect"
)
2024-04-29 03:23:54 +08:00
func StructToSchema(instance any) *schema_pb.RecordType {
2024-04-29 02:14:13 +08:00
myType := reflect.TypeOf(instance)
2024-04-29 03:23:54 +08:00
if myType.Kind() != reflect.Struct {
return nil
2024-04-29 02:14:13 +08:00
}
2024-04-29 03:23:54 +08:00
st := reflectTypeToSchemaType(myType)
return st.GetRecordType()
2024-04-29 02:14:13 +08:00
}
func reflectTypeToSchemaType(t reflect.Type) *schema_pb.Type {
switch t.Kind() {
case reflect.Bool:
return TypeBoolean
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32:
2024-05-02 23:52:10 +08:00
return TypeInt32
2024-04-29 02:14:13 +08:00
case reflect.Int64:
2024-05-02 23:52:10 +08:00
return Type64
2024-04-29 02:14:13 +08:00
case reflect.Float32:
2024-05-02 23:52:10 +08:00
return TypeFloat32
2024-04-29 02:14:13 +08:00
case reflect.Float64:
2024-05-02 23:52:10 +08:00
return TypeFloat64
2024-04-29 02:14:13 +08:00
case reflect.String:
return TypeString
case reflect.Slice:
switch t.Elem().Kind() {
case reflect.Uint8:
return TypeBytes
default:
if st := reflectTypeToSchemaType(t.Elem()); st != nil {
return &schema_pb.Type{
Kind: &schema_pb.Type_ListType{
ListType: &schema_pb.ListType{
ElementType: st,
},
},
}
}
}
2024-04-29 03:23:54 +08:00
case reflect.Struct:
recordType := &schema_pb.RecordType{}
for i := 0; i < t.NumField(); i++ {
field := t.Field(i)
fieldType := field.Type
fieldName := field.Name
schemaField := reflectTypeToSchemaType(fieldType)
if schemaField == nil {
return nil
}
recordType.Fields = append(recordType.Fields, &schema_pb.Field{
Name: fieldName,
Type: schemaField,
})
}
return &schema_pb.Type{
Kind: &schema_pb.Type_RecordType{
RecordType: recordType,
},
}
2024-04-29 02:14:13 +08:00
}
return nil
}