promisify-patch

1.0.10 • Public • Published

promisify-patch

Will wrap node-style callback methods as a promise.

Browser: If you use this in the browser (via browserify), you should have an ES6-shim that includes a Promise implementation loaded before this library.

Installation

npm install promisify-patch

Promise implementation

This project does not install any promise implementation itself or as a dependency. If you are running an older version of node that does not implement promises, this module will attempt to load one of the following (in order). es6-promise, es6-promises, bluebird, Q.

In the browser (via browserify), no promise implementation will be loaded by this module. You should use an appropriate ES6 shim that provides a global Promise class/method.

Should you want to access the promise detection/use that this module uses, you can do so.

var Promise = require('promisify-patch').getPromiseImplementation();
if (typeof Promise !== 'function') throw new Error("No Promise implementation available.');
...
  return new Promise(function(resolve, reject){
    ...
  });

Usage

Single Use:

var promisify = require('promisify-patch');

promisify(fs.readdir, '/some/path')
    //.then
    //.catch
    ;

Patch Use

//only needs to be done once
require('promisify-patch').patch(); //adds itself as Function.prototype.promise

//somewhere ehlse
fs.readdir.promise('/some/path')
    //.then
    //.catch
    ;

//if you need to call a method bound against an object context
return context.foo.bind(context).promise(...);

NOTE: if you have a method that needs to be bound to a context object, you will need to explicitely bind it before .promise. (ex: return context.foo.bind(context).promise(...);)

Package Sidebar

Install

npm i promisify-patch

Weekly Downloads

9

Version

1.0.10

License

ISC

Last publish

Collaborators

  • tracker1