2013-06-12 01:41:21 +00: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/.
|
|
|
|
*
|
|
|
|
* The origin of this IDL file is
|
2013-07-11 20:40:36 +00:00
|
|
|
* http://dom.spec.whatwg.org/#promises
|
2013-06-12 01:41:21 +00:00
|
|
|
*/
|
|
|
|
|
2013-09-11 16:03:04 +00:00
|
|
|
// TODO We use object instead Function. There is an open issue on WebIDL to
|
|
|
|
// have different types for "platform-provided function" and "user-provided
|
|
|
|
// function"; for now, we just use "object".
|
|
|
|
callback PromiseInit = void (object resolve, object reject);
|
2014-01-28 18:14:57 +00:00
|
|
|
|
2016-02-09 22:40:31 +00:00
|
|
|
callback PromiseJobCallback = void();
|
|
|
|
|
2014-01-28 18:14:57 +00:00
|
|
|
[TreatNonCallableAsNull]
|
2013-11-19 18:39:51 +00:00
|
|
|
callback AnyCallback = any (any value);
|
2013-06-12 01:41:21 +00:00
|
|
|
|
2016-02-09 22:40:30 +00:00
|
|
|
// When using SpiderMonkey promises, we don't want to define all this stuff;
|
|
|
|
// just define a tiny interface to make codegen of Promise arguments and return
|
|
|
|
// values work.
|
|
|
|
#ifndef SPIDERMONKEY_PROMISE
|
2014-08-05 02:20:34 +00:00
|
|
|
[Constructor(PromiseInit init),
|
2016-03-24 15:12:00 +00:00
|
|
|
Exposed=(Window,Worker,WorkerDebugger,System)]
|
2014-08-01 03:50:30 +00:00
|
|
|
// Need to escape "Promise" so it's treated as an identifier.
|
|
|
|
interface _Promise {
|
2015-11-25 20:48:09 +00:00
|
|
|
// Have to use "any" (or "object", but "any" is simpler) as the type to
|
|
|
|
// support the subclassing behavior, since nothing actually requires the
|
|
|
|
// return value of PromiseSubclass.resolve/reject to be a Promise object.
|
|
|
|
[NewObject, Throws]
|
|
|
|
static any resolve(optional any value);
|
2015-11-25 20:48:09 +00:00
|
|
|
[NewObject, Throws]
|
|
|
|
static any reject(optional any value);
|
2013-06-12 01:41:22 +00:00
|
|
|
|
2014-01-28 18:14:57 +00:00
|
|
|
// The [TreatNonCallableAsNull] annotation is required since then() should do
|
|
|
|
// nothing instead of throwing errors when non-callable arguments are passed.
|
2015-11-25 20:48:10 +00:00
|
|
|
// Have to use "any" (or "object", but "any" is simpler) as the type to
|
|
|
|
// support the subclassing behavior, since nothing actually requires the
|
|
|
|
// return value of PromiseSubclass.then/catch to be a Promise object.
|
|
|
|
[NewObject, Throws]
|
|
|
|
any then([TreatNonCallableAsNull] optional AnyCallback? fulfillCallback = null,
|
|
|
|
[TreatNonCallableAsNull] optional AnyCallback? rejectCallback = null);
|
2013-06-12 01:41:22 +00:00
|
|
|
|
2015-11-25 20:48:10 +00:00
|
|
|
[NewObject, Throws]
|
|
|
|
any catch([TreatNonCallableAsNull] optional AnyCallback? rejectCallback = null);
|
2013-11-19 21:53:00 +00:00
|
|
|
|
2015-11-25 20:48:09 +00:00
|
|
|
// Have to use "any" (or "object", but "any" is simpler) as the type to
|
|
|
|
// support the subclassing behavior, since nothing actually requires the
|
|
|
|
// return value of PromiseSubclass.all to be a Promise object. As a result,
|
|
|
|
// we also have to do our argument conversion manually, because we want to
|
|
|
|
// convert its exceptions into rejections.
|
|
|
|
[NewObject, Throws]
|
|
|
|
static any all(optional any iterable);
|
2013-11-19 21:53:00 +00:00
|
|
|
|
2015-11-25 20:48:09 +00:00
|
|
|
// Have to use "any" (or "object", but "any" is simpler) as the type to
|
|
|
|
// support the subclassing behavior, since nothing actually requires the
|
|
|
|
// return value of PromiseSubclass.race to be a Promise object. As a result,
|
|
|
|
// we also have to do our argument conversion manually, because we want to
|
|
|
|
// convert its exceptions into rejections.
|
|
|
|
[NewObject, Throws]
|
|
|
|
static any race(optional any iterable);
|
2013-06-12 01:41:21 +00:00
|
|
|
};
|
2016-02-09 22:40:30 +00:00
|
|
|
#else // SPIDERMONKEY_PROMISE
|
|
|
|
[NoInterfaceObject,
|
2016-03-30 12:11:07 +00:00
|
|
|
Exposed=(Window,Worker,WorkerDebugger,System)]
|
2016-02-09 22:40:30 +00:00
|
|
|
// Need to escape "Promise" so it's treated as an identifier.
|
|
|
|
interface _Promise {
|
|
|
|
};
|
2016-02-09 22:40:31 +00:00
|
|
|
|
|
|
|
// Hack to allow us to have JS owning and properly tracing/CCing/etc a
|
|
|
|
// PromiseNativeHandler.
|
|
|
|
[NoInterfaceObject,
|
|
|
|
Exposed=(Window,Worker,System)]
|
|
|
|
interface PromiseNativeHandler {
|
|
|
|
};
|
2016-02-09 22:40:30 +00:00
|
|
|
#endif // SPIDERMONKEY_PROMISE
|