Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2009, 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2009, 2010 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 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 46 #include "platform/network/ResourceResponse.h" | 46 #include "platform/network/ResourceResponse.h" |
| 47 #include "platform/weborigin/SecurityPolicy.h" | 47 #include "platform/weborigin/SecurityPolicy.h" |
| 48 #include "public/platform/Platform.h" | 48 #include "public/platform/Platform.h" |
| 49 #include "public/platform/WebWaitableEvent.h" | 49 #include "public/platform/WebWaitableEvent.h" |
| 50 #include "wtf/MainThread.h" | 50 #include "wtf/MainThread.h" |
| 51 #include "wtf/OwnPtr.h" | 51 #include "wtf/OwnPtr.h" |
| 52 #include "wtf/Vector.h" | 52 #include "wtf/Vector.h" |
| 53 | 53 |
| 54 namespace blink { | 54 namespace blink { |
| 55 | 55 |
| 56 WorkerThreadableLoader::WorkerThreadableLoader(WorkerGlobalScope& workerGlobalSc ope, PassRefPtr<ThreadableLoaderClientWrapper> clientWrapper, PassOwnPtr<Threada bleLoaderClient> clientBridge, const ResourceRequest& request, const ThreadableL oaderOptions& options, const ResourceLoaderOptions& resourceLoaderOptions) | 56 WorkerThreadableLoader::WorkerThreadableLoader(WorkerGlobalScope& workerGlobalSc ope, PassRefPtr<ThreadableLoaderClientWrapper> clientWrapper, PassOwnPtr<Threada bleLoaderClient> clientBridge, const ThreadableLoaderOptions& options, const Res ourceLoaderOptions& resourceLoaderOptions) |
| 57 : m_workerGlobalScope(&workerGlobalScope) | 57 : m_workerGlobalScope(&workerGlobalScope) |
| 58 , m_workerClientWrapper(clientWrapper) | 58 , m_workerClientWrapper(clientWrapper) |
| 59 , m_bridge(*(new MainThreadBridge(m_workerClientWrapper, clientBridge, worke rGlobalScope.thread()->workerLoaderProxy(), request, options, resourceLoaderOpti ons, workerGlobalScope.referrerPolicy(), workerGlobalScope.url().strippedForUseA sReferrer()))) | 59 , m_bridge(*(new MainThreadBridge(m_workerClientWrapper, clientBridge, worke rGlobalScope.thread()->workerLoaderProxy(), options, resourceLoaderOptions))) |
| 60 { | 60 { |
| 61 m_workerClientWrapper->setResourceTimingClient(this); | |
| 62 } | 61 } |
| 63 | 62 |
| 64 WorkerThreadableLoader::~WorkerThreadableLoader() | 63 WorkerThreadableLoader::~WorkerThreadableLoader() |
| 65 { | 64 { |
| 66 m_workerClientWrapper->clearResourceTimingClient(); | 65 m_workerClientWrapper->clearResourceTimingClient(); |
| 67 m_bridge.destroy(); | 66 m_bridge.destroy(); |
| 68 } | 67 } |
| 69 | 68 |
| 70 void WorkerThreadableLoader::loadResourceSynchronously(WorkerGlobalScope& worker GlobalScope, const ResourceRequest& request, ThreadableLoaderClient& client, con st ThreadableLoaderOptions& options, const ResourceLoaderOptions& resourceLoader Options) | 69 void WorkerThreadableLoader::loadResourceSynchronously(WorkerGlobalScope& worker GlobalScope, const ResourceRequest& request, ThreadableLoaderClient& client, con st ThreadableLoaderOptions& options, const ResourceLoaderOptions& resourceLoader Options) |
| 71 { | 70 { |
| 72 WebWaitableEvent* shutdownEvent = | 71 WebWaitableEvent* shutdownEvent = |
| 73 workerGlobalScope.thread()->shutdownEvent(); | 72 workerGlobalScope.thread()->shutdownEvent(); |
| 74 OwnPtr<WebWaitableEvent> loaderDone = | 73 OwnPtr<WebWaitableEvent> loaderDone = |
| 75 adoptPtr(Platform::current()->createWaitableEvent()); | 74 adoptPtr(Platform::current()->createWaitableEvent()); |
| 76 | 75 |
| 77 Vector<WebWaitableEvent*> events; | 76 Vector<WebWaitableEvent*> events; |
| 78 events.append(shutdownEvent); | 77 events.append(shutdownEvent); |
| 79 events.append(loaderDone.get()); | 78 events.append(loaderDone.get()); |
| 80 | 79 |
| 81 RefPtr<ThreadableLoaderClientWrapper> clientWrapper(ThreadableLoaderClientWr apper::create(&client)); | 80 RefPtr<ThreadableLoaderClientWrapper> clientWrapper(ThreadableLoaderClientWr apper::create(&client)); |
| 82 OwnPtr<WorkerLoaderClientBridgeSyncHelper> clientBridge(WorkerLoaderClientBr idgeSyncHelper::create(clientWrapper.get(), loaderDone.release())); | 81 OwnPtr<WorkerLoaderClientBridgeSyncHelper> clientBridge(WorkerLoaderClientBr idgeSyncHelper::create(clientWrapper.get(), loaderDone.release())); |
| 83 | 82 |
| 84 // This must be valid while loader is around. | 83 // This must be valid while loader is around. |
| 85 WorkerLoaderClientBridgeSyncHelper* clientBridgePtr = clientBridge.get(); | 84 WorkerLoaderClientBridgeSyncHelper* clientBridgePtr = clientBridge.get(); |
| 86 | 85 |
| 87 RefPtr<WorkerThreadableLoader> loader = WorkerThreadableLoader::create(worke rGlobalScope, clientWrapper, clientBridge.release(), request, options, resourceL oaderOptions); | 86 RefPtr<WorkerThreadableLoader> loader = WorkerThreadableLoader::create(worke rGlobalScope, clientWrapper, clientBridge.release(), options, resourceLoaderOpti ons); |
| 87 loader->start(request); | |
| 88 | 88 |
| 89 WebWaitableEvent* signalled; | 89 WebWaitableEvent* signalled; |
| 90 { | 90 { |
| 91 SafePointScope scope(ThreadState::HeapPointersOnStack); | 91 SafePointScope scope(ThreadState::HeapPointersOnStack); |
| 92 signalled = Platform::current()->waitMultipleEvents(events); | 92 signalled = Platform::current()->waitMultipleEvents(events); |
| 93 } | 93 } |
| 94 if (signalled == shutdownEvent) { | 94 if (signalled == shutdownEvent) { |
| 95 loader->cancel(); | 95 loader->cancel(); |
| 96 return; | 96 return; |
| 97 } | 97 } |
| 98 | 98 |
| 99 clientBridgePtr->run(); | 99 clientBridgePtr->run(); |
| 100 } | 100 } |
| 101 | 101 |
| 102 void WorkerThreadableLoader::start(const ResourceRequest& request) | |
| 103 { | |
| 104 m_bridge.start(request, m_workerGlobalScope->referrerPolicy(), m_workerGloba lScope->url().strippedForUseAsReferrer()); | |
| 105 m_workerClientWrapper->setResourceTimingClient(this); | |
| 106 } | |
| 107 | |
| 102 void WorkerThreadableLoader::overrideTimeout(unsigned long timeoutMilliseconds) | 108 void WorkerThreadableLoader::overrideTimeout(unsigned long timeoutMilliseconds) |
| 103 { | 109 { |
| 104 m_bridge.overrideTimeout(timeoutMilliseconds); | 110 m_bridge.overrideTimeout(timeoutMilliseconds); |
| 105 } | 111 } |
| 106 | 112 |
| 107 void WorkerThreadableLoader::cancel() | 113 void WorkerThreadableLoader::cancel() |
| 108 { | 114 { |
| 109 m_bridge.cancel(); | 115 m_bridge.cancel(); |
| 110 } | 116 } |
| 111 | 117 |
| 112 void WorkerThreadableLoader::didReceiveResourceTiming(const ResourceTimingInfo& info) | 118 void WorkerThreadableLoader::didReceiveResourceTiming(const ResourceTimingInfo& info) |
| 113 { | 119 { |
| 114 WorkerGlobalScopePerformance::performance(*m_workerGlobalScope)->addResource Timing(info); | 120 WorkerGlobalScopePerformance::performance(*m_workerGlobalScope)->addResource Timing(info); |
| 115 } | 121 } |
| 116 | 122 |
| 117 WorkerThreadableLoader::MainThreadBridge::MainThreadBridge( | 123 WorkerThreadableLoader::MainThreadBridge::MainThreadBridge( |
| 118 PassRefPtr<ThreadableLoaderClientWrapper> workerClientWrapper, | 124 PassRefPtr<ThreadableLoaderClientWrapper> workerClientWrapper, |
| 119 PassOwnPtr<ThreadableLoaderClient> clientBridge, | 125 PassOwnPtr<ThreadableLoaderClient> clientBridge, |
| 120 PassRefPtr<WorkerLoaderProxy> loaderProxy, | 126 PassRefPtr<WorkerLoaderProxy> loaderProxy, |
| 121 const ResourceRequest& request, | |
| 122 const ThreadableLoaderOptions& options, | 127 const ThreadableLoaderOptions& options, |
| 123 const ResourceLoaderOptions& resourceLoaderOptions, | 128 const ResourceLoaderOptions& resourceLoaderOptions) |
| 124 const ReferrerPolicy referrerPolicy, | |
| 125 const String& outgoingReferrer) | |
| 126 : m_clientBridge(clientBridge) | 129 : m_clientBridge(clientBridge) |
| 127 , m_workerClientWrapper(workerClientWrapper) | 130 , m_workerClientWrapper(workerClientWrapper) |
| 128 , m_loaderProxy(loaderProxy) | 131 , m_loaderProxy(loaderProxy) |
| 129 { | 132 { |
| 130 ASSERT(m_workerClientWrapper.get()); | 133 ASSERT(m_workerClientWrapper.get()); |
| 131 ASSERT(m_clientBridge.get()); | 134 ASSERT(m_clientBridge.get()); |
| 132 m_loaderProxy->postTaskToLoader( | 135 m_loaderProxy->postTaskToLoader( |
| 133 createCrossThreadTask(&MainThreadBridge::mainThreadCreateLoader, this, r equest, options, resourceLoaderOptions, referrerPolicy, outgoingReferrer)); | 136 createCrossThreadTask(&MainThreadBridge::mainThreadCreateLoader, this, o ptions, resourceLoaderOptions)); |
| 134 } | 137 } |
| 135 | 138 |
| 136 WorkerThreadableLoader::MainThreadBridge::~MainThreadBridge() | 139 WorkerThreadableLoader::MainThreadBridge::~MainThreadBridge() |
| 137 { | 140 { |
| 138 } | 141 } |
| 139 | 142 |
| 140 void WorkerThreadableLoader::MainThreadBridge::mainThreadCreateLoader(PassOwnPtr <CrossThreadResourceRequestData> requestData, ThreadableLoaderOptions options, R esourceLoaderOptions resourceLoaderOptions, const ReferrerPolicy referrerPolicy, const String& outgoingReferrer, ExecutionContext* context) | 143 void WorkerThreadableLoader::MainThreadBridge::mainThreadCreateLoader(Threadable LoaderOptions options, ResourceLoaderOptions resourceLoaderOptions, ExecutionCon text* context) |
| 141 { | 144 { |
| 142 ASSERT(isMainThread()); | 145 ASSERT(isMainThread()); |
| 143 Document* document = toDocument(context); | 146 Document* document = toDocument(context); |
| 144 | 147 |
| 148 resourceLoaderOptions.requestInitiatorContext = WorkerContext; | |
| 149 m_mainThreadLoader = DocumentThreadableLoader::create(*document, this, optio ns, resourceLoaderOptions); | |
| 150 ASSERT(m_mainThreadLoader); | |
| 151 } | |
| 152 | |
| 153 void WorkerThreadableLoader::MainThreadBridge::mainThreadStart(PassOwnPtr<CrossT hreadResourceRequestData> requestData, const ReferrerPolicy referrerPolicy, cons t String& outgoingReferrer) | |
| 154 { | |
| 155 ASSERT(isMainThread()); | |
| 156 | |
| 157 if (!m_mainThreadLoader) | |
|
hiroshige
2015/07/30 12:07:21
When can |m_mainThreadLoader| be null? Please add
tyoshino (SeeGerritForStatus)
2015/07/31 08:00:42
Good point. As we require start() to be always cal
| |
| 158 return; | |
| 159 | |
| 145 OwnPtr<ResourceRequest> request(ResourceRequest::adopt(requestData)); | 160 OwnPtr<ResourceRequest> request(ResourceRequest::adopt(requestData)); |
| 146 request->setHTTPReferrer(SecurityPolicy::generateReferrer(referrerPolicy, re quest->url(), outgoingReferrer)); | 161 request->setHTTPReferrer(SecurityPolicy::generateReferrer(referrerPolicy, re quest->url(), outgoingReferrer)); |
| 147 resourceLoaderOptions.requestInitiatorContext = WorkerContext; | 162 |
| 148 m_mainThreadLoader = DocumentThreadableLoader::create(*document, this, *requ est, options, resourceLoaderOptions); | 163 m_mainThreadLoader->start(*request); |
| 149 if (!m_mainThreadLoader) { | 164 } |
| 150 // DocumentThreadableLoader::create may return 0 when the document loade r has been already changed. | 165 |
| 151 didFail(ResourceError(errorDomainBlinkInternal, 0, request->url().string (), "Can't create DocumentThreadableLoader")); | 166 void WorkerThreadableLoader::MainThreadBridge::start(const ResourceRequest& requ est, const ReferrerPolicy referrerPolicy, const String& outgoingReferrer) |
| 152 } | 167 { |
| 168 m_loaderProxy->postTaskToLoader( | |
| 169 createCrossThreadTask(&MainThreadBridge::mainThreadStart, this, request, referrerPolicy, outgoingReferrer)); | |
| 153 } | 170 } |
| 154 | 171 |
| 155 void WorkerThreadableLoader::MainThreadBridge::mainThreadDestroy(ExecutionContex t* context) | 172 void WorkerThreadableLoader::MainThreadBridge::mainThreadDestroy(ExecutionContex t* context) |
| 156 { | 173 { |
| 157 ASSERT(isMainThread()); | 174 ASSERT(isMainThread()); |
| 158 ASSERT_UNUSED(context, context->isDocument()); | 175 ASSERT_UNUSED(context, context->isDocument()); |
| 159 delete this; | 176 delete this; |
| 160 } | 177 } |
| 161 | 178 |
| 162 void WorkerThreadableLoader::MainThreadBridge::destroy() | 179 void WorkerThreadableLoader::MainThreadBridge::destroy() |
| (...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 261 { | 278 { |
| 262 m_clientBridge->didFailRedirectCheck(); | 279 m_clientBridge->didFailRedirectCheck(); |
| 263 } | 280 } |
| 264 | 281 |
| 265 void WorkerThreadableLoader::MainThreadBridge::didReceiveResourceTiming(const Re sourceTimingInfo& info) | 282 void WorkerThreadableLoader::MainThreadBridge::didReceiveResourceTiming(const Re sourceTimingInfo& info) |
| 266 { | 283 { |
| 267 m_clientBridge->didReceiveResourceTiming(info); | 284 m_clientBridge->didReceiveResourceTiming(info); |
| 268 } | 285 } |
| 269 | 286 |
| 270 } // namespace blink | 287 } // namespace blink |
| OLD | NEW |