OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "net/proxy/multi_threaded_proxy_resolver.h" | 5 #include "net/proxy/multi_threaded_proxy_resolver.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
9 #include "base/message_loop/message_loop_proxy.h" | 9 #include "base/message_loop/message_loop_proxy.h" |
10 #include "base/strings/string_util.h" | 10 #include "base/strings/string_util.h" |
(...skipping 157 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
168 public: | 168 public: |
169 SetPacScriptJob(const scoped_refptr<ProxyResolverScriptData>& script_data, | 169 SetPacScriptJob(const scoped_refptr<ProxyResolverScriptData>& script_data, |
170 const CompletionCallback& callback) | 170 const CompletionCallback& callback) |
171 : Job(!callback.is_null() ? TYPE_SET_PAC_SCRIPT : | 171 : Job(!callback.is_null() ? TYPE_SET_PAC_SCRIPT : |
172 TYPE_SET_PAC_SCRIPT_INTERNAL, | 172 TYPE_SET_PAC_SCRIPT_INTERNAL, |
173 callback), | 173 callback), |
174 script_data_(script_data) { | 174 script_data_(script_data) { |
175 } | 175 } |
176 | 176 |
177 // Runs on the worker thread. | 177 // Runs on the worker thread. |
178 virtual void Run(scoped_refptr<base::MessageLoopProxy> origin_loop) OVERRIDE { | 178 virtual void Run(scoped_refptr<base::MessageLoopProxy> origin_loop) override { |
179 ProxyResolver* resolver = executor()->resolver(); | 179 ProxyResolver* resolver = executor()->resolver(); |
180 int rv = resolver->SetPacScript(script_data_, CompletionCallback()); | 180 int rv = resolver->SetPacScript(script_data_, CompletionCallback()); |
181 | 181 |
182 DCHECK_NE(rv, ERR_IO_PENDING); | 182 DCHECK_NE(rv, ERR_IO_PENDING); |
183 origin_loop->PostTask( | 183 origin_loop->PostTask( |
184 FROM_HERE, | 184 FROM_HERE, |
185 base::Bind(&SetPacScriptJob::RequestComplete, this, rv)); | 185 base::Bind(&SetPacScriptJob::RequestComplete, this, rv)); |
186 } | 186 } |
187 | 187 |
188 protected: | 188 protected: |
(...skipping 26 matching lines...) Expand all Loading... |
215 : Job(TYPE_GET_PROXY_FOR_URL, callback), | 215 : Job(TYPE_GET_PROXY_FOR_URL, callback), |
216 results_(results), | 216 results_(results), |
217 net_log_(net_log), | 217 net_log_(net_log), |
218 url_(url), | 218 url_(url), |
219 was_waiting_for_thread_(false) { | 219 was_waiting_for_thread_(false) { |
220 DCHECK(!callback.is_null()); | 220 DCHECK(!callback.is_null()); |
221 } | 221 } |
222 | 222 |
223 BoundNetLog* net_log() { return &net_log_; } | 223 BoundNetLog* net_log() { return &net_log_; } |
224 | 224 |
225 virtual void WaitingForThread() OVERRIDE { | 225 virtual void WaitingForThread() override { |
226 was_waiting_for_thread_ = true; | 226 was_waiting_for_thread_ = true; |
227 net_log_.BeginEvent(NetLog::TYPE_WAITING_FOR_PROXY_RESOLVER_THREAD); | 227 net_log_.BeginEvent(NetLog::TYPE_WAITING_FOR_PROXY_RESOLVER_THREAD); |
228 } | 228 } |
229 | 229 |
230 virtual void FinishedWaitingForThread() OVERRIDE { | 230 virtual void FinishedWaitingForThread() override { |
231 DCHECK(executor()); | 231 DCHECK(executor()); |
232 | 232 |
233 if (was_waiting_for_thread_) { | 233 if (was_waiting_for_thread_) { |
234 net_log_.EndEvent(NetLog::TYPE_WAITING_FOR_PROXY_RESOLVER_THREAD); | 234 net_log_.EndEvent(NetLog::TYPE_WAITING_FOR_PROXY_RESOLVER_THREAD); |
235 } | 235 } |
236 | 236 |
237 net_log_.AddEvent( | 237 net_log_.AddEvent( |
238 NetLog::TYPE_SUBMITTED_TO_RESOLVER_THREAD, | 238 NetLog::TYPE_SUBMITTED_TO_RESOLVER_THREAD, |
239 NetLog::IntegerCallback("thread_number", executor()->thread_number())); | 239 NetLog::IntegerCallback("thread_number", executor()->thread_number())); |
240 } | 240 } |
241 | 241 |
242 // Runs on the worker thread. | 242 // Runs on the worker thread. |
243 virtual void Run(scoped_refptr<base::MessageLoopProxy> origin_loop) OVERRIDE { | 243 virtual void Run(scoped_refptr<base::MessageLoopProxy> origin_loop) override { |
244 ProxyResolver* resolver = executor()->resolver(); | 244 ProxyResolver* resolver = executor()->resolver(); |
245 int rv = resolver->GetProxyForURL( | 245 int rv = resolver->GetProxyForURL( |
246 url_, &results_buf_, CompletionCallback(), NULL, net_log_); | 246 url_, &results_buf_, CompletionCallback(), NULL, net_log_); |
247 DCHECK_NE(rv, ERR_IO_PENDING); | 247 DCHECK_NE(rv, ERR_IO_PENDING); |
248 | 248 |
249 origin_loop->PostTask( | 249 origin_loop->PostTask( |
250 FROM_HERE, | 250 FROM_HERE, |
251 base::Bind(&GetProxyForURLJob::QueryComplete, this, rv)); | 251 base::Bind(&GetProxyForURLJob::QueryComplete, this, rv)); |
252 } | 252 } |
253 | 253 |
(...skipping 277 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
531 return; | 531 return; |
532 | 532 |
533 // Get the next job to process (FIFO). Transfer it from the pending queue | 533 // Get the next job to process (FIFO). Transfer it from the pending queue |
534 // to the executor. | 534 // to the executor. |
535 scoped_refptr<Job> job = pending_jobs_.front(); | 535 scoped_refptr<Job> job = pending_jobs_.front(); |
536 pending_jobs_.pop_front(); | 536 pending_jobs_.pop_front(); |
537 executor->StartJob(job.get()); | 537 executor->StartJob(job.get()); |
538 } | 538 } |
539 | 539 |
540 } // namespace net | 540 } // namespace net |
OLD | NEW |