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

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: add CRXs Created 5 years, 8 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 weak_ptr_factory_(this) {
21 if (url.is_valid()) {
22 DCHECK(context_getter);
23 url_fetcher_.reset(net::URLFetcher::Create(
24 url, net::URLFetcher::GET, this));
25 url_fetcher_->SetRequestContext(context_getter);
26 url_fetcher_->SetLoadFlags(net::LOAD_DO_NOT_SAVE_COOKIES |
27 net::LOAD_DO_NOT_SEND_COOKIES);
28
29 url_fetcher_->Start();
30 // We'll get called back in OnURLFetchComplete.
31 } else {
32 base::MessageLoopProxy::current()->PostTask(
33 FROM_HERE,
34 base::Bind(&SafeImageFetcher::OnDecodeImageFailed,
35 weak_ptr_factory_.GetWeakPtr()));
36 }
37 }
38
39 SafeImageFetcher::~SafeImageFetcher() {
40 }
41
42 void SafeImageFetcher::OnURLFetchComplete(const net::URLFetcher* source) {
43 DCHECK_EQ(url_fetcher_.get(), source);
44 int response_code =
45 source->GetStatus().is_success() ? source->GetResponseCode() : 0;
46 if (!source->GetStatus().is_success() ||
47 response_code / 100 == 4 || response_code / 100 == 5) {
Lei Zhang 2015/03/31 09:39:08 So if we somehow get respond code 900, that counts
Marc Treib 2015/03/31 12:48:21 Hm, I'm guessing is_success() wouldn't be true in
48 OnDecodeImageFailed();
49 } else {
50 std::string response_data;
51 source->GetResponseAsString(&response_data);
52
53 ImageDecoder::Start(this, response_data);
54 }
55 url_fetcher_.reset();
56 }
57
58 void SafeImageFetcher::OnImageDecoded(const SkBitmap& decoded_image) {
59 callback_.Run(decoded_image);
60 }
61
62 void SafeImageFetcher::OnDecodeImageFailed() {
63 callback_.Run(SkBitmap());
64 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698