Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 124 String origin; | 124 String origin; |
| 125 if (!sourceOrigin.isUnique()) | 125 if (!sourceOrigin.isUnique()) |
| 126 origin = sourceOrigin.toString(); | 126 origin = sourceOrigin.toString(); |
| 127 ServiceWorker* source = ServiceWorker::from(m_workerGlobalScope->getExecutio nContext(), adoptPtr(handle.release())); | 127 ServiceWorker* source = ServiceWorker::from(m_workerGlobalScope->getExecutio nContext(), adoptPtr(handle.release())); |
| 128 WaitUntilObserver* observer = WaitUntilObserver::create(workerGlobalScope(), WaitUntilObserver::Message, eventID); | 128 WaitUntilObserver* observer = WaitUntilObserver::create(workerGlobalScope(), WaitUntilObserver::Message, eventID); |
| 129 | 129 |
| 130 Event* event = ExtendableMessageEvent::create(value, origin, ports, source, observer); | 130 Event* event = ExtendableMessageEvent::create(value, origin, ports, source, observer); |
| 131 workerGlobalScope()->dispatchExtendableEvent(event, observer); | 131 workerGlobalScope()->dispatchExtendableEvent(event, observer); |
| 132 } | 132 } |
| 133 | 133 |
| 134 void ServiceWorkerGlobalScopeProxy::dispatchFetchEvent(int eventID, const WebSer viceWorkerRequest& webRequest) | 134 void ServiceWorkerGlobalScopeProxy::dispatchFetchEvent(int responseEventID, int finishEventID, const WebServiceWorkerRequest& webRequest) |
|
falken
2016/06/06 10:01:40
I feel these names could be improved. responseEven
shimazu
2016/06/09 05:44:21
Done.
| |
| 135 { | 135 { |
| 136 RespondWithObserver* observer = RespondWithObserver::create(workerGlobalScop e(), eventID, webRequest.url(), webRequest.mode(), webRequest.frameType(), webRe quest.requestContext()); | 136 WaitUntilObserver* waitUntilObserver = WaitUntilObserver::create(workerGloba lScope(), WaitUntilObserver::Fetch, finishEventID); |
| 137 RespondWithObserver* respondWithObserver = RespondWithObserver::create(worke rGlobalScope(), responseEventID, webRequest.url(), webRequest.mode(), webRequest .frameType(), webRequest.requestContext(), waitUntilObserver); | |
| 137 Request* request = Request::create(workerGlobalScope()->scriptController()-> getScriptState(), webRequest); | 138 Request* request = Request::create(workerGlobalScope()->scriptController()-> getScriptState(), webRequest); |
| 138 request->getHeaders()->setGuard(Headers::ImmutableGuard); | 139 request->getHeaders()->setGuard(Headers::ImmutableGuard); |
| 139 FetchEventInit eventInit; | 140 FetchEventInit eventInit; |
| 140 eventInit.setCancelable(true); | 141 eventInit.setCancelable(true); |
| 141 eventInit.setRequest(request); | 142 eventInit.setRequest(request); |
| 142 eventInit.setClientId(webRequest.isMainResourceLoad() ? WebString() : webReq uest.clientId()); | 143 eventInit.setClientId(webRequest.isMainResourceLoad() ? WebString() : webReq uest.clientId()); |
| 143 eventInit.setIsReload(webRequest.isReload()); | 144 eventInit.setIsReload(webRequest.isReload()); |
| 144 FetchEvent* fetchEvent = FetchEvent::create(EventTypeNames::fetch, eventInit , observer); | 145 FetchEvent* fetchEvent = FetchEvent::create(EventTypeNames::fetch, eventInit , respondWithObserver, waitUntilObserver); |
| 146 waitUntilObserver->willDispatchEvent(); | |
| 145 DispatchEventResult dispatchResult = workerGlobalScope()->dispatchEvent(fetc hEvent); | 147 DispatchEventResult dispatchResult = workerGlobalScope()->dispatchEvent(fetc hEvent); |
| 146 observer->didDispatchEvent(dispatchResult); | 148 respondWithObserver->didDispatchEvent(dispatchResult); |
| 149 waitUntilObserver->didDispatchEvent(dispatchResult != DispatchEventResult::N otCanceled); | |
| 147 } | 150 } |
| 148 | 151 |
| 149 void ServiceWorkerGlobalScopeProxy::dispatchForeignFetchEvent(int eventID, const WebServiceWorkerRequest& webRequest) | 152 void ServiceWorkerGlobalScopeProxy::dispatchForeignFetchEvent(int responseEventI D, int finishEventID, const WebServiceWorkerRequest& webRequest) |
| 150 { | 153 { |
| 151 RefPtr<SecurityOrigin> origin = SecurityOrigin::create(webRequest.referrerUr l()); | 154 RefPtr<SecurityOrigin> origin = SecurityOrigin::create(webRequest.referrerUr l()); |
| 152 ForeignFetchRespondWithObserver* observer = ForeignFetchRespondWithObserver: :create(workerGlobalScope(), eventID, webRequest.url(), webRequest.mode(), webRe quest.frameType(), webRequest.requestContext(), origin); | 155 WaitUntilObserver* waitUntilObserver = WaitUntilObserver::create(workerGloba lScope(), WaitUntilObserver::Fetch, finishEventID); |
| 156 ForeignFetchRespondWithObserver* respondWithObserver = ForeignFetchRespondWi thObserver::create(workerGlobalScope(), responseEventID, webRequest.url(), webRe quest.mode(), webRequest.frameType(), webRequest.requestContext(), origin, waitU ntilObserver); | |
| 153 Request* request = Request::create(workerGlobalScope()->scriptController()-> getScriptState(), webRequest); | 157 Request* request = Request::create(workerGlobalScope()->scriptController()-> getScriptState(), webRequest); |
| 154 request->getHeaders()->setGuard(Headers::ImmutableGuard); | 158 request->getHeaders()->setGuard(Headers::ImmutableGuard); |
| 155 ForeignFetchEventInit eventInit; | 159 ForeignFetchEventInit eventInit; |
| 156 eventInit.setCancelable(true); | 160 eventInit.setCancelable(true); |
| 157 eventInit.setRequest(request); | 161 eventInit.setRequest(request); |
| 158 eventInit.setOrigin(origin->toString()); | 162 eventInit.setOrigin(origin->toString()); |
| 159 ForeignFetchEvent* fetchEvent = ForeignFetchEvent::create(EventTypeNames::fo reignfetch, eventInit, observer); | 163 ForeignFetchEvent* fetchEvent = ForeignFetchEvent::create(EventTypeNames::fo reignfetch, eventInit, respondWithObserver, waitUntilObserver); |
| 164 waitUntilObserver->willDispatchEvent(); | |
| 160 DispatchEventResult dispatchResult = workerGlobalScope()->dispatchEvent(fetc hEvent); | 165 DispatchEventResult dispatchResult = workerGlobalScope()->dispatchEvent(fetc hEvent); |
| 161 observer->didDispatchEvent(dispatchResult); | 166 respondWithObserver->didDispatchEvent(dispatchResult); |
| 167 waitUntilObserver->didDispatchEvent(dispatchResult != DispatchEventResult::N otCanceled); | |
| 162 } | 168 } |
| 163 | 169 |
| 164 void ServiceWorkerGlobalScopeProxy::dispatchInstallEvent(int eventID) | 170 void ServiceWorkerGlobalScopeProxy::dispatchInstallEvent(int eventID) |
| 165 { | 171 { |
| 166 WaitUntilObserver* observer = WaitUntilObserver::create(workerGlobalScope(), WaitUntilObserver::Install, eventID); | 172 WaitUntilObserver* observer = WaitUntilObserver::create(workerGlobalScope(), WaitUntilObserver::Install, eventID); |
| 167 Event* event; | 173 Event* event; |
| 168 if (RuntimeEnabledFeatures::foreignFetchEnabled()) | 174 if (RuntimeEnabledFeatures::foreignFetchEnabled()) |
| 169 event = InstallEvent::create(EventTypeNames::install, ExtendableEventIni t(), observer); | 175 event = InstallEvent::create(EventTypeNames::install, ExtendableEventIni t(), observer); |
| 170 else | 176 else |
| 171 event = ExtendableEvent::create(EventTypeNames::install, ExtendableEvent Init(), observer); | 177 event = ExtendableEvent::create(EventTypeNames::install, ExtendableEvent Init(), observer); |
| (...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 298 return *m_document; | 304 return *m_document; |
| 299 } | 305 } |
| 300 | 306 |
| 301 ServiceWorkerGlobalScope* ServiceWorkerGlobalScopeProxy::workerGlobalScope() con st | 307 ServiceWorkerGlobalScope* ServiceWorkerGlobalScopeProxy::workerGlobalScope() con st |
| 302 { | 308 { |
| 303 DCHECK(m_workerGlobalScope); | 309 DCHECK(m_workerGlobalScope); |
| 304 return m_workerGlobalScope; | 310 return m_workerGlobalScope; |
| 305 } | 311 } |
| 306 | 312 |
| 307 } // namespace blink | 313 } // namespace blink |
| OLD | NEW |