import _curry2 from "./internal/_curry2.js";
|
|
import slice from "./slice.js";
|
|
/**
|
|
* Splits a collection into slices of the specified length.
|
|
*
|
|
* @func
|
|
* @memberOf R
|
|
* @since v0.16.0
|
|
* @category List
|
|
* @sig Number -> [a] -> [[a]]
|
|
* @sig Number -> String -> [String]
|
|
* @param {Number} n
|
|
* @param {Array} list
|
|
* @return {Array}
|
|
* @example
|
|
*
|
|
* R.splitEvery(3, [1, 2, 3, 4, 5, 6, 7]); //=> [[1, 2, 3], [4, 5, 6], [7]]
|
|
* R.splitEvery(3, 'foobarbaz'); //=> ['foo', 'bar', 'baz']
|
|
*/
|
|
|
|
var splitEvery =
|
|
/*#__PURE__*/
|
|
_curry2(function splitEvery(n, list) {
|
|
if (n <= 0) {
|
|
throw new Error('First argument to splitEvery must be a positive integer');
|
|
}
|
|
|
|
var result = [];
|
|
var idx = 0;
|
|
|
|
while (idx < list.length) {
|
|
result.push(slice(idx, idx += n, list));
|
|
}
|
|
|
|
return result;
|
|
});
|
|
|
|
export default splitEvery;
|