package utils import ( "github.com/jinzhu/copier" "github.com/pkg/errors" "math/rand" "runtime" "strconv" "strings" "time" ) // copy a by b b->a func CopyStructFields(a interface{}, b interface{}, fields ...string) (err error) { return copier.Copy(a, b) } func Wrap(err error, message string) error { return errors.Wrap(err, "==> "+printCallerNameAndLine()+message) } func WithMessage(err error, message string) error { return errors.WithMessage(err, "==> "+printCallerNameAndLine()+message) } func printCallerNameAndLine() string { pc, _, line, _ := runtime.Caller(2) return runtime.FuncForPC(pc).Name() + "()@" + strconv.Itoa(line) + ": " } func GetSelfFuncName() string { pc, _, _, _ := runtime.Caller(1) return cleanUpFuncName(runtime.FuncForPC(pc).Name()) } func cleanUpFuncName(funcName string) string { end := strings.LastIndex(funcName, ".") if end == -1 { return "" } return funcName[end+1:] } //Get the intersection of two slices func Intersect(slice1, slice2 []uint32) []uint32 { m := make(map[uint32]bool) n := make([]uint32, 0) for _, v := range slice1 { m[v] = true } for _, v := range slice2 { flag, _ := m[v] if flag { n = append(n, v) } } return n } //Get the diff of two slices func Difference(slice1, slice2 []uint32) []uint32 { m := make(map[uint32]bool) n := make([]uint32, 0) inter := Intersect(slice1, slice2) for _, v := range inter { m[v] = true } for _, v := range slice1 { if !m[v] { n = append(n, v) } } for _, v := range slice2 { if !m[v] { n = append(n, v) } } return n } //Get the intersection of two slices func IntersectString(slice1, slice2 []string) []string { m := make(map[string]bool) n := make([]string, 0) for _, v := range slice1 { m[v] = true } for _, v := range slice2 { flag, _ := m[v] if flag { n = append(n, v) } } return n } //Get the diff of two slices func DifferenceString(slice1, slice2 []string) []string { m := make(map[string]bool) n := make([]string, 0) inter := IntersectString(slice1, slice2) for _, v := range inter { m[v] = true } for _, v := range slice1 { if !m[v] { n = append(n, v) } } for _, v := range slice2 { if !m[v] { n = append(n, v) } } return n } func OperationIDGenerator() string { return strconv.FormatInt(time.Now().UnixNano()+int64(rand.Uint32()), 10) } func RemoveRepeatedStringInList(slc []string) []string { var result []string tempMap := map[string]byte{} for _, e := range slc { l := len(tempMap) tempMap[e] = 0 if len(tempMap) != l { result = append(result, e) } } return result }