diff options
author | Florian Dold <florian.dold@gmail.com> | 2017-05-03 15:35:00 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2017-05-03 15:35:00 +0200 |
commit | de98e0b232509d5f40c135d540a70e415272ff85 (patch) | |
tree | a79222a5b58484ab3b80d18efcaaa7ccc4769b33 /node_modules/fbjs/lib/Deferred.js.flow | |
parent | e0c9d480a73fa629c1e4a47d3e721f1d2d345406 (diff) |
node_modules
Diffstat (limited to 'node_modules/fbjs/lib/Deferred.js.flow')
-rw-r--r-- | node_modules/fbjs/lib/Deferred.js.flow | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/node_modules/fbjs/lib/Deferred.js.flow b/node_modules/fbjs/lib/Deferred.js.flow new file mode 100644 index 000000000..aaad67b5c --- /dev/null +++ b/node_modules/fbjs/lib/Deferred.js.flow @@ -0,0 +1,75 @@ +/** + * Copyright (c) 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + * @providesModule Deferred + * @typechecks + * @flow + */ + +/** + * Deferred provides a Promise-like API that exposes methods to resolve and + * reject the Promise. It is most useful when converting non-Promise code to use + * Promises. + * + * If you want to export the Promise without exposing access to the resolve and + * reject methods, you should export `getPromise` which returns a Promise with + * the same semantics excluding those methods. + */ +class Deferred<Tvalue, Treason> { + _settled: boolean; + _promise: Promise<any>; + _resolve: (value: Tvalue) => void; + _reject: (reason: Treason) => void; + + constructor() { + this._settled = false; + this._promise = new Promise((resolve, reject) => { + this._resolve = (resolve: any); + this._reject = (reject: any); + }); + } + + getPromise(): Promise<any> { + return this._promise; + } + + resolve(value: Tvalue): void { + this._settled = true; + this._resolve(value); + } + + reject(reason: Treason): void { + this._settled = true; + this._reject(reason); + } + + catch(): Promise<any> { + return Promise.prototype.catch.apply(this._promise, arguments); + } + + then(): Promise<any> { + return Promise.prototype.then.apply(this._promise, arguments); + } + + done(): void { + // Embed the polyfill for the non-standard Promise.prototype.done so that + // users of the open source fbjs don't need a custom lib for Promise + const promise = arguments.length ? this._promise.then.apply(this._promise, arguments) : this._promise; + promise.then(undefined, function (err) { + setTimeout(function () { + throw err; + }, 0); + }); + } + + isSettled(): boolean { + return this._settled; + } +} + +module.exports = Deferred;
\ No newline at end of file |