-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathhelpers.go
121 lines (102 loc) · 2.25 KB
/
helpers.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
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
package goseeder
import (
"encoding/json"
"fmt"
"log"
"reflect"
"runtime"
"strconv"
"strings"
)
const (
infoColor = "\033[1;34m%s\033[0m"
noticeColor = "\033[1;36m%s\033[0m"
warningColor = "\033[1;33m%s\033[0m"
errorColor = "\033[1;31m%s\033[0m"
debugColor = "\033[0;36m%s\033[0m"
)
var printInfo = func(s string) {
fmt.Print(color(infoColor)(s))
}
var printError = func(s string) {
fmt.Print(color(errorColor)(s))
}
func color(colorString string) func(...interface{}) string {
return func(args ...interface{}) string {
return fmt.Sprintf(colorString,
fmt.Sprint(args...))
}
}
func findString(slice []string, val string) (int, bool) {
for i, item := range slice {
if item == val {
return i, true
}
}
return -1, false
}
func prepareStatement(table string, row map[string]interface{}) (strings.Builder, []interface{}) {
var left strings.Builder
var right strings.Builder
var args []interface{}
left.WriteString(fmt.Sprintf("insert into %s (", table))
right.WriteString("values (")
i := 0
for k, v := range row {
if i == 0 {
left.WriteString(k)
right.WriteString("?")
} else {
left.WriteString(fmt.Sprintf(", %s", k))
right.WriteString(", ?")
}
args = append(args, parseValue(v))
i++
}
left.WriteString(") ")
right.WriteString(")")
left.WriteString(right.String())
return left, args
}
func parseValue(value interface{}) interface{} {
if value == nil {
return value
}
switch v := value.(type) {
case bool:
return value.(bool)
case int:
return value.(int)
case int32:
return value.(int32)
case int64:
return value.(int64)
case float32:
return value.(float32)
case float64:
return value.(float64)
case string:
return value.(string)
case interface{}:
asJson, err := json.Marshal(value)
if err != nil {
panic(err)
}
return string(asJson)
default:
log.Printf("Don't know type : %v", v)
}
if parsed, err := strconv.ParseInt(value.(string), 10, 64); err == nil {
return parsed
}
if parsed, err := strconv.ParseFloat(value.(string), 32); err == nil {
return parsed
}
if parsed, err := strconv.ParseBool(value.(string)); err == nil {
return parsed
}
return value
}
func getFunctionName(i interface{}) string {
return runtime.FuncForPC(reflect.ValueOf(i).Pointer()).Name()
}