OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/chromeos/app_mode/kiosk_app_data.h" | 5 #include "chrome/browser/chromeos/app_mode/kiosk_app_data.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/files/file_util.h" | 10 #include "base/files/file_util.h" |
(...skipping 214 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
225 void LoadOnBlockingPool() { | 225 void LoadOnBlockingPool() { |
226 DCHECK(task_runner_->RunsTasksOnCurrentThread()); | 226 DCHECK(task_runner_->RunsTasksOnCurrentThread()); |
227 | 227 |
228 std::string data; | 228 std::string data; |
229 if (!base::ReadFileToString(base::FilePath(icon_path_), &data)) { | 229 if (!base::ReadFileToString(base::FilePath(icon_path_), &data)) { |
230 ReportResultOnBlockingPool(FAILED_TO_LOAD); | 230 ReportResultOnBlockingPool(FAILED_TO_LOAD); |
231 return; | 231 return; |
232 } | 232 } |
233 raw_icon_ = base::RefCountedString::TakeString(&data); | 233 raw_icon_ = base::RefCountedString::TakeString(&data); |
234 | 234 |
235 scoped_refptr<ImageDecoder> image_decoder = new ImageDecoder( | 235 ImageDecoder::GetInstance()->Start(this, raw_icon_->data(), |
236 this, raw_icon_->data(), ImageDecoder::DEFAULT_CODEC); | 236 ImageDecoder::DEFAULT_CODEC, |
237 image_decoder->Start(task_runner_); | 237 task_runner_, false); |
238 } | 238 } |
239 | 239 |
240 void ReportResultOnBlockingPool(LoadResult result) { | 240 void ReportResultOnBlockingPool(LoadResult result) { |
241 DCHECK(task_runner_->RunsTasksOnCurrentThread()); | 241 DCHECK(task_runner_->RunsTasksOnCurrentThread()); |
242 | 242 |
243 load_result_ = result; | 243 load_result_ = result; |
244 BrowserThread::PostTask( | 244 BrowserThread::PostTask( |
245 BrowserThread::UI, | 245 BrowserThread::UI, |
246 FROM_HERE, | 246 FROM_HERE, |
247 base::Bind(&IconLoader::ReportResultOnUIThread, | 247 base::Bind(&IconLoader::ReportResultOnUIThread, |
(...skipping 11 matching lines...) Expand all Loading... |
259 } | 259 } |
260 | 260 |
261 void ReportResultOnUIThread() { | 261 void ReportResultOnUIThread() { |
262 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 262 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
263 | 263 |
264 NotifyClient(); | 264 NotifyClient(); |
265 delete this; | 265 delete this; |
266 } | 266 } |
267 | 267 |
268 // ImageDecoder::Delegate overrides: | 268 // ImageDecoder::Delegate overrides: |
269 void OnImageDecoded(const ImageDecoder* decoder, | 269 void OnImageDecoded(const SkBitmap& decoded_image) override { |
270 const SkBitmap& decoded_image) override { | |
271 icon_ = gfx::ImageSkia::CreateFrom1xBitmap(decoded_image); | 270 icon_ = gfx::ImageSkia::CreateFrom1xBitmap(decoded_image); |
272 icon_.MakeThreadSafe(); | 271 icon_.MakeThreadSafe(); |
273 ReportResultOnBlockingPool(SUCCESS); | 272 ReportResultOnBlockingPool(SUCCESS); |
274 } | 273 } |
275 | 274 |
276 void OnDecodeImageFailed(const ImageDecoder* decoder) override { | 275 void OnDecodeImageFailed() override { |
277 ReportResultOnBlockingPool(FAILED_TO_DECODE); | 276 ReportResultOnBlockingPool(FAILED_TO_DECODE); |
278 } | 277 } |
279 | 278 |
280 base::WeakPtr<KioskAppData> client_; | 279 base::WeakPtr<KioskAppData> client_; |
281 base::FilePath icon_path_; | 280 base::FilePath icon_path_; |
282 | 281 |
283 LoadResult load_result_; | 282 LoadResult load_result_; |
284 scoped_refptr<base::SequencedTaskRunner> task_runner_; | 283 scoped_refptr<base::SequencedTaskRunner> task_runner_; |
285 | 284 |
286 gfx::ImageSkia icon_; | 285 gfx::ImageSkia icon_; |
(...skipping 13 matching lines...) Expand all Loading... |
300 : client_(client) {} | 299 : client_(client) {} |
301 | 300 |
302 void Start(const std::string& app_id, | 301 void Start(const std::string& app_id, |
303 const std::string& manifest, | 302 const std::string& manifest, |
304 const GURL& icon_url, | 303 const GURL& icon_url, |
305 net::URLRequestContextGetter* context_getter) { | 304 net::URLRequestContextGetter* context_getter) { |
306 scoped_refptr<extensions::WebstoreInstallHelper> webstore_helper = | 305 scoped_refptr<extensions::WebstoreInstallHelper> webstore_helper = |
307 new extensions::WebstoreInstallHelper(this, | 306 new extensions::WebstoreInstallHelper(this, |
308 app_id, | 307 app_id, |
309 manifest, | 308 manifest, |
310 "", // No icon data. | |
311 icon_url, | 309 icon_url, |
312 context_getter); | 310 context_getter); |
313 webstore_helper->Start(); | 311 webstore_helper->Start(); |
314 } | 312 } |
315 | 313 |
316 private: | 314 private: |
317 friend class base::RefCounted<WebstoreDataParser>; | 315 friend class base::RefCounted<WebstoreDataParser>; |
318 | 316 |
319 ~WebstoreDataParser() override {} | 317 ~WebstoreDataParser() override {} |
320 | 318 |
(...skipping 323 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
644 | 642 |
645 SkBitmap icon = crx_loader->icon(); | 643 SkBitmap icon = crx_loader->icon(); |
646 if (icon.empty()) | 644 if (icon.empty()) |
647 icon = *extensions::util::GetDefaultAppIcon().bitmap(); | 645 icon = *extensions::util::GetDefaultAppIcon().bitmap(); |
648 SetCache(crx_loader->name(), icon); | 646 SetCache(crx_loader->name(), icon); |
649 | 647 |
650 SetStatus(STATUS_LOADED); | 648 SetStatus(STATUS_LOADED); |
651 } | 649 } |
652 | 650 |
653 } // namespace chromeos | 651 } // namespace chromeos |
OLD | NEW |