a-sync-waterfall

WebJar for a-sync-waterfall

License

License

MIT
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

a-sync-waterfall
Last Version

Last Version

1.0.1
Release Date

Release Date

Type

Type

jar
Description

Description

a-sync-waterfall
WebJar for a-sync-waterfall
Project URL

Project URL

http://webjars.org
Source Code Management

Source Code Management

https://github.com/hydiak/a-sync-waterfall

Download a-sync-waterfall

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/a-sync-waterfall/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>a-sync-waterfall</artifactId>
    <version>1.0.1</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/a-sync-waterfall/
implementation 'org.webjars.npm:a-sync-waterfall:1.0.1'
// https://jarcasting.com/artifacts/org.webjars.npm/a-sync-waterfall/
implementation ("org.webjars.npm:a-sync-waterfall:1.0.1")
'org.webjars.npm:a-sync-waterfall:jar:1.0.1'
<dependency org="org.webjars.npm" name="a-sync-waterfall" rev="1.0.1">
  <artifact name="a-sync-waterfall" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='a-sync-waterfall', version='1.0.1')
)
libraryDependencies += "org.webjars.npm" % "a-sync-waterfall" % "1.0.1"
[org.webjars.npm/a-sync-waterfall "1.0.1"]

Dependencies

There are no dependencies for this project. It is a standalone project that does not depend on any other jars.

Project Modules

There are no modules declared in this project.

a-sync-waterfall

Simple, isolated sync/async waterfall module for JavaScript.

Runs an array of functions in series, each passing their results to the next in the array. However, if any of the functions pass an error to the callback, the next function is not executed and the main callback is immediately called with the error.

For browsers and node.js.

Installation

  • Just include a-sync-waterfall before your scripts.
  • npm install a-sync-waterfall if you’re using node.js.

Usage

  • waterfall(tasks, optionalCallback, forceAsync);
  • tasks - An array of functions to run, each function is passed a callback(err, result1, result2, ...) it must call on completion. The first argument is an error (which can be null) and any further arguments will be passed as arguments in order to the next task.
  • optionalCallback - An optional callback to run once all the functions have completed. This will be passed the results of the last task's callback.
  • forceAsync An optional flag that force tasks run asynchronously even if they are sync.
Node.js:
var waterfall = require('a-sync-waterfall');
waterfall(tasks, callback);
Browser:
var waterfall = require('a-sync-waterfall');
waterfall(tasks, callback);

// Default:
window.waterfall(tasks, callback);
Tasks as Array of Functions
waterfall([
  function(callback){
    callback(null, 'one', 'two');
  },
  function(arg1, arg2, callback){
    callback(null, 'three');
  },
  function(arg1, callback){
    // arg1 now equals 'three'
    callback(null, 'done');
  }
], function (err, result) {
  // result now equals 'done'
});
Derive Tasks from an Array.map
/* basic - no arguments */
waterfall(myArray.map(function (arrayItem) {
  return function (nextCallback) {
    // same execution for each item, call the next one when done
    doAsyncThingsWith(arrayItem, nextCallback);
}}));

/* with arguments, initializer function, and final callback */
waterfall([function initializer (firstMapFunction) {
    firstMapFunction(null, initialValue);
  }].concat(myArray.map(function (arrayItem) {
    return function (lastItemResult, nextCallback) {
      // same execution for each item in the array
      var itemResult = doThingsWith(arrayItem, lastItemResult);
      // results carried along from each to the next
      nextCallback(null, itemResult);
}})), function (err, finalResult) {
  // final callback
});

Acknowledgements

Hat tip to Caolan McMahon and Paul Miller, whose prior contributions this is based upon. Also Elan Shanker from which this rep is forked

License

MIT

Versions

Version
1.0.1
1.0.0