Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
efc99a9658 | |||
7988676059 | |||
3901e3934f | |||
![]() |
abeecfd797 | ||
![]() |
5735640ab6 | ||
![]() |
26ea846e93 | ||
![]() |
0592add8ca | ||
![]() |
ab6e6684f8 | ||
![]() |
55928776b4 |
38
filter.go
Normal file
38
filter.go
Normal file
@ -0,0 +1,38 @@
|
||||
package slices
|
||||
|
||||
func Filter[T any](slice []T, f func(T) bool) []T {
|
||||
ret := make([]T, 0, len(slice))
|
||||
for _, v := range slice {
|
||||
if f(v) {
|
||||
ret = append(ret, v)
|
||||
}
|
||||
}
|
||||
return ret
|
||||
}
|
||||
|
||||
func FindFirst[T any](slice []T, f func(T) bool) (T, bool) {
|
||||
for _, v := range slice {
|
||||
if f(v) {
|
||||
return v, true
|
||||
}
|
||||
}
|
||||
return *new(T), false
|
||||
}
|
||||
|
||||
func FindFirstIndex[T any](slice []T, f func(T) bool) (int, bool) {
|
||||
for i, v := range slice {
|
||||
if f(v) {
|
||||
return i, true
|
||||
}
|
||||
}
|
||||
return -1, false
|
||||
}
|
||||
|
||||
func FindLastIndex[T any](slice []T, f func(T) bool) (int, bool) {
|
||||
for i := len(slice); i >= 0; i-- {
|
||||
if f(slice[i]) {
|
||||
return i, true
|
||||
}
|
||||
}
|
||||
return -1, false
|
||||
}
|
6
go.mod
6
go.mod
@ -1,3 +1,5 @@
|
||||
module git.milar.in/milarin/slices
|
||||
module git.tordarus.net/tordarus/slices
|
||||
|
||||
go 1.19
|
||||
go 1.19
|
||||
|
||||
require git.tordarus.net/tordarus/gmath v0.0.7
|
||||
|
4
go.sum
4
go.sum
@ -1,2 +1,2 @@
|
||||
git.milar.in/milarin/channel v0.0.7 h1:cVKtwgH/EE7U+XTHcoFCClJ4LR349KanzjX9xKwRcNg=
|
||||
git.milar.in/milarin/channel v0.0.7/go.mod h1:We83LTI8S7u7II3pD+A2ChCDWJfCkcBUCUqii9HjTtM=
|
||||
git.tordarus.net/tordarus/gmath v0.0.7 h1:tR48idt9AUL0r556ww3ZxByTKJEr6NWCTlhl2ihzYxQ=
|
||||
git.tordarus.net/tordarus/gmath v0.0.7/go.mod h1:mO7aPlvNrGVE9UFXEuuACjZgMDsM63l3OcQy6xSQnoE=
|
||||
|
12
map.go
12
map.go
@ -7,3 +7,15 @@ func Map[I, O any](slice []I, mapper func(I) O) []O {
|
||||
}
|
||||
return ret
|
||||
}
|
||||
|
||||
func MapError[I, O any](slice []I, mapper func(I) (O, error)) ([]O, error) {
|
||||
ret := make([]O, 0, len(slice))
|
||||
for _, old := range slice {
|
||||
new, err := mapper(old)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
ret = append(ret, new)
|
||||
}
|
||||
return ret, nil
|
||||
}
|
||||
|
12
of.go
12
of.go
@ -14,3 +14,15 @@ func OfMap[K comparable, V, T any](m map[K]V, unmapper func(K, V) T) []T {
|
||||
}
|
||||
return out
|
||||
}
|
||||
|
||||
// UnmapKey is an unmapper function which returns the map key only
|
||||
// and discards its value. It is supposed to be used with OfMap
|
||||
func UnmapKey[K comparable, V any](key K, _ V) K {
|
||||
return key
|
||||
}
|
||||
|
||||
// UnmapValue is an unmapper function which returns the map value only
|
||||
// and discards its key. It is supposed to be used with OfMap
|
||||
func UnmapValue[K comparable, V any](_ K, value V) V {
|
||||
return value
|
||||
}
|
||||
|
15
reduce.go
Normal file
15
reduce.go
Normal file
@ -0,0 +1,15 @@
|
||||
package slices
|
||||
|
||||
import "git.tordarus.net/tordarus/gmath"
|
||||
|
||||
func Reduce[T, R any](slice []T, reducer func(current R, v T) R) R {
|
||||
res := new(R)
|
||||
Each(slice, func(v T) {
|
||||
*res = reducer(*res, v)
|
||||
})
|
||||
return *res
|
||||
}
|
||||
|
||||
func SumReducer[N gmath.Number](a, b N) N {
|
||||
return a + b
|
||||
}
|
11
reduce_test.go
Normal file
11
reduce_test.go
Normal file
@ -0,0 +1,11 @@
|
||||
package slices
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestReduce(t *testing.T) {
|
||||
s := Of(1, 2, 3)
|
||||
fmt.Println(Reduce(s, SumReducer[int]))
|
||||
}
|
11
search.go
11
search.go
@ -1,11 +0,0 @@
|
||||
package slices
|
||||
|
||||
func Search[T any](slice []T, f func(a, b T) T) T {
|
||||
if len(slice) == 0 {
|
||||
return *new(T)
|
||||
}
|
||||
|
||||
value := slice[0]
|
||||
Each(slice, func(v T) { value = f(value, v) })
|
||||
return value
|
||||
}
|
10
to.go
10
to.go
@ -17,6 +17,16 @@ func Deref[T any](s []*T) []T {
|
||||
return out
|
||||
}
|
||||
|
||||
// Ref returns a slice containing pointers to all values of s.
|
||||
// The order in s is preserved.
|
||||
func Ref[T any](s []T) []*T {
|
||||
out := make([]*T, 0, len(s))
|
||||
Each(s, func(v T) {
|
||||
out = append(out, &v)
|
||||
})
|
||||
return out
|
||||
}
|
||||
|
||||
// ToList returns a list.List containing all values of s
|
||||
func ToList[T any](s []T) *list.List {
|
||||
l := list.New()
|
||||
|
Loading…
x
Reference in New Issue
Block a user