diff options
author | Moonchild <moonchild@palemoon.org> | 2020-06-11 08:51:07 +0000 |
---|---|---|
committer | Moonchild <moonchild@palemoon.org> | 2020-06-11 08:51:07 +0000 |
commit | fdc11c731c0d0176c4522f1eb8b1d390d6505c6d (patch) | |
tree | 09ee62a28ee25de80a1c5b14b9d2931cbb7036a0 /dom/fetch/FetchObserver.cpp | |
parent | ec792e2ac7614b8e4281f496d288f20441b837bf (diff) | |
download | UXP-fdc11c731c0d0176c4522f1eb8b1d390d6505c6d.tar UXP-fdc11c731c0d0176c4522f1eb8b1d390d6505c6d.tar.gz UXP-fdc11c731c0d0176c4522f1eb8b1d390d6505c6d.tar.lz UXP-fdc11c731c0d0176c4522f1eb8b1d390d6505c6d.tar.xz UXP-fdc11c731c0d0176c4522f1eb8b1d390d6505c6d.zip |
Issue #1587 - Part 5: Hook FetchObserver up to the Fetch API
Diffstat (limited to 'dom/fetch/FetchObserver.cpp')
-rw-r--r-- | dom/fetch/FetchObserver.cpp | 57 |
1 files changed, 54 insertions, 3 deletions
diff --git a/dom/fetch/FetchObserver.cpp b/dom/fetch/FetchObserver.cpp index bc8c6fc2b..982f0ad49 100644 --- a/dom/fetch/FetchObserver.cpp +++ b/dom/fetch/FetchObserver.cpp @@ -6,6 +6,7 @@ #include "FetchObserver.h" #include "WorkerPrivate.h" +#include "mozilla/dom/Event.h" namespace mozilla { namespace dom { @@ -45,10 +46,14 @@ FetchObserver::IsEnabled(JSContext* aCx, JSObject* aGlobal) } FetchObserver::FetchObserver(nsIGlobalObject* aGlobal, - FetchState aState) + FetchSignal* aSignal) : DOMEventTargetHelper(aGlobal) - , mState(aState) -{} + , mState(FetchState::Requesting) +{ + if (aSignal) { + Follow(aSignal); + } +} JSObject* FetchObserver::WrapObject(JSContext* aCx, JS::Handle<JSObject*> aGivenProto) @@ -62,5 +67,51 @@ FetchObserver::State() const return mState; } +void +FetchObserver::Aborted() +{ + SetState(FetchState::Aborted); +} + +void +FetchObserver::SetState(FetchState aState) +{ + MOZ_ASSERT(mState < aState); + + if (mState == FetchState::Aborted || + mState == FetchState::Errored || + mState == FetchState::Complete) { + // We are already in a final state. + return; + } + + // We cannot pass from Requesting to Complete directly. + if (mState == FetchState::Requesting && + aState == FetchState::Complete) { + SetState(FetchState::Responding); + } + + mState = aState; + + if (mState == FetchState::Aborted || + mState == FetchState::Errored || + mState == FetchState::Complete) { + Unfollow(); + } + + EventInit init; + init.mBubbles = false; + init.mCancelable = false; + + // TODO which kind of event should we dispatch here? + + RefPtr<Event> event = + Event::Constructor(this, NS_LITERAL_STRING("statechange"), init); + event->SetTrusted(true); + + bool dummy; + DispatchEvent(event, &dummy); +} + } // dom namespace } // mozilla namespace |