-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathstruct.go
More file actions
107 lines (93 loc) · 1.96 KB
/
Copy pathstruct.go
File metadata and controls
107 lines (93 loc) · 1.96 KB
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
package struct2sql
import (
"reflect"
)
//
//
// Struct
//
//
type SQLTable struct {
Name string
NumField int
Fields []SQLField
PrimaryKey int
ForeignKey []SQLForeignKey
}
type SQLField struct {
Name string
Type reflect.Type
Keyword string
CustomType string
IsForeignKey bool
}
type SQLForeignKey struct {
FieldIndex int
Reference string
}
//
//
// Global Variable
//
//
var sqlTables map[reflect.Type]SQLTable = make(map[reflect.Type]SQLTable)
//
//
// Analyze Struct
//
//
func AnalyzeStruct(model interface{}) SQLTable {
// Get type of the struct
var v reflect.Type
var ok bool
if v, ok = model.(reflect.Type); !ok {
v = reflect.Indirect(reflect.ValueOf(model)).Type()
}
// Return if table already exist
if t, ok := sqlTables[v]; ok {
return t
}
// Get basic info from the struct
sqlTable := SQLTable{
Name: v.Name(),
NumField: v.NumField(),
Fields: make([]SQLField, v.NumField()),
PrimaryKey: -1,
ForeignKey: make([]SQLForeignKey, 0),
}
if v.Field(0).Tag.Get("tablename") != "" {
sqlTable.Name = v.Field(0).Tag.Get("tablename")
}
// Get struct field info
for i := 0; i < sqlTable.NumField; i++ {
sqlTable.Fields[i] = SQLField{
Name: v.Field(i).Name,
Type: v.Field(i).Type,
Keyword: v.Field(i).Tag.Get("keyword"),
CustomType: v.Field(i).Tag.Get("customtype"),
}
// Detect tags like primary key and foreign key
if v.Field(i).Tag.Get("primarykey") == "true" {
sqlTable.PrimaryKey = i
} else if v.Field(i).Tag.Get("foreignkey") != "" {
sqlTable.ForeignKey = append(sqlTable.ForeignKey, SQLForeignKey{
FieldIndex: i,
Reference: v.Field(i).Tag.Get("foreignkey"),
})
sqlTable.Fields[i].IsForeignKey = true
}
}
sqlTables[v] = sqlTable
return sqlTable
}
func getTable(t reflect.Type) SQLTable {
if sqlTable, ok := sqlTables[t]; ok {
return sqlTable
}
return AnalyzeStruct(t)
}
func check(err error) {
if err != nil {
panic(err)
}
}