Bug 1698468 - Add AbortSignal.abort() r=smaug

Differential Revision: https://phabricator.services.mozilla.com/D108503
This commit is contained in:
Kagami Sascha Rosylight 2021-03-15 20:46:53 +00:00
Родитель fa8747857b
Коммит a9e13dca62
4 изменённых файлов: 15 добавлений и 0 удалений

Просмотреть файл

@ -84,6 +84,12 @@ JSObject* AbortSignal::WrapObject(JSContext* aCx,
return AbortSignal_Binding::Wrap(aCx, this, aGivenProto);
}
already_AddRefed<AbortSignal> AbortSignal::Abort(GlobalObject& aGlobal) {
nsCOMPtr<nsIGlobalObject> global = do_QueryInterface(aGlobal.GetAsSupports());
RefPtr<AbortSignal> abortSignal = new AbortSignal(global, true);
return abortSignal.forget();
}
// https://dom.spec.whatwg.org/#abortsignal-signal-abort
void AbortSignal::SignalAbort() {
// Steps 1-4.

Просмотреть файл

@ -39,6 +39,8 @@ class AbortSignal final : public DOMEventTargetHelper,
IMPL_EVENT_HANDLER(abort);
static already_AddRefed<AbortSignal> Abort(GlobalObject& aGlobal);
// AbortSignalImpl
void SignalAbort() override;

Просмотреть файл

@ -9,6 +9,8 @@
[Exposed=(Window,Worker)]
interface AbortSignal : EventTarget {
[NewObject] static AbortSignal abort();
readonly attribute boolean aborted;
attribute EventHandler onabort;

Просмотреть файл

@ -64,4 +64,9 @@ test(t => {
controller.abort();
}, "the abort event should have the right properties");
test(t => {
const signal = AbortSignal.abort();
assert_true(signal.aborted);
}, "the AbortSignal.abort() static returns an already aborted signal");
done();