| 'use strict'; | 
|   | 
| Object.defineProperty(exports, "__esModule", { | 
|     value: true | 
| }); | 
| exports.default = forever; | 
|   | 
| var _noop = require('lodash/noop'); | 
|   | 
| var _noop2 = _interopRequireDefault(_noop); | 
|   | 
| var _onlyOnce = require('./internal/onlyOnce'); | 
|   | 
| var _onlyOnce2 = _interopRequireDefault(_onlyOnce); | 
|   | 
| var _ensureAsync = require('./ensureAsync'); | 
|   | 
| var _ensureAsync2 = _interopRequireDefault(_ensureAsync); | 
|   | 
| var _wrapAsync = require('./internal/wrapAsync'); | 
|   | 
| var _wrapAsync2 = _interopRequireDefault(_wrapAsync); | 
|   | 
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | 
|   | 
| /** | 
|  * Calls the asynchronous function `fn` with a callback parameter that allows it | 
|  * to call itself again, in series, indefinitely. | 
|   | 
|  * If an error is passed to the callback then `errback` is called with the | 
|  * error, and execution stops, otherwise it will never be called. | 
|  * | 
|  * @name forever | 
|  * @static | 
|  * @memberOf module:ControlFlow | 
|  * @method | 
|  * @category Control Flow | 
|  * @param {AsyncFunction} fn - an async function to call repeatedly. | 
|  * Invoked with (next). | 
|  * @param {Function} [errback] - when `fn` passes an error to it's callback, | 
|  * this function will be called, and execution stops. Invoked with (err). | 
|  * @example | 
|  * | 
|  * async.forever( | 
|  *     function(next) { | 
|  *         // next is suitable for passing to things that need a callback(err [, whatever]); | 
|  *         // it will result in this function being called again. | 
|  *     }, | 
|  *     function(err) { | 
|  *         // if next is called with a value in its first parameter, it will appear | 
|  *         // in here as 'err', and execution will stop. | 
|  *     } | 
|  * ); | 
|  */ | 
| function forever(fn, errback) { | 
|     var done = (0, _onlyOnce2.default)(errback || _noop2.default); | 
|     var task = (0, _wrapAsync2.default)((0, _ensureAsync2.default)(fn)); | 
|   | 
|     function next(err) { | 
|         if (err) return done(err); | 
|         task(next); | 
|     } | 
|     next(); | 
| } | 
| module.exports = exports['default']; |