race.js 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. 'use strict';
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = race;
  6. var _isArray = require('lodash/isArray');
  7. var _isArray2 = _interopRequireDefault(_isArray);
  8. var _noop = require('lodash/noop');
  9. var _noop2 = _interopRequireDefault(_noop);
  10. var _once = require('./internal/once');
  11. var _once2 = _interopRequireDefault(_once);
  12. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  13. /**
  14. * Runs the `tasks` array of functions in parallel, without waiting until the
  15. * previous function has completed. Once any of the `tasks` complete or pass an
  16. * error to its callback, the main `callback` is immediately called. It's
  17. * equivalent to `Promise.race()`.
  18. *
  19. * @name race
  20. * @static
  21. * @memberOf module:ControlFlow
  22. * @method
  23. * @category Control Flow
  24. * @param {Array} tasks - An array containing functions to run. Each function
  25. * is passed a `callback(err, result)` which it must call on completion with an
  26. * error `err` (which can be `null`) and an optional `result` value.
  27. * @param {Function} callback - A callback to run once any of the functions have
  28. * completed. This function gets an error or result from the first function that
  29. * completed. Invoked with (err, result).
  30. * @returns undefined
  31. * @example
  32. *
  33. * async.race([
  34. * function(callback) {
  35. * setTimeout(function() {
  36. * callback(null, 'one');
  37. * }, 200);
  38. * },
  39. * function(callback) {
  40. * setTimeout(function() {
  41. * callback(null, 'two');
  42. * }, 100);
  43. * }
  44. * ],
  45. * // main callback
  46. * function(err, result) {
  47. * // the result will be equal to 'two' as it finishes earlier
  48. * });
  49. */
  50. function race(tasks, callback) {
  51. callback = (0, _once2.default)(callback || _noop2.default);
  52. if (!(0, _isArray2.default)(tasks)) return callback(new TypeError('First argument to race must be an array of functions'));
  53. if (!tasks.length) return callback();
  54. for (var i = 0, l = tasks.length; i < l; i++) {
  55. tasks[i](callback);
  56. }
  57. }
  58. module.exports = exports['default'];