OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2014 Google Inc. All rights reserved. | 2 * Copyright (C) 2014 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 18 matching lines...) Expand all Loading... |
29 */ | 29 */ |
30 | 30 |
31 #include "config.h" | 31 #include "config.h" |
32 #include "core/loader/WorkerLoaderClientBridgeSyncHelper.h" | 32 #include "core/loader/WorkerLoaderClientBridgeSyncHelper.h" |
33 | 33 |
34 #include "core/workers/WorkerGlobalScope.h" | 34 #include "core/workers/WorkerGlobalScope.h" |
35 #include "core/workers/WorkerLoaderProxy.h" | 35 #include "core/workers/WorkerLoaderProxy.h" |
36 #include "platform/ThreadSafeFunctional.h" | 36 #include "platform/ThreadSafeFunctional.h" |
37 #include "platform/network/ResourceError.h" | 37 #include "platform/network/ResourceError.h" |
38 #include "platform/network/ResourceResponse.h" | 38 #include "platform/network/ResourceResponse.h" |
| 39 #include "platform/network/ResourceTimingInfo.h" |
39 #include "public/platform/WebWaitableEvent.h" | 40 #include "public/platform/WebWaitableEvent.h" |
40 #include "wtf/MainThread.h" | 41 #include "wtf/MainThread.h" |
41 #include "wtf/OwnPtr.h" | 42 #include "wtf/OwnPtr.h" |
42 | 43 |
43 namespace blink { | 44 namespace blink { |
44 | 45 |
45 PassOwnPtr<WorkerLoaderClientBridgeSyncHelper> WorkerLoaderClientBridgeSyncHelpe
r::create(ThreadableLoaderClient& client, PassOwnPtr<WebWaitableEvent> event) | 46 PassOwnPtr<WorkerLoaderClientBridgeSyncHelper> WorkerLoaderClientBridgeSyncHelpe
r::create(ThreadableLoaderClientWrapper* client, PassOwnPtr<WebWaitableEvent> ev
ent) |
46 { | 47 { |
47 return adoptPtr(new WorkerLoaderClientBridgeSyncHelper(client, event)); | 48 return adoptPtr(new WorkerLoaderClientBridgeSyncHelper(client, event)); |
48 } | 49 } |
49 | 50 |
50 WorkerLoaderClientBridgeSyncHelper::~WorkerLoaderClientBridgeSyncHelper() | 51 WorkerLoaderClientBridgeSyncHelper::~WorkerLoaderClientBridgeSyncHelper() |
51 { | 52 { |
52 MutexLocker lock(m_lock); | 53 MutexLocker lock(m_lock); |
53 ASSERT(isMainThread()); | 54 ASSERT(isMainThread()); |
54 for (size_t i = 0; i < m_receivedData.size(); ++i) | 55 for (size_t i = 0; i < m_receivedData.size(); ++i) |
55 delete m_receivedData[i]; | 56 delete m_receivedData[i]; |
56 } | 57 } |
57 | 58 |
58 void WorkerLoaderClientBridgeSyncHelper::run() | 59 void WorkerLoaderClientBridgeSyncHelper::run() |
59 { | 60 { |
60 // This must be called only after m_event is signalled. | 61 // This must be called only after m_event is signalled. |
61 MutexLocker lock(m_lock); | 62 MutexLocker lock(m_lock); |
62 ASSERT(m_done); | 63 ASSERT(m_done); |
63 for (size_t i = 0; i < m_clientTasks.size(); ++i) | 64 for (size_t i = 0; i < m_clientTasks.size(); ++i) |
64 (*m_clientTasks[i])(); | 65 (*m_clientTasks[i])(); |
65 } | 66 } |
66 | 67 |
67 void WorkerLoaderClientBridgeSyncHelper::didSendData(unsigned long long bytesSen
t, unsigned long long totalBytesToBeSent) | 68 void WorkerLoaderClientBridgeSyncHelper::didSendData(unsigned long long bytesSen
t, unsigned long long totalBytesToBeSent) |
68 { | 69 { |
69 MutexLocker lock(m_lock); | 70 MutexLocker lock(m_lock); |
70 ASSERT(isMainThread()); | 71 ASSERT(isMainThread()); |
71 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didSendData, Al
lowCrossThreadAccess(&m_client), bytesSent, totalBytesToBeSent)); | 72 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didSendD
ata, AllowCrossThreadAccess(m_client.get()), bytesSent, totalBytesToBeSent)); |
72 } | 73 } |
73 | 74 |
74 static void didReceiveResponseAdapter(ThreadableLoaderClient* client, unsigned l
ong identifier, PassOwnPtr<CrossThreadResourceResponseData> responseData, PassOw
nPtr<WebDataConsumerHandle> handle) | 75 static void didReceiveResponseAdapter(ThreadableLoaderClientWrapper* client, uns
igned long identifier, PassOwnPtr<CrossThreadResourceResponseData> responseData,
PassOwnPtr<WebDataConsumerHandle> handle) |
75 { | 76 { |
76 OwnPtr<ResourceResponse> response(ResourceResponse::adopt(responseData)); | 77 OwnPtr<ResourceResponse> response(ResourceResponse::adopt(responseData)); |
77 client->didReceiveResponse(identifier, *response, handle); | 78 client->didReceiveResponse(identifier, *response, handle); |
78 } | 79 } |
79 | 80 |
80 void WorkerLoaderClientBridgeSyncHelper::didReceiveResponse(unsigned long identi
fier, const ResourceResponse& response, PassOwnPtr<WebDataConsumerHandle> handle
) | 81 void WorkerLoaderClientBridgeSyncHelper::didReceiveResponse(unsigned long identi
fier, const ResourceResponse& response, PassOwnPtr<WebDataConsumerHandle> handle
) |
81 { | 82 { |
82 MutexLocker lock(m_lock); | 83 MutexLocker lock(m_lock); |
83 ASSERT(isMainThread()); | 84 ASSERT(isMainThread()); |
84 m_clientTasks.append(threadSafeBind(&didReceiveResponseAdapter, AllowCrossTh
readAccess(&m_client), identifier, response, handle)); | 85 m_clientTasks.append(threadSafeBind(&didReceiveResponseAdapter, AllowCrossTh
readAccess(m_client.get()), identifier, response, handle)); |
85 } | 86 } |
86 | 87 |
87 void WorkerLoaderClientBridgeSyncHelper::didReceiveData(const char* data, unsign
ed dataLength) | 88 void WorkerLoaderClientBridgeSyncHelper::didReceiveData(const char* data, unsign
ed dataLength) |
88 { | 89 { |
89 MutexLocker lock(m_lock); | 90 MutexLocker lock(m_lock); |
90 ASSERT(isMainThread()); | 91 ASSERT(isMainThread()); |
91 Vector<char>* buffer = new Vector<char>(dataLength); | 92 Vector<char>* buffer = new Vector<char>(dataLength); |
92 memcpy(buffer->data(), data, dataLength); | 93 memcpy(buffer->data(), data, dataLength); |
93 m_receivedData.append(buffer); | 94 m_receivedData.append(buffer); |
94 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didReceiveData,
AllowCrossThreadAccess(&m_client), AllowCrossThreadAccess(static_cast<const cha
r*>(buffer->data())), dataLength)); | 95 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didRecei
veData, AllowCrossThreadAccess(m_client.get()), AllowCrossThreadAccess(static_ca
st<const char*>(buffer->data())), dataLength)); |
95 } | 96 } |
96 | 97 |
97 void WorkerLoaderClientBridgeSyncHelper::didDownloadData(int dataLength) | 98 void WorkerLoaderClientBridgeSyncHelper::didDownloadData(int dataLength) |
98 { | 99 { |
99 MutexLocker lock(m_lock); | 100 MutexLocker lock(m_lock); |
100 ASSERT(isMainThread()); | 101 ASSERT(isMainThread()); |
101 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didDownloadData
, AllowCrossThreadAccess(&m_client), dataLength)); | 102 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didDownl
oadData, AllowCrossThreadAccess(m_client.get()), dataLength)); |
102 } | 103 } |
103 | 104 |
104 void WorkerLoaderClientBridgeSyncHelper::didReceiveCachedMetadata(const char* da
ta, int dataLength) | 105 void WorkerLoaderClientBridgeSyncHelper::didReceiveCachedMetadata(const char* da
ta, int dataLength) |
105 { | 106 { |
106 MutexLocker lock(m_lock); | 107 MutexLocker lock(m_lock); |
107 ASSERT(isMainThread()); | 108 ASSERT(isMainThread()); |
108 Vector<char>* buffer = new Vector<char>(dataLength); | 109 Vector<char>* buffer = new Vector<char>(dataLength); |
109 memcpy(buffer->data(), data, dataLength); | 110 memcpy(buffer->data(), data, dataLength); |
110 m_receivedData.append(buffer); | 111 m_receivedData.append(buffer); |
111 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didReceiveCache
dMetadata, AllowCrossThreadAccess(&m_client), AllowCrossThreadAccess(static_cast
<const char*>(buffer->data())), dataLength)); | 112 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didRecei
veCachedMetadata, AllowCrossThreadAccess(m_client.get()), AllowCrossThreadAccess
(static_cast<const char*>(buffer->data())), dataLength)); |
112 } | 113 } |
113 | 114 |
114 void WorkerLoaderClientBridgeSyncHelper::didFinishLoading(unsigned long identifi
er, double finishTime) | 115 void WorkerLoaderClientBridgeSyncHelper::didFinishLoading(unsigned long identifi
er, double finishTime) |
115 { | 116 { |
116 MutexLocker lock(m_lock); | 117 MutexLocker lock(m_lock); |
117 ASSERT(isMainThread()); | 118 ASSERT(isMainThread()); |
118 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didFinishLoadin
g, AllowCrossThreadAccess(&m_client), identifier, finishTime)); | 119 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didFinis
hLoading, AllowCrossThreadAccess(m_client.get()), identifier, finishTime)); |
119 m_done = true; | 120 m_done = true; |
120 m_event->signal(); | 121 m_event->signal(); |
121 } | 122 } |
122 | 123 |
123 void WorkerLoaderClientBridgeSyncHelper::didFail(const ResourceError& error) | 124 void WorkerLoaderClientBridgeSyncHelper::didFail(const ResourceError& error) |
124 { | 125 { |
125 MutexLocker lock(m_lock); | 126 MutexLocker lock(m_lock); |
126 ASSERT(isMainThread()); | 127 ASSERT(isMainThread()); |
127 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didFail, AllowC
rossThreadAccess(&m_client), error)); | 128 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didFail,
AllowCrossThreadAccess(m_client.get()), error)); |
128 m_done = true; | 129 m_done = true; |
129 m_event->signal(); | 130 m_event->signal(); |
130 } | 131 } |
131 | 132 |
132 void WorkerLoaderClientBridgeSyncHelper::didFailAccessControlCheck(const Resourc
eError& error) | 133 void WorkerLoaderClientBridgeSyncHelper::didFailAccessControlCheck(const Resourc
eError& error) |
133 { | 134 { |
134 MutexLocker lock(m_lock); | 135 MutexLocker lock(m_lock); |
135 ASSERT(isMainThread()); | 136 ASSERT(isMainThread()); |
136 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didFailAccessCo
ntrolCheck, AllowCrossThreadAccess(&m_client), error)); | 137 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didFailA
ccessControlCheck, AllowCrossThreadAccess(m_client.get()), error)); |
137 m_done = true; | 138 m_done = true; |
138 m_event->signal(); | 139 m_event->signal(); |
139 } | 140 } |
140 | 141 |
141 void WorkerLoaderClientBridgeSyncHelper::didFailRedirectCheck() | 142 void WorkerLoaderClientBridgeSyncHelper::didFailRedirectCheck() |
142 { | 143 { |
143 MutexLocker lock(m_lock); | 144 MutexLocker lock(m_lock); |
144 ASSERT(isMainThread()); | 145 ASSERT(isMainThread()); |
145 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClient::didFailRedirect
Check, AllowCrossThreadAccess(&m_client))); | 146 m_clientTasks.append(threadSafeBind(&ThreadableLoaderClientWrapper::didFailR
edirectCheck, AllowCrossThreadAccess(m_client.get()))); |
146 m_done = true; | 147 m_done = true; |
147 m_event->signal(); | 148 m_event->signal(); |
148 } | 149 } |
149 | 150 |
150 WorkerLoaderClientBridgeSyncHelper::WorkerLoaderClientBridgeSyncHelper(Threadabl
eLoaderClient& client, PassOwnPtr<WebWaitableEvent> event) | 151 static void didReceiveResourceTimingAdapter(ThreadableLoaderClientWrapper* clien
t, PassOwnPtr<CrossThreadResourceTimingInfoData> timingData) |
| 152 { |
| 153 OwnPtr<ResourceTimingInfo> info(ResourceTimingInfo::adopt(timingData)); |
| 154 client->didReceiveResourceTiming(*info); |
| 155 } |
| 156 |
| 157 void WorkerLoaderClientBridgeSyncHelper::didReceiveResourceTiming(const Resource
TimingInfo& info) |
| 158 { |
| 159 MutexLocker lock(m_lock); |
| 160 ASSERT(isMainThread()); |
| 161 m_clientTasks.append(threadSafeBind(&didReceiveResourceTimingAdapter, AllowC
rossThreadAccess(m_client.get()), info)); |
| 162 } |
| 163 |
| 164 WorkerLoaderClientBridgeSyncHelper::WorkerLoaderClientBridgeSyncHelper(Threadabl
eLoaderClientWrapper* client, PassOwnPtr<WebWaitableEvent> event) |
151 : m_done(false) | 165 : m_done(false) |
152 , m_client(client) | 166 , m_client(client) |
153 , m_event(event) | 167 , m_event(event) |
154 { | 168 { |
155 ASSERT(m_event); | 169 ASSERT(m_event); |
156 } | 170 } |
157 | 171 |
158 } // namespace blink | 172 } // namespace blink |
OLD | NEW |