| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 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 | 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 "content/renderer/image_downloader/image_downloader_impl.h" | 5 #include "content/renderer/image_downloader/image_downloader_impl.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/location.h" | 10 #include "base/location.h" |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 116 original_image_sizes->push_back( | 116 original_image_sizes->push_back( |
| 117 gfx::Size(min_image->width(), min_image->height())); | 117 gfx::Size(min_image->width(), min_image->height())); |
| 118 } | 118 } |
| 119 | 119 |
| 120 } // namespace | 120 } // namespace |
| 121 | 121 |
| 122 namespace content { | 122 namespace content { |
| 123 | 123 |
| 124 ImageDownloaderImpl::ImageDownloaderImpl( | 124 ImageDownloaderImpl::ImageDownloaderImpl( |
| 125 RenderFrame* render_frame, | 125 RenderFrame* render_frame, |
| 126 mojo::InterfaceRequest<content::mojom::ImageDownloader> request) | 126 mojom::ImageDownloaderRequest request) |
| 127 : RenderFrameObserver(render_frame), binding_(this, std::move(request)) { | 127 : RenderFrameObserver(render_frame), |
| 128 binding_(this, std::move(request)) { |
| 128 DCHECK(render_frame); | 129 DCHECK(render_frame); |
| 129 RenderThread::Get()->AddObserver(this); | 130 RenderThread::Get()->AddObserver(this); |
| 131 binding_.set_connection_error_handler( |
| 132 base::Bind(&ImageDownloaderImpl::OnDestruct, base::Unretained(this))); |
| 130 } | 133 } |
| 131 | 134 |
| 132 ImageDownloaderImpl::~ImageDownloaderImpl() { | 135 ImageDownloaderImpl::~ImageDownloaderImpl() { |
| 133 RenderThread* thread = RenderThread::Get(); | 136 RenderThread* thread = RenderThread::Get(); |
| 134 // As ImageDownloaderImpl is a strong binding with message pipe, the | 137 // As ImageDownloaderImpl is a strong binding with message pipe, the |
| 135 // destructor may run after message loop shutdown, so we need to check whether | 138 // destructor may run after message loop shutdown, so we need to check whether |
| 136 // RenderThread is null. | 139 // RenderThread is null. |
| 137 if (thread) | 140 if (thread) |
| 138 thread->RemoveObserver(this); | 141 thread->RemoveObserver(this); |
| 139 } | 142 } |
| 140 | 143 |
| 141 // static | 144 // static |
| 142 void ImageDownloaderImpl::CreateMojoService( | 145 void ImageDownloaderImpl::CreateMojoService( |
| 143 RenderFrame* render_frame, | 146 RenderFrame* render_frame, |
| 144 mojo::InterfaceRequest<content::mojom::ImageDownloader> request) { | 147 mojom::ImageDownloaderRequest request) { |
| 145 DVLOG(1) << "ImageDownloaderImpl::CreateService"; | 148 DVLOG(1) << "ImageDownloaderImpl::CreateMojoService"; |
| 146 DCHECK(render_frame); | 149 DCHECK(render_frame); |
| 147 | 150 |
| 151 // Owns itself. |
| 148 new ImageDownloaderImpl(render_frame, std::move(request)); | 152 new ImageDownloaderImpl(render_frame, std::move(request)); |
| 149 } | 153 } |
| 150 | 154 |
| 151 // Ensure all loaders cleared before calling blink::shutdown. | 155 // Ensure all loaders cleared before calling blink::shutdown. |
| 152 void ImageDownloaderImpl::OnRenderProcessShutdown() { | 156 void ImageDownloaderImpl::OnRenderProcessShutdown() { |
| 153 image_fetchers_.clear(); | 157 image_fetchers_.clear(); |
| 154 } | 158 } |
| 155 | 159 |
| 156 // ImageDownloader methods: | 160 // ImageDownloader methods: |
| 157 void ImageDownloaderImpl::DownloadImage(const GURL& image_url, | 161 void ImageDownloaderImpl::DownloadImage(const GURL& image_url, |
| (...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 230 const std::vector<gfx::Size>& result_original_image_sizes, | 234 const std::vector<gfx::Size>& result_original_image_sizes, |
| 231 const DownloadImageCallback& callback) { | 235 const DownloadImageCallback& callback) { |
| 232 callback.Run(http_status_code, result_images, result_original_image_sizes); | 236 callback.Run(http_status_code, result_images, result_original_image_sizes); |
| 233 } | 237 } |
| 234 | 238 |
| 235 void ImageDownloaderImpl::OnDestruct() { | 239 void ImageDownloaderImpl::OnDestruct() { |
| 236 delete this; | 240 delete this; |
| 237 } | 241 } |
| 238 | 242 |
| 239 } // namespace content | 243 } // namespace content |
| OLD | NEW |