diff options
author | Hubert Argasinski <argasinski.hubert@gmail.com> | 2016-03-31 02:22:16 -0700 |
---|---|---|
committer | Graeme Yeates <yeatesgraeme@gmail.com> | 2016-04-12 18:46:28 -0400 |
commit | 8eb2a7cec2c62edf35d7b812765bd64e6b7d484f (patch) | |
tree | 76a0c7715c612acddd9e6801dc14ec43f768176f /lib/seq.js | |
parent | a778ee63788d533111ff63b611cc5034e18a907f (diff) | |
download | async-8eb2a7cec2c62edf35d7b812765bd64e6b7d484f.tar.gz |
jsdoc-style documentation began documenting `Control Flow` methods
remaining `Control Flow` methods to document:
- queue
- priorityQueue
- cargo
- auto
- autoInject
- retry
- retryable
- iterator
- times, timesSeries, timesLimit
- race
Diffstat (limited to 'lib/seq.js')
-rw-r--r-- | lib/seq.js | 36 |
1 files changed, 36 insertions, 0 deletions
@@ -4,6 +4,42 @@ import noop from 'lodash/noop'; import rest from 'lodash/rest'; import reduce from './reduce'; +/** + * Version of the compose function that is more natural to read. Each function + * consumes the return value of the previous function. It is the equivalent of + * [`compose`](#compose) with the arguments reversed. + * + * Each function is executed with the `this` binding of the composed function. + * + * @name seq + * @static + * @memberOf async + * @see `async.compose` + * @category Control Flow + * @param {...Function} functions - the asynchronous functions to compose + * @example + * + * // Requires lodash (or underscore), express3 and dresende's orm2. + * // Part of an app, that fetches cats of the logged user. + * // This example uses `seq` function to avoid overnesting and error + * // handling clutter. + * app.get('/cats', function(request, response) { + * var User = request.models.User; + * async.seq( + * _.bind(User.get, User), // 'User.get' has signature (id, callback(err, data)) + * function(user, fn) { + * user.getCats(fn); // 'getCats' has signature (callback(err, data)) + * } + * )(req.session.user_id, function (err, cats) { + * if (err) { + * console.error(err); + * response.json({ status: 'error', message: err.message }); + * } else { + * response.json({ status: 'ok', message: 'Cats found', data: cats }); + * } + * }); + * }); + */ export default function seq( /* functions... */ ) { var fns = arguments; return rest(function(args) { |