invoke is a dead simple asynchronous flow control micro-library. Sequential (.then) and parallel (.and) async functions can be chained into simple steps:
invoke(function (data, callback) {
// I'm an async function!
}).and(function (data, callback) {
// I am too! I execute in parallel with the first function.
}).then(function (data, callback) {
// I run after both of the parallel functions have called back. Their results
// are passed to me as an array via the data arg.
}).rescue(function (err) {
// I'll be invoked if any functions in the call chain call back with an error.
}).end(initialData, function (data) {
// Calling .end initiates invocation of the set of chained steps. The final result
// is passed to this callback.
});
Because I can.
This library is an experiment in flow control, chained APIs, and minimal JS syntax (yes, I skipped all those semi-colons on purpose).
invoke can be installed via npm:
npm install invoke
The API is exposed as a single function that generates a chainable Invocable object.
var invoke = require('invoke');
invoke(function (data, callback) {
somethingAsync(function (err, results) {
callback(err, results);
});
}).then(function (data, callback) {
// and so forth
Take a look at the examples.
Adds a function as a sequential step. This function will not be invoked until all previous steps have called back, and later steps will not be invoked until this function calls back.
- data - The result of the previous step. If the previous step was sequential, this is the value passed by the previous step's callback. If the previous step was parallel, it is an array of the values passed by the callbacks of the parallel functions.
- callback(err, results) - Function to be invoked once with either an error or the results of this step.
Adds a function as a parallel step. This function will not be invoked in parallel with any other functions chained with .and immediately before or immediately after this .and call.
- data - The result of the previous step. If the previous step was sequential, this is the value passed by the previous step's callback. If the previous step was parallel, it is an array of the values passed by the callbacks of the parallel functions.
- callback(err, results) - Function to be invoked once with either an error or the results of this step.
Adds an error handler. This function will be invoked once if any function in the call chain calls back with an error.
- err - The error.
Adds a final callback and initiates invocation of the function steps defined in the chain. initialValue
is the initial value passed as the first argument into the first function step.
- data - The result of the previous (final) step. If the previous step was sequential, this is the value passed by the previous step's callback. If the previous step was parallel, it is an array of the values passed by the callbacks of the parallel functions.
Install dev dependencies
$ npm install -d
$ npm test
$ npm run-script build
invoke.js is MIT licensed. See LICENSE.