forked from thoas/go-funk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathzip.go
46 lines (40 loc) · 1.03 KB
/
zip.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
package funk
import (
"reflect"
)
// Tuple is the return type of Zip
type Tuple struct {
Element1 interface{}
Element2 interface{}
}
// Zip returns a list of tuples, where the i-th tuple contains the i-th element
// from each of the input iterables. The returned list is truncated in length
// to the length of the shortest input iterable.
func Zip(slice1 interface{}, slice2 interface{}) []Tuple {
inValue1 := reflect.ValueOf(slice1)
inValue2 := reflect.ValueOf(slice2)
kind1 := inValue1.Type().Kind()
kind2 := inValue2.Type().Kind()
result := []Tuple{}
for _, kind := range []reflect.Kind{kind1, kind2} {
if kind != reflect.Slice && kind != reflect.Array {
return result
}
}
var minLength int
length1 := inValue1.Len()
length2 := inValue2.Len()
if length1 <= length2 {
minLength = length1
} else {
minLength = length2
}
for i := 0; i < minLength; i++ {
newTuple := Tuple{
Element1: inValue1.Index(i).Interface(),
Element2: inValue2.Index(i).Interface(),
}
result = append(result, newTuple)
}
return result
}