-
Notifications
You must be signed in to change notification settings - Fork 122
/
fieldmapper.go
46 lines (38 loc) · 1.45 KB
/
fieldmapper.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package sqlbuilder
import (
"reflect"
"github.com/huandu/xstrings"
)
var (
// DefaultFieldMapper is the default field name to table column name mapper func.
// It's nil by default which means field name will be kept as it is.
//
// If a Struct has its own mapper func, the DefaultFieldMapper is ignored in this Struct.
// Field tag has precedence over all kinds of field mapper functions.
//
// Field mapper is called only once on a Struct when the Struct is used to create builder for the first time.
DefaultFieldMapper FieldMapperFunc
// DefaultGetAlias is the default alias and dbtag get func
DefaultGetAlias GetAliasFunc
)
func init() {
DefaultGetAlias = func(field *reflect.StructField) (alias string, dbtag string) {
dbtag = field.Tag.Get(DBTag)
alias = dbtag
return
}
}
// FieldMapperFunc is a func to map struct field names to column names,
// which will be used in query as columns.
type FieldMapperFunc func(name string) string
// SnakeCaseMapper is a field mapper which can convert field name from CamelCase to snake_case.
//
// For instance, it will convert "MyField" to "my_field".
//
// SnakeCaseMapper uses package "xstrings" to do the conversion.
// See https://pkg.go.dev/github.com/huandu/xstrings#ToSnakeCase for conversion rules.
func SnakeCaseMapper(field string) string {
return xstrings.ToSnakeCase(field)
}
// GetAliasFunc is a func to get alias and dbtag
type GetAliasFunc func(field *reflect.StructField) (alias string, dbtag string)