OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "chrome/browser/bitmap_fetcher/bitmap_fetcher.h" | 5 #include "chrome/browser/bitmap_fetcher/bitmap_fetcher.h" |
6 | 6 |
7 #include "content/public/browser/browser_thread.h" | 7 #include "content/public/browser/browser_thread.h" |
8 #include "net/url_request/url_fetcher.h" | 8 #include "net/url_request/url_fetcher.h" |
9 #include "net/url_request/url_request_context_getter.h" | 9 #include "net/url_request/url_request_context_getter.h" |
10 #include "net/url_request/url_request_status.h" | 10 #include "net/url_request/url_request_status.h" |
11 | 11 |
12 namespace chrome { | 12 namespace chrome { |
13 | 13 |
14 BitmapFetcher::BitmapFetcher(const GURL& url, BitmapFetcherDelegate* delegate) | 14 BitmapFetcher::BitmapFetcher(const GURL& url, BitmapFetcherDelegate* delegate) |
15 : url_(url), | 15 : url_(url), |
16 delegate_(delegate) { | 16 delegate_(delegate) { |
17 } | 17 } |
18 | 18 |
19 BitmapFetcher::~BitmapFetcher() { | 19 BitmapFetcher::~BitmapFetcher() { |
20 } | 20 } |
21 | 21 |
22 void BitmapFetcher::Start(net::URLRequestContextGetter* request_context, | 22 void BitmapFetcher::Init(net::URLRequestContextGetter* request_context, |
23 const std::string& referrer, | 23 const std::string& referrer, |
24 net::URLRequest::ReferrerPolicy referrer_policy, | 24 net::URLRequest::ReferrerPolicy referrer_policy, |
25 int load_flags) { | 25 int load_flags) { |
26 if (url_fetcher_ != NULL) | 26 if (url_fetcher_ != NULL) |
sky
2015/06/08 15:05:29
In general we DCHECK people calling Init multiple
| |
27 return; | 27 return; |
28 | 28 |
29 url_fetcher_ = net::URLFetcher::Create(url_, net::URLFetcher::GET, this); | 29 url_fetcher_ = net::URLFetcher::Create(url_, net::URLFetcher::GET, this); |
30 url_fetcher_->SetRequestContext(request_context); | 30 url_fetcher_->SetRequestContext(request_context); |
31 url_fetcher_->SetReferrer(referrer); | 31 url_fetcher_->SetReferrer(referrer); |
32 url_fetcher_->SetReferrerPolicy(referrer_policy); | 32 url_fetcher_->SetReferrerPolicy(referrer_policy); |
33 url_fetcher_->SetLoadFlags(load_flags); | 33 url_fetcher_->SetLoadFlags(load_flags); |
34 } | |
35 | |
36 void BitmapFetcher::Start() { | |
34 url_fetcher_->Start(); | 37 url_fetcher_->Start(); |
sky
2015/06/08 15:05:29
The old code early outed if url_fecher_ was alread
| |
35 } | 38 } |
36 | 39 |
37 // Methods inherited from URLFetcherDelegate. | 40 // Methods inherited from URLFetcherDelegate. |
38 | 41 |
39 void BitmapFetcher::OnURLFetchComplete(const net::URLFetcher* source) { | 42 void BitmapFetcher::OnURLFetchComplete(const net::URLFetcher* source) { |
40 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 43 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
41 | 44 |
42 if (source->GetStatus().status() != net::URLRequestStatus::SUCCESS) { | 45 if (source->GetStatus().status() != net::URLRequestStatus::SUCCESS) { |
43 ReportFailure(); | 46 ReportFailure(); |
44 return; | 47 return; |
(...skipping 22 matching lines...) Expand all Loading... | |
67 | 70 |
68 void BitmapFetcher::OnDecodeImageFailed() { | 71 void BitmapFetcher::OnDecodeImageFailed() { |
69 ReportFailure(); | 72 ReportFailure(); |
70 } | 73 } |
71 | 74 |
72 void BitmapFetcher::ReportFailure() { | 75 void BitmapFetcher::ReportFailure() { |
73 delegate_->OnFetchComplete(url_, NULL); | 76 delegate_->OnFetchComplete(url_, NULL); |
74 } | 77 } |
75 | 78 |
76 } // namespace chrome | 79 } // namespace chrome |
OLD | NEW |