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

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

Powered by Google App Engine
This is Rietveld 408576698