diff options
author | estade@chromium.org <estade@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-08 19:01:02 +0000 |
---|---|---|
committer | estade@chromium.org <estade@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-08 19:01:02 +0000 |
commit | 0f38ceaebbc66b29fb3297516f74f9c8379d902f (patch) | |
tree | 8af215d4a01c60a2d3a5fe0aa55fd35cab05a744 /chrome/browser/icon_loader.cc | |
parent | eac83f0d14be2fed85edf2ffad934dd1309819e7 (diff) | |
download | chromium_src-0f38ceaebbc66b29fb3297516f74f9c8379d902f.zip chromium_src-0f38ceaebbc66b29fb3297516f74f9c8379d902f.tar.gz chromium_src-0f38ceaebbc66b29fb3297516f74f9c8379d902f.tar.bz2 |
Stub implementation of linux, mac icon loader/manager.
Define a platform specific type IconGroupID which helps with caching multiple requests for the same icon. Previously we just used the file path (or the extension), but on POSIX we use mime types rather than extensions.
Review URL: http://codereview.chromium.org/113120
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@15665 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/icon_loader.cc')
-rw-r--r-- | chrome/browser/icon_loader.cc | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/chrome/browser/icon_loader.cc b/chrome/browser/icon_loader.cc new file mode 100644 index 0000000..6896427 --- /dev/null +++ b/chrome/browser/icon_loader.cc @@ -0,0 +1,34 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "chrome/browser/icon_loader.h" + +#include "base/message_loop.h" +#include "base/thread.h" +#include "chrome/browser/browser_process.h" +#include "skia/include/SkBitmap.h" + +IconLoader::IconLoader(const IconGroupID& group, IconSize size, + Delegate* delegate) + : group_(group), + icon_size_(size), + bitmap_(NULL), + delegate_(delegate) { +} + +IconLoader::~IconLoader() { + delete bitmap_; +} + +void IconLoader::Start() { + target_message_loop_ = MessageLoop::current(); + + g_browser_process->file_thread()->message_loop()->PostTask(FROM_HERE, + NewRunnableMethod(this, &IconLoader::ReadIcon)); +} + +void IconLoader::NotifyDelegate() { + delegate_->OnBitmapLoaded(this, bitmap_); + bitmap_ = NULL; +} |