mirror of
https://github.com/rjNemo/underscore
synced 2026-06-06 02:26:42 +00:00
* feat: add Tap, Transpose, Unzip, ParallelReduce, and Replicate - Add Tap: for side effects/debugging in pipelines - Add Transpose: flip matrix rows and columns - Add Unzip: split tuple slice into two slices - Add ParallelReduce: parallel reduction (experimental) - Add Replicate: create n copies of a value Comprehensive tests included for all functions. Resolves Issues 21, 22, 23, 24, 25 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com> * test: improve ParallelReduce test coverage to 97.5% Add comprehensive tests covering: - Default workers (workers <= 0) - Negative workers - Error handling and propagation - Context cancellation during execution - Context timeout - Single element processing - Many workers (more workers than elements) - Benchmark for performance validation Coverage increased from 68.75% to 97.5% 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com> --------- Co-authored-by: Claude <noreply@anthropic.com>
17 lines
380 B
Go
17 lines
380 B
Go
package underscore
|
|
|
|
// Replicate creates a slice containing count copies of value.
|
|
// Returns an empty slice if count is less than or equal to 0.
|
|
//
|
|
// Example: Replicate(3, "hello") → ["hello", "hello", "hello"]
|
|
func Replicate[T any](count int, value T) []T {
|
|
if count <= 0 {
|
|
return []T{}
|
|
}
|
|
|
|
res := make([]T, count)
|
|
for i := range res {
|
|
res[i] = value
|
|
}
|
|
return res
|
|
}
|