#include "bindings/v8/ScriptFunction.h"
#include "bindings/v8/ScriptPromise.h"
#include "bindings/v8/ScriptValue.h"
+#include "bindings/v8/V8Binding.h"
#include "core/dom/ExecutionContext.h"
#include "platform/NotImplemented.h"
+#include "public/platform/WebServiceWorkerEventResult.h"
#include "wtf/Assertions.h"
#include "wtf/RefCounted.h"
#include "wtf/RefPtr.h"
if (m_resolveType == Rejected)
m_observer->reportError(value);
m_observer->decrementPendingActivity();
- m_observer = 0;
+ m_observer = nullptr;
return value;
}
ResolveType m_resolveType;
};
-PassRefPtr<WaitUntilObserver> WaitUntilObserver::create(ExecutionContext* context, int eventID)
+PassRefPtr<WaitUntilObserver> WaitUntilObserver::create(ExecutionContext* context, EventType type, int eventID)
{
- return adoptRef(new WaitUntilObserver(context, eventID));
+ return adoptRef(new WaitUntilObserver(context, type, eventID));
}
WaitUntilObserver::~WaitUntilObserver()
void WaitUntilObserver::waitUntil(const ScriptValue& value)
{
incrementPendingActivity();
- ScriptPromise(value).then(
+ ScriptPromise::cast(value).then(
ThenFunction::create(this, ThenFunction::Fulfilled),
ThenFunction::create(this, ThenFunction::Rejected));
}
-WaitUntilObserver::WaitUntilObserver(ExecutionContext* context, int eventID)
+WaitUntilObserver::WaitUntilObserver(ExecutionContext* context, EventType type, int eventID)
: ContextLifecycleObserver(context)
+ , m_type(type)
, m_eventID(eventID)
, m_pendingActivity(0)
+ , m_hasError(false)
{
}
{
// FIXME: Propagate error message to the client for onerror handling.
notImplemented();
+
+ m_hasError = true;
}
void WaitUntilObserver::incrementPendingActivity()
if (--m_pendingActivity || !executionContext())
return;
- ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleInstallEvent(m_eventID);
+ ServiceWorkerGlobalScopeClient* client = ServiceWorkerGlobalScopeClient::from(executionContext());
+ blink::WebServiceWorkerEventResult result = m_hasError ? blink::WebServiceWorkerEventResultRejected : blink::WebServiceWorkerEventResultCompleted;
+ switch (m_type) {
+ case Activate:
+ client->didHandleActivateEvent(m_eventID, result);
+ break;
+ case Install:
+ client->didHandleInstallEvent(m_eventID, result);
+ break;
+ }
observeContext(0);
}