-
Notifications
You must be signed in to change notification settings - Fork 0
/
util.go
48 lines (44 loc) · 891 Bytes
/
util.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
package entity
import "reflect"
func Unique[T comparable](in []T) []T {
set := make(map[T]struct{}, len(in))
out := make([]T, 0, len(in))
for _, val := range in {
_, ok := set[val]
if ok {
continue
}
out = append(out, val)
set[val] = struct{}{}
}
return out
}
func MergeKeys(dst, src map[string]any) map[string]any {
if dst == nil {
return src
}
for key, rightVal := range src {
if leftVal, present := dst[key]; present {
switch rightVal.(type) {
case map[string]any:
dst[key] = MergeKeys(leftVal.(map[string]any), rightVal.(map[string]any))
default:
dst[key] = rightVal
}
} else {
dst[key] = rightVal
}
}
return dst
}
func NotNilValues(values ...any) int {
counter := 0
for _, value := range values {
val := reflect.ValueOf(value)
if val.Kind() == reflect.Ptr && val.IsNil() {
continue
}
counter++
}
return counter
}