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

Side by Side Diff: chrome/browser/safe_image_fetcher.cc

Issue 855513002: Add/resurrect support for bundles of WebStore items. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@testext_bundle
Patch Set: remove icon_data Created 5 years, 9 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
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/safe_image_fetcher.h"
6
7 #include "base/bind.h"
8 #include "base/callback.h"
9 #include "base/message_loop/message_loop_proxy.h"
10 #include "net/base/load_flags.h"
11 #include "net/url_request/url_fetcher.h"
12 #include "third_party/skia/include/core/SkBitmap.h"
13
14 SafeImageFetcher::SafeImageFetcher(
15 const GURL& url,
16 net::URLRequestContextGetter* context_getter,
17 const GetImageCallback& callback)
18 : ImageRequest(base::MessageLoopProxy::current()),
19 callback_(callback) {
20 if (url.is_valid()) {
21 DCHECK(context_getter);
22 url_fetcher_.reset(net::URLFetcher::Create(
23 url, net::URLFetcher::GET, this));
24 url_fetcher_->SetRequestContext(context_getter);
25 url_fetcher_->SetLoadFlags(net::LOAD_DO_NOT_SAVE_COOKIES |
26 net::LOAD_DO_NOT_SEND_COOKIES);
27
28 url_fetcher_->Start();
29 // We'll get called back in OnURLFetchComplete.
30 } else {
31 base::MessageLoopProxy::current()->PostTask(
32 FROM_HERE,
33 base::Bind(&SafeImageFetcher::OnDecodeImageFailed,
34 base::Unretained(this)));
asargent_no_longer_on_chrome 2015/03/26 18:12:50 What if this object is deleted by its owner before
Marc Treib 2015/03/27 11:52:12 Hm, just adding a comment feels like asking for tr
35 }
36 }
37
38 SafeImageFetcher::~SafeImageFetcher() {
39 }
40
41 void SafeImageFetcher::OnURLFetchComplete(const net::URLFetcher* source) {
42 DCHECK_EQ(url_fetcher_.get(), source);
43 int response_code =
44 source->GetStatus().is_success() ? source->GetResponseCode() : 0;
45 if (!source->GetStatus().is_success() ||
46 response_code / 100 == 4 || response_code / 100 == 5) {
47 OnDecodeImageFailed();
48 } else {
49 std::string response_data;
50 source->GetResponseAsString(&response_data);
51
52 ImageDecoder::Start(this, response_data);
53 }
54 url_fetcher_.reset();
55 }
56
57 void SafeImageFetcher::OnImageDecoded(const SkBitmap& decoded_image) {
58 callback_.Run(decoded_image);
59 }
60
61 void SafeImageFetcher::OnDecodeImageFailed() {
62 callback_.Run(SkBitmap());
63 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698