package model import ( "bytes" "fmt" "regexp" "strings" "text/template" "github.com/xxjwxc/gormt/data/config" "github.com/xxjwxc/gormt/data/view/cnf" "github.com/xxjwxc/gormt/data/view/genfunc" "github.com/xxjwxc/public/mybigcamel" ) // getCamelName Big Hump or Capital Letter.大驼峰或者首字母大写 func getCamelName(name string) string { if !config.GetSingularTable() { // If the table name plural is globally disabled.如果全局禁用表名复数 return mybigcamel.Marshal(strings.TrimSuffix(name, "s")) } return mybigcamel.Marshal(name) } // titleCase title case.首字母大写 func titleCase(name string) string { vv := []rune(name) if len(vv) > 0 { if bool(vv[0] >= 'a' && vv[0] <= 'z') { // title case.首字母大写 vv[0] -= 32 } } return string(vv) } // CapLowercase 小写.且兼容 golint 驼峰命名规则 func CapLowercase(name string) string { // IDAPIID == > idAPIID list := strings.Split(mybigcamel.UnMarshal(name), "_") if len(list) == 0 { return "" } return list[0] + name[len(list[0]):] } // getTypeName Type acquisition filtering.类型获取过滤 func getTypeName(name string) string { // Precise matching first.先精确匹配 if v, ok := cnf.TypeMysqlDicMp[name]; ok { return v } // Fuzzy Regular Matching.模糊正则匹配 for k, v := range cnf.TypeMysqlMatchMp { if ok, _ := regexp.MatchString(k, name); ok { return v } } panic(fmt.Sprintf("type (%v) not match in any way.maybe need to add on (https://github.com/xxjwxc/gormt/blob/master/data/view/cnf/def.go)", name)) } func getUninStr(left, middle, right string) string { re := left if len(right) > 0 { re = left + middle + right } return re } func getGormModelElement() []EmInfo { var result []EmInfo result = append(result, EmInfo{ IsMulti: false, Notes: "Primary key", Type: "int64", // Type.类型标记 ColName: "id", ColStructName: "ID", }) result = append(result, EmInfo{ IsMulti: false, Notes: "created time", Type: "time.Time", // Type.类型标记 ColName: "created_at", ColStructName: "CreatedAt", }) result = append(result, EmInfo{ IsMulti: false, Notes: "updated at", Type: "time.Time", // Type.类型标记 ColName: "updated_at", ColStructName: "UpdatedAt", }) result = append(result, EmInfo{ IsMulti: false, Notes: "deleted time", Type: "time.Time", // Type.类型标记 ColName: "deleted_at", ColStructName: "DeletedAt", }) return result } func buildFList(list *[]FList, key ColumnsKey, keyName, tp, colName string) { for i := 0; i < len(*list); i++ { if (*list)[i].KeyName == keyName { (*list)[i].Kem = append((*list)[i].Kem, FEm{ Type: tp, ColName: colName, ColStructName: getCamelName(colName), }) return } } // 没有 添加一个 *list = append(*list, FList{ Key: key, KeyName: keyName, Kem: []FEm{FEm{ Type: tp, ColName: colName, ColStructName: getCamelName(colName), }}, }) } // GenPreloadList 生成list func GenPreloadList(list []PreloadInfo, multi bool) string { if len(list) > 0 { tmpl, err := template.New("gen_preload").Parse(genfunc.GetGenPreloadTemp(multi)) if err != nil { panic(err) } var buf bytes.Buffer tmpl.Execute(&buf, list) return buf.String() } return "" } // GenFListIndex 生成list status(1:获取函数名,2:获取参数列表,3:获取sql case,4:值列表) func GenFListIndex(info FList, status int) string { switch status { case 1: // 1:获取函数名 { return widthFunctionName(info) } case 2: // 2:获取参数列表 { var strs []string for _, v := range info.Kem { strs = append(strs, fmt.Sprintf("%v %v ", CapLowercase(v.ColStructName), v.Type)) } return strings.Join(strs, ",") } case 3: // 3:获取sql case, { var strs []string for _, v := range info.Kem { strs = append(strs, fmt.Sprintf("%v = ?", v.ColName)) } return strings.Join(strs, " AND ") } case 4: // 4:值列表 { var strs []string for _, v := range info.Kem { strs = append(strs, CapLowercase(v.ColStructName)) } return strings.Join(strs, " , ") } } return "" } func widthFunctionName(info FList) string { switch info.Key { // case ColumnsKeyDefault: case ColumnsKeyPrimary: // primary key.主键 return "FetchByPrimaryKey" case ColumnsKeyUnique: // unique key.唯一索引 return "FetchByUnique" case ColumnsKeyIndex: // index key.复合索引 return "FetchBy" + getCamelName(info.KeyName) + "Index" case ColumnsKeyUniqueIndex: // unique index key.唯一复合索引 return "FetchBy" + getCamelName(info.KeyName) + "UniqueIndex" } return "" }