Extract method FieldByName
This commit is contained in:
parent
96db2a1d15
commit
3eb4adafba
@ -98,7 +98,7 @@ func sortProcessors(cps []*callback_processor) []*func(scope *Scope) {
|
|||||||
} else if cp.remove {
|
} else if cp.remove {
|
||||||
fmt.Printf("[info] removing callback `%v` from %v\n", cp.name, fileWithLineNum())
|
fmt.Printf("[info] removing callback `%v` from %v\n", cp.name, fileWithLineNum())
|
||||||
} else {
|
} else {
|
||||||
fmt.Println("[warning] duplicated callback `%v` from %v\n", cp.name, fileWithLineNum())
|
fmt.Printf("[warning] duplicated callback `%v` from %v\n", cp.name, fileWithLineNum())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
names = append(names, cp.name)
|
names = append(names, cp.name)
|
||||||
|
16
scope.go
16
scope.go
@ -111,21 +111,7 @@ func (scope *Scope) HasColumn(name string) bool {
|
|||||||
|
|
||||||
// FieldByName to get column's value and existence
|
// FieldByName to get column's value and existence
|
||||||
func (scope *Scope) FieldByName(name string) (interface{}, bool) {
|
func (scope *Scope) FieldByName(name string) (interface{}, bool) {
|
||||||
data := reflect.Indirect(reflect.ValueOf(scope.Value))
|
return FieldByName(name, scope.Value)
|
||||||
|
|
||||||
if data.Kind() == reflect.Struct {
|
|
||||||
if field := data.FieldByName(name); field.IsValid() {
|
|
||||||
return field.Interface(), true
|
|
||||||
}
|
|
||||||
} else if data.Kind() == reflect.Slice {
|
|
||||||
elem := data.Type().Elem()
|
|
||||||
if elem.Kind() == reflect.Ptr {
|
|
||||||
return nil, reflect.New(data.Type().Elem().Elem()).Elem().FieldByName(name).IsValid()
|
|
||||||
} else {
|
|
||||||
return nil, reflect.New(data.Type().Elem()).Elem().FieldByName(name).IsValid()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nil, false
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetColumn to set the column's value
|
// SetColumn to set the column's value
|
||||||
|
23
utils.go
23
utils.go
@ -30,6 +30,29 @@ func (s *safeMap) Get(key string) string {
|
|||||||
return s.m[key]
|
return s.m[key]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func FieldByName(name string, value interface{}, withAddr ...bool) (interface{}, bool) {
|
||||||
|
data := reflect.Indirect(reflect.ValueOf(value))
|
||||||
|
name = snakeToUpperCamel(name)
|
||||||
|
|
||||||
|
if data.Kind() == reflect.Struct {
|
||||||
|
if field := data.FieldByName(name); field.IsValid() {
|
||||||
|
if len(withAddr) > 0 && field.CanAddr() {
|
||||||
|
return field.Addr().Interface(), true
|
||||||
|
} else {
|
||||||
|
return field.Interface(), true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if data.Kind() == reflect.Slice {
|
||||||
|
elem := data.Type().Elem()
|
||||||
|
if elem.Kind() == reflect.Ptr {
|
||||||
|
return nil, reflect.New(data.Type().Elem().Elem()).Elem().FieldByName(name).IsValid()
|
||||||
|
} else {
|
||||||
|
return nil, reflect.New(data.Type().Elem()).Elem().FieldByName(name).IsValid()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil, false
|
||||||
|
}
|
||||||
|
|
||||||
func newSafeMap() *safeMap {
|
func newSafeMap() *safeMap {
|
||||||
return &safeMap{l: new(sync.RWMutex), m: make(map[string]string)}
|
return &safeMap{l: new(sync.RWMutex), m: make(map[string]string)}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user