2014-07-02 08:19:48 +04:00
|
|
|
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
|
|
* You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* This is a utility namespace for promise-debugging functionality */
|
|
|
|
|
|
|
|
|
|
|
|
dictionary PromiseDebuggingStateHolder {
|
|
|
|
PromiseDebuggingState state = "pending";
|
|
|
|
any value;
|
|
|
|
any reason;
|
|
|
|
};
|
|
|
|
enum PromiseDebuggingState { "pending", "fulfilled", "rejected" };
|
|
|
|
|
2014-10-17 19:30:19 +04:00
|
|
|
[ChromeOnly, Exposed=(Window,System)]
|
2014-07-02 08:19:48 +04:00
|
|
|
interface PromiseDebugging {
|
2014-08-01 07:50:30 +04:00
|
|
|
static PromiseDebuggingStateHolder getState(Promise<any> p);
|
2014-10-20 06:27:12 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the stack to the promise's allocation point. This can
|
|
|
|
* return null if the promise was not created from script.
|
|
|
|
*/
|
|
|
|
static object? getAllocationStack(Promise<any> p);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the stack to the promise's rejection point, if the
|
|
|
|
* rejection happened from script. This can return null if the
|
|
|
|
* promise has not been rejected or was not rejected from script.
|
|
|
|
*/
|
|
|
|
static object? getRejectionStack(Promise<any> p);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the stack to the promise's fulfillment point, if the
|
|
|
|
* fulfillment happened from script. This can return null if the
|
|
|
|
* promise has not been fulfilled or was not fulfilled from script.
|
|
|
|
*/
|
|
|
|
static object? getFullfillmentStack(Promise<any> p);
|
2014-07-02 08:19:48 +04:00
|
|
|
};
|