AhMyth 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
..
.editorconfig 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
.gitattributes 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
.jshintrc 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
.npmignore 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
.travis.yml 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
LICENSE 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
README.md 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
index.js 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
package.json 9000392778 beta version %!s(int64=8) %!d(string=hai) anos
test.js 9000392778 beta version %!s(int64=8) %!d(string=hai) anos

README.md

Run Async

npm tests dependencies

Utility method to run function either synchronously or asynchronously using the common this.async() style.

This is useful for library author accepting sync or async functions as parameter. runAsync will always run them as async method, and normalize the function handling.

Installation

npm install --save run-async

Usage

var runAsync = require('run-async');

// In Async mode:
var asyncFn = function (a) {
  var done = this.async();

  setTimeout(function () {
    done('running: ' + a);
  }, 10);
};

runAsync(asyncFn, function (answer) {
  console.log(answer); // 'running: async'
}, 'async');

// In Sync mode:
var syncFn = function (a) {
  return 'running: ' + a;
};

runAsync(asyncFn, function (answer) {
  console.log(answer); // 'running: sync'
}, 'sync');

Licence

Copyright (c) 2014 Simon Boudrias (twitter: @vaxilart)
Licensed under the MIT license.