UNPKG

asyncc

Version:
43 lines (41 loc) 1.54 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = parallel; var _parallelLimit = _interopRequireDefault(require("./parallelLimit")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; } /** * Run `tasks` callback functions in parallel. * * Does not stop parallel execution on errors. *All tasks get executed.* * The optional `callback` gets called after the longest running task finishes. * * @name parallel * @memberOf module:parallel * @static * @method * @param {Array<Function>} tasks - Array of callback functions of type `function (cb: Function)` * @param {Object} [options] * @param {Number} [options.timeout] - timeout in ms which throwing `AsynccError` in case that `tasks` are still running * @param {Boolean} [options.bail] - bail-out on first error * @param {Function} [callback] - optional callback function called by last * terminating function from `tasks`, needs to be of type * `function (err: AsynccError, result: Array<any>)` * where `err.errors` is an Array containing the errors in the same * order as the `res` results array. `err.errpos` gives the positions of errors in * order as they occur. * @example * parallel([ * (cb) => { cb(null, 1) }, * (cb) => { cb('error', 2) }, * (cb) => { cb(null, 3) } * ], (err, res) => { * //> err.errors = [null, 'error', null] * //> err.errpos = [1] * //> res = [1, 2, 3] * }) */ function parallel(tasks, opts, callback) { (0, _parallelLimit["default"])(0, tasks, opts, callback); }