You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					68 lines
				
				1.8 KiB
			
		
		
			
		
	
	
					68 lines
				
				1.8 KiB
			| 
											3 years ago
										 | 'use strict'; | ||
|  | 
 | ||
|  | Object.defineProperty(exports, "__esModule", { | ||
|  |     value: true | ||
|  | }); | ||
|  | 
 | ||
|  | exports.default = function (fn /*, ...args*/) { | ||
|  |     var args = (0, _slice2.default)(arguments, 1); | ||
|  |     return function () /*callArgs*/{ | ||
|  |         var callArgs = (0, _slice2.default)(arguments); | ||
|  |         return fn.apply(null, args.concat(callArgs)); | ||
|  |     }; | ||
|  | }; | ||
|  | 
 | ||
|  | var _slice = require('./internal/slice'); | ||
|  | 
 | ||
|  | var _slice2 = _interopRequireDefault(_slice); | ||
|  | 
 | ||
|  | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
|  | 
 | ||
|  | ; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Creates a continuation function with some arguments already applied. | ||
|  |  * | ||
|  |  * Useful as a shorthand when combined with other control flow functions. Any | ||
|  |  * arguments passed to the returned function are added to the arguments | ||
|  |  * originally passed to apply. | ||
|  |  * | ||
|  |  * @name apply | ||
|  |  * @static | ||
|  |  * @memberOf module:Utils | ||
|  |  * @method | ||
|  |  * @category Util | ||
|  |  * @param {Function} fn - The function you want to eventually apply all | ||
|  |  * arguments to. Invokes with (arguments...). | ||
|  |  * @param {...*} arguments... - Any number of arguments to automatically apply | ||
|  |  * when the continuation is called. | ||
|  |  * @returns {Function} the partially-applied function | ||
|  |  * @example | ||
|  |  * | ||
|  |  * // using apply
 | ||
|  |  * async.parallel([ | ||
|  |  *     async.apply(fs.writeFile, 'testfile1', 'test1'), | ||
|  |  *     async.apply(fs.writeFile, 'testfile2', 'test2') | ||
|  |  * ]); | ||
|  |  * | ||
|  |  * | ||
|  |  * // the same process without using apply
 | ||
|  |  * async.parallel([ | ||
|  |  *     function(callback) { | ||
|  |  *         fs.writeFile('testfile1', 'test1', callback); | ||
|  |  *     }, | ||
|  |  *     function(callback) { | ||
|  |  *         fs.writeFile('testfile2', 'test2', callback); | ||
|  |  *     } | ||
|  |  * ]); | ||
|  |  * | ||
|  |  * // It's possible to pass any number of additional arguments when calling the
 | ||
|  |  * // continuation:
 | ||
|  |  * | ||
|  |  * node> var fn = async.apply(sys.puts, 'one'); | ||
|  |  * node> fn('two', 'three'); | ||
|  |  * one | ||
|  |  * two | ||
|  |  * three | ||
|  |  */ | ||
|  | module.exports = exports['default']; |