Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1)

Side by Side Diff: Source/core/loader/WorkerThreadableLoader.cpp

Issue 1264453002: Split the constructor of ThreadableLoader into two methods (ctor and start()) (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698