Files
lodash/spread.js
2017-01-10 01:46:24 -08:00

54 lines
1.5 KiB
JavaScript

import apply from './.internal/apply.js';
import arrayPush from './.internal/arrayPush.js';
import castSlice from './.internal/castSlice.js';
import toInteger from './toInteger.js';
/* Built-in method references for those with the same name as other `lodash` methods. */
const nativeMax = Math.max;
/**
* Creates a function that invokes `func` with the `this` binding of the
* create function and an array of arguments much like
* [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).
*
* **Note:** This method is based on the
* [spread operator](https://mdn.io/spread_operator).
*
* @since 3.2.0
* @category Function
* @param {Function} func The function to spread arguments over.
* @param {number} [start=0] The start position of the spread.
* @returns {Function} Returns the new function.
* @example
*
* const say = spread((who, what) => `${ who } says ${ what }`);
*
* say(['fred', 'hello']);
* // => 'fred says hello'
*
* const numbers = Promise.all([
* Promise.resolve(40),
* Promise.resolve(36)
* ]);
*
* numbers.then(spread((x, y) => x + y));
* // => a Promise of 76
*/
function spread(func, start) {
if (typeof func != 'function') {
throw new TypeError('Expected a function');
}
start = start == null ? 0 : nativeMax(toInteger(start), 0);
return (...args) => {
const array = args[start];
const otherArgs = castSlice(args, 0, start);
if (array) {
arrayPush(otherArgs, array);
}
return apply(func, this, otherArgs);
};
}
export default spread;