82e444710d
Bug: 335718784 Test: CI Change-Id: I26f7babca349c654780711cfe0f0ece3faa5f436
25 lines
538 B
Go
25 lines
538 B
Go
package proptools
|
|
|
|
import (
|
|
"math"
|
|
)
|
|
|
|
func ShardBySize[T ~[]E, E any](toShard T, shardSize int) []T {
|
|
if len(toShard) == 0 {
|
|
return nil
|
|
}
|
|
|
|
ret := make([]T, 0, (len(toShard)+shardSize-1)/shardSize)
|
|
for len(toShard) > shardSize {
|
|
ret = append(ret, toShard[0:shardSize])
|
|
toShard = toShard[shardSize:]
|
|
}
|
|
if len(toShard) > 0 {
|
|
ret = append(ret, toShard)
|
|
}
|
|
return ret
|
|
}
|
|
|
|
func ShardByCount[T ~[]E, E any](toShard T, shardCount int) []T {
|
|
return ShardBySize(toShard, int(math.Ceil(float64(len(toShard))/float64(shardCount))))
|
|
}
|