commit
This commit is contained in:
parent
a70448a434
commit
a15c733e45
55 changed files with 13236 additions and 1 deletions
64
node_modules/bluebird/js/main/timers.js
generated
vendored
Normal file
64
node_modules/bluebird/js/main/timers.js
generated
vendored
Normal file
|
@ -0,0 +1,64 @@
|
|||
"use strict";
|
||||
module.exports = function(Promise, INTERNAL) {
|
||||
var util = require("./util.js");
|
||||
var TimeoutError = Promise.TimeoutError;
|
||||
|
||||
var afterTimeout = function (promise, message) {
|
||||
if (!promise.isPending()) return;
|
||||
|
||||
var err;
|
||||
if(!util.isPrimitive(message) && (message instanceof Error)) {
|
||||
err = message;
|
||||
} else {
|
||||
if (typeof message !== "string") {
|
||||
message = "operation timed out";
|
||||
}
|
||||
err = new TimeoutError(message);
|
||||
}
|
||||
util.markAsOriginatingFromRejection(err);
|
||||
promise._attachExtraTrace(err);
|
||||
promise._cancel(err);
|
||||
};
|
||||
|
||||
var afterValue = function(value) { return delay(+this).thenReturn(value); };
|
||||
var delay = Promise.delay = function (value, ms) {
|
||||
if (ms === undefined) {
|
||||
ms = value;
|
||||
value = undefined;
|
||||
var ret = new Promise(INTERNAL);
|
||||
setTimeout(function() { ret._fulfill(); }, ms);
|
||||
return ret;
|
||||
}
|
||||
ms = +ms;
|
||||
return Promise.resolve(value)._then(afterValue, null, null, ms, undefined);
|
||||
};
|
||||
|
||||
Promise.prototype.delay = function (ms) {
|
||||
return delay(this, ms);
|
||||
};
|
||||
|
||||
function successClear(value) {
|
||||
var handle = this;
|
||||
if (handle instanceof Number) handle = +handle;
|
||||
clearTimeout(handle);
|
||||
return value;
|
||||
}
|
||||
|
||||
function failureClear(reason) {
|
||||
var handle = this;
|
||||
if (handle instanceof Number) handle = +handle;
|
||||
clearTimeout(handle);
|
||||
throw reason;
|
||||
}
|
||||
|
||||
Promise.prototype.timeout = function (ms, message) {
|
||||
ms = +ms;
|
||||
var ret = this.then().cancellable();
|
||||
ret._cancellationParent = this;
|
||||
var handle = setTimeout(function timeoutTimeout() {
|
||||
afterTimeout(ret, message);
|
||||
}, ms);
|
||||
return ret._then(successClear, failureClear, undefined, handle, undefined);
|
||||
};
|
||||
|
||||
};
|
Loading…
Add table
Add a link
Reference in a new issue