12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- package builderx
- import (
- "fmt"
- "reflect"
- "github.com/go-xorm/builder"
- )
- const dbTag = "db"
- func NewEq(in interface{}) builder.Eq {
- return builder.Eq(ToMap(in))
- }
- func NewGt(in interface{}) builder.Gt {
- return builder.Gt(ToMap(in))
- }
- func ToMap(in interface{}) map[string]interface{} {
- out := make(map[string]interface{})
- v := reflect.ValueOf(in)
- if v.Kind() == reflect.Ptr {
- v = v.Elem()
- }
- // we only accept structs
- if v.Kind() != reflect.Struct {
- panic(fmt.Errorf("ToMap only accepts structs; got %T", v))
- }
- typ := v.Type()
- for i := 0; i < v.NumField(); i++ {
- // gets us a StructField
- fi := typ.Field(i)
- if tagv := fi.Tag.Get(dbTag); tagv != "" {
- // set key of map to value in struct field
- val := v.Field(i)
- zero := reflect.Zero(val.Type()).Interface()
- current := val.Interface()
- if reflect.DeepEqual(current, zero) {
- continue
- }
- out[tagv] = current
- }
- }
- return out
- }
- func FieldNames(in interface{}) []string {
- out := make([]string, 0)
- v := reflect.ValueOf(in)
- if v.Kind() == reflect.Ptr {
- v = v.Elem()
- }
- // we only accept structs
- if v.Kind() != reflect.Struct {
- panic(fmt.Errorf("ToMap only accepts structs; got %T", v))
- }
- typ := v.Type()
- for i := 0; i < v.NumField(); i++ {
- // gets us a StructField
- fi := typ.Field(i)
- if tagv := fi.Tag.Get(dbTag); tagv != "" {
- out = append(out, tagv)
- } else {
- out = append(out, fi.Name)
- }
- }
- return out
- }
- func FieldNamesAlias(in interface{}, alias string) []string {
- out := make([]string, 0)
- v := reflect.ValueOf(in)
- if v.Kind() == reflect.Ptr {
- v = v.Elem()
- }
- // we only accept structs
- if v.Kind() != reflect.Struct {
- panic(fmt.Errorf("ToMap only accepts structs; got %T", v))
- }
- typ := v.Type()
- for i := 0; i < v.NumField(); i++ {
- // gets us a StructField
- fi := typ.Field(i)
- tagName := ""
- if tagv := fi.Tag.Get(dbTag); tagv != "" {
- tagName = tagv
- } else {
- tagName = fi.Name
- }
- if len(alias) > 0 {
- tagName = alias + "." + tagName
- }
- out = append(out, tagName)
- }
- return out
- }
|