Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #ifndef CHROME_BROWSER_FAVICON_HELPER_H__ | 5 #ifndef CHROME_BROWSER_FAVICON_HELPER_H__ |
| 6 #define CHROME_BROWSER_FAVICON_HELPER_H__ | 6 #define CHROME_BROWSER_FAVICON_HELPER_H__ |
| 7 #pragma once | 7 #pragma once |
| 8 | 8 |
| 9 #include <map> | 9 #include <map> |
| 10 | 10 |
| 11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
| 12 #include "base/callback.h" | 12 #include "base/callback.h" |
| 13 #include "base/ref_counted.h" | 13 #include "base/ref_counted.h" |
| 14 #include "chrome/browser/favicon_service.h" | 14 #include "chrome/browser/favicon_service.h" |
| 15 #include "chrome/common/icon_messages.h" | |
| 15 #include "chrome/common/ref_counted_util.h" | 16 #include "chrome/common/ref_counted_util.h" |
| 16 #include "content/browser/cancelable_request.h" | 17 #include "content/browser/cancelable_request.h" |
| 17 #include "content/browser/tab_contents/tab_contents_observer.h" | 18 #include "content/browser/tab_contents/tab_contents_observer.h" |
| 18 #include "googleurl/src/gurl.h" | 19 #include "googleurl/src/gurl.h" |
| 19 | 20 |
| 20 class NavigationEntry; | 21 class NavigationEntry; |
| 21 class Profile; | 22 class Profile; |
| 22 class RefCountedMemory; | 23 class RefCountedMemory; |
| 23 class SkBitmap; | 24 class SkBitmap; |
| 24 class TabContents; | 25 class TabContents; |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 60 // OnFaviconData either updates the favicon of the NavigationEntry (if the | 61 // OnFaviconData either updates the favicon of the NavigationEntry (if the |
| 61 // db knew about the favicon), or requests the renderer to download the | 62 // db knew about the favicon), or requests the renderer to download the |
| 62 // favicon. | 63 // favicon. |
| 63 // | 64 // |
| 64 // When the renderer downloads the favicon SetFaviconImageData is invoked, | 65 // When the renderer downloads the favicon SetFaviconImageData is invoked, |
| 65 // at which point we update the favicon of the NavigationEntry and notify | 66 // at which point we update the favicon of the NavigationEntry and notify |
| 66 // the database to save the favicon. | 67 // the database to save the favicon. |
| 67 | 68 |
| 68 class FaviconHelper : public TabContentsObserver { | 69 class FaviconHelper : public TabContentsObserver { |
| 69 public: | 70 public: |
| 70 explicit FaviconHelper(TabContents* tab_contents); | 71 enum Types { |
|
sky
2011/03/28 15:02:58
Types -> Type
michaelbai
2011/03/29 00:00:50
Done.
| |
| 72 FAVICON, | |
| 73 TOUCH, | |
| 74 }; | |
| 75 | |
| 76 FaviconHelper(TabContents* tab_contents, Types icon_type); | |
| 71 virtual ~FaviconHelper(); | 77 virtual ~FaviconHelper(); |
| 72 | 78 |
| 73 // Initiates loading the favicon for the specified url. | 79 // Initiates loading the favicon for the specified url. |
| 74 void FetchFavicon(const GURL& url); | 80 void FetchFavicon(const GURL& url); |
| 75 | 81 |
| 76 // Initiates loading an image from given |image_url|. Returns a download id | 82 // Initiates loading an image from given |image_url|. Returns a download id |
| 77 // for caller to track the request. When download completes, |callback| is | 83 // for caller to track the request. When download completes, |callback| is |
| 78 // called with the three params: the download_id, a boolean flag to indicate | 84 // called with the three params: the download_id, a boolean flag to indicate |
| 79 // whether the download succeeds and a SkBitmap as the downloaded image. | 85 // whether the download succeeds and a SkBitmap as the downloaded image. |
| 80 // Note that |image_size| is a hint for images with multiple sizes. The | 86 // Note that |image_size| is a hint for images with multiple sizes. The |
| 81 // downloaded image is not resized to the given image_size. If 0 is passed, | 87 // downloaded image is not resized to the given image_size. If 0 is passed, |
| 82 // the first frame of the image is returned. | 88 // the first frame of the image is returned. |
| 83 typedef Callback3<int, bool, const SkBitmap&>::Type ImageDownloadCallback; | 89 typedef Callback3<int, bool, const SkBitmap&>::Type ImageDownloadCallback; |
| 84 int DownloadImage(const GURL& image_url, int image_size, | 90 int DownloadImage(const GURL& image_url, |
| 91 int image_size, | |
| 92 history::IconType icon_type, | |
| 85 ImageDownloadCallback* callback); | 93 ImageDownloadCallback* callback); |
| 86 | 94 |
| 87 // Message Handler. Must be public, because also called from | 95 // Message Handler. Must be public, because also called from |
| 88 // PrerenderContents. | 96 // PrerenderContents. |
| 89 void OnUpdateFaviconURL(int32 page_id, const GURL& icon_url); | 97 void OnUpdateFaviconURL(int32 page_id, |
| 98 const std::vector<FaviconURL>& candidates); | |
| 99 | |
| 100 protected: | |
| 101 // These virtual methods make FaviconHelper testable and are overridden by | |
| 102 // TestFaviconHelper | |
| 103 // | |
| 104 // Return the NavigationEntry for the active entry, or NULL if the active | |
| 105 // entries URL does not match that of the URL last passed to FetchFavicon. | |
| 106 virtual NavigationEntry* GetEntry(); | |
|
sky
2011/03/28 15:02:58
You need to move all the implementations to match
michaelbai
2011/03/29 00:00:50
Done.
| |
| 107 | |
| 108 // Asks the render to download favicon. | |
|
sky
2011/03/28 15:02:58
Document return value.
michaelbai
2011/03/29 00:00:50
Done.
| |
| 109 virtual int DownloadFavicon(const GURL& image_url, int image_size); | |
| 110 | |
| 111 // Ask the favicon from history | |
| 112 virtual void UpdateFaviconMappingAndFetch( | |
| 113 const GURL& page_url, | |
| 114 const GURL& icon_url, | |
| 115 history::IconType icon_type, | |
| 116 CancelableRequestConsumerBase* consumer, | |
| 117 FaviconService::FaviconDataCallback* callback); | |
| 118 | |
| 119 virtual void GetFavicon( | |
| 120 const GURL& icon_url, | |
| 121 history::IconType icon_type, | |
| 122 CancelableRequestConsumerBase* consumer, | |
| 123 FaviconService::FaviconDataCallback* callback); | |
| 124 | |
| 125 virtual void GetFaviconForURL( | |
| 126 const GURL& page_url, | |
| 127 int icon_types, | |
| 128 CancelableRequestConsumerBase* consumer, | |
| 129 FaviconService::FaviconDataCallback* callback); | |
| 130 | |
| 131 virtual void SetHistoryFavicon(const GURL& page_url, | |
| 132 const GURL& icon_url, | |
| 133 const std::vector<unsigned char>& image_data, | |
| 134 history::IconType icon_type); | |
| 135 | |
| 136 virtual FaviconService* GetFaviconService(); | |
| 137 | |
| 138 // Returns true if the favicon should be saved. | |
| 139 virtual bool ShouldSaveFavicon(const GURL& url); | |
| 90 | 140 |
| 91 private: | 141 private: |
| 142 friend class DownloadHandler; // For testing | |
|
sky
2011/03/28 15:02:58
Instead of having so many friends, which is pain t
michaelbai
2011/03/29 00:00:50
Done.
| |
| 143 friend class HistoryRequestHandler; // For testing | |
| 144 FRIEND_TEST_ALL_PREFIXES(FaviconHelperTest, DownloadFavicon); | |
| 145 FRIEND_TEST_ALL_PREFIXES(FaviconHelperTest, GetFaviconFromHistory); | |
| 146 FRIEND_TEST_ALL_PREFIXES(FaviconHelperTest, UpdateAndDownloadFavicon); | |
| 147 FRIEND_TEST_ALL_PREFIXES(FaviconHelperTest, UpdateFavicon); | |
| 148 FRIEND_TEST_ALL_PREFIXES(FaviconHelperTest, Download2ndFaviconURLCandidate); | |
| 149 FRIEND_TEST_ALL_PREFIXES(FaviconHelperTest, UpdateDuringDownloading); | |
| 150 | |
| 92 struct DownloadRequest { | 151 struct DownloadRequest { |
| 93 DownloadRequest() {} | 152 DownloadRequest(); |
| 153 | |
| 94 DownloadRequest(const GURL& url, | 154 DownloadRequest(const GURL& url, |
| 95 const GURL& image_url, | 155 const GURL& image_url, |
| 96 ImageDownloadCallback* callback) | 156 ImageDownloadCallback* callback, |
| 97 : url(url), | 157 history::IconType icon_type); |
| 98 image_url(image_url), | |
| 99 callback(callback) { } | |
| 100 | 158 |
| 101 GURL url; | 159 GURL url; |
| 102 GURL image_url; | 160 GURL image_url; |
| 103 ImageDownloadCallback* callback; | 161 ImageDownloadCallback* callback; |
| 162 history::IconType icon_type; | |
| 104 }; | 163 }; |
| 105 | 164 |
| 165 static bool do_url_and_icon_match(const FaviconURL& favicon_url, | |
| 166 const GURL& url, | |
| 167 history::IconType icon_type) { | |
| 168 return favicon_url.icon_url == url && | |
| 169 favicon_url.icon_type == static_cast<IconType>(icon_type); | |
| 170 } | |
| 171 | |
| 106 // TabContentsObserver implementation. | 172 // TabContentsObserver implementation. |
| 107 virtual bool OnMessageReceived(const IPC::Message& message); | 173 virtual bool OnMessageReceived(const IPC::Message& message); |
| 108 | 174 |
| 109 void OnDidDownloadFavicon(int id, | 175 void OnDidDownloadFavicon(int id, |
| 110 const GURL& image_url, | 176 const GURL& image_url, |
| 111 bool errored, | 177 bool errored, |
| 112 const SkBitmap& image); | 178 const SkBitmap& image); |
| 113 | 179 |
| 114 // Return the NavigationEntry for the active entry, or NULL if the active | |
| 115 // entries URL does not match that of the URL last passed to FetchFavicon. | |
| 116 NavigationEntry* GetEntry(); | |
| 117 | |
| 118 Profile* profile(); | 180 Profile* profile(); |
| 119 | 181 |
| 120 FaviconService* GetFaviconService(); | |
| 121 | |
| 122 // See description above class for details. | 182 // See description above class for details. |
| 123 void OnFaviconDataForInitialURL(FaviconService::Handle handle, | 183 void OnFaviconDataForInitialURL(FaviconService::Handle handle, |
| 124 history::FaviconData favicon); | 184 history::FaviconData favicon); |
| 125 | 185 |
| 126 // If the favicon has expired, asks the renderer to download the favicon. | 186 // If the favicon has expired, asks the renderer to download the favicon. |
| 127 // Otherwise asks history to update the mapping between page url and icon | 187 // Otherwise asks history to update the mapping between page url and icon |
| 128 // url with a callback to OnFaviconData when done. | 188 // url with a callback to OnFaviconData when done. |
| 129 void DownloadFaviconOrAskHistory(NavigationEntry* entry); | 189 void DownloadFaviconOrAskHistory(const GURL& page_url, |
| 190 const GURL& icon_url, | |
| 191 history::IconType icon_type); | |
| 130 | 192 |
| 131 // See description above class for details. | 193 // See description above class for details. |
| 132 void OnFaviconData(FaviconService::Handle handle, | 194 void OnFaviconData(FaviconService::Handle handle, |
| 133 history::FaviconData favicon); | 195 history::FaviconData favicon); |
| 134 | 196 |
| 135 // Schedules a download for the specified entry. This adds the request to | 197 // Schedules a download for the specified entry. This adds the request to |
| 136 // download_requests_. | 198 // download_requests_. |
| 137 int ScheduleDownload(const GURL& url, const GURL& image_url, int image_size, | 199 int ScheduleDownload(const GURL& url, |
| 200 const GURL& image_url, | |
| 201 int image_size, | |
| 202 history::IconType icon_type, | |
| 138 ImageDownloadCallback* callback); | 203 ImageDownloadCallback* callback); |
| 139 | 204 |
| 140 // Sets the image data for the favicon. This is invoked asynchronously after | 205 // Sets the image data for the favicon. This is invoked asynchronously after |
| 141 // we request the TabContents to download the favicon. | 206 // we request the TabContents to download the favicon. |
| 142 void SetFavicon(const GURL& url, const GURL& icon_url, const SkBitmap& image); | 207 void SetFavicon(const GURL& url, |
| 208 const GURL& icon_url, | |
| 209 const SkBitmap& image, | |
| 210 history::IconType icon_type); | |
| 143 | 211 |
| 144 // Converts the image data to an SkBitmap and sets it on the NavigationEntry. | 212 // Converts the FAVICON's image data to an SkBitmap and sets it on the |
| 213 // NavigationEntry. | |
| 145 // If the TabContents has a delegate, it is notified of the new favicon | 214 // If the TabContents has a delegate, it is notified of the new favicon |
| 146 // (INVALIDATE_FAVICON). | 215 // (INVALIDATE_FAVICON). |
| 147 void UpdateFavicon(NavigationEntry* entry, | 216 void UpdateFavicon(NavigationEntry* entry, |
| 148 scoped_refptr<RefCountedMemory> data); | 217 scoped_refptr<RefCountedMemory> data); |
| 149 void UpdateFavicon(NavigationEntry* entry, const SkBitmap& image); | 218 void UpdateFavicon(NavigationEntry* entry, const SkBitmap& image); |
| 150 | 219 |
| 151 // Scales the image such that either the width and/or height is 16 pixels | 220 // Scales the image such that either the width and/or height is 16 pixels |
| 152 // wide. Does nothing if the image is empty. | 221 // wide. Does nothing if the image is empty. |
| 153 SkBitmap ConvertToFaviconSize(const SkBitmap& image); | 222 SkBitmap ConvertToFaviconSize(const SkBitmap& image); |
| 154 | 223 |
| 155 // Returns true if the favicon should be saved. | 224 void FetchFaviconInternal(); |
| 156 bool ShouldSaveFavicon(const GURL& url); | 225 |
| 226 // Return the current candidate if any. | |
| 227 FaviconURL* current_candidate() { | |
| 228 return (urls_.size() > current_url_index_) ? | |
| 229 &urls_[current_url_index_] : NULL; | |
| 230 } | |
| 157 | 231 |
| 158 // Used for history requests. | 232 // Used for history requests. |
| 159 CancelableRequestConsumer cancelable_consumer_; | 233 CancelableRequestConsumer cancelable_consumer_; |
| 160 | 234 |
| 161 // URL of the page we're requesting the favicon for. | 235 // URL of the page we're requesting the favicon for. |
| 162 GURL url_; | 236 GURL url_; |
| 163 | 237 |
| 164 // Whether we got the url for the page back from the renderer. | |
| 165 // See "Favicon Details" in tab_contents.cc for more details. | |
| 166 bool got_favicon_url_; | |
| 167 | |
| 168 // Whether we got the initial response for the favicon back from the renderer. | 238 // Whether we got the initial response for the favicon back from the renderer. |
| 169 // See "Favicon Details" in tab_contents.cc for more details. | 239 // See "Favicon Details" in tab_contents.cc for more details. |
| 170 bool got_favicon_from_history_; | 240 bool got_favicon_from_history_; |
| 171 | 241 |
| 172 // Whether the favicon is out of date. If true, it means history knows about | 242 // Whether the favicon is out of date. If true, it means history knows about |
| 173 // the favicon, but we need to download the favicon because the icon has | 243 // the favicon, but we need to download the favicon because the icon has |
| 174 // expired. | 244 // expired. |
| 175 // See "Favicon Details" in tab_contents.cc for more details. | 245 // See "Favicon Details" in tab_contents.cc for more details. |
| 176 bool favicon_expired_; | 246 bool favicon_expired_; |
| 177 | 247 |
| 178 // Requests to the renderer to download favicons. | 248 // Requests to the renderer to download favicons. |
| 179 typedef std::map<int, DownloadRequest> DownloadRequests; | 249 typedef std::map<int, DownloadRequest> DownloadRequests; |
| 180 DownloadRequests download_requests_; | 250 DownloadRequests download_requests_; |
| 181 | 251 |
| 252 // The combination of the supported icon types. | |
| 253 const int icon_types_; | |
| 254 | |
| 255 // The prioritized favicon candidates from the page back from the renderer. | |
| 256 std::vector<FaviconURL> urls_; | |
| 257 | |
| 258 // The current candidate's index in urls_. | |
| 259 size_t current_url_index_; | |
| 260 | |
| 261 // The FaviconData from history. | |
| 262 history::FaviconData history_icon_; | |
| 263 | |
| 264 // The preferred icon size for supported icon types. | |
| 265 int preferred_icon_size_; | |
|
sky
2011/03/28 15:02:58
Nuke this and calculate it from icon_types_ when y
michaelbai
2011/03/29 00:00:50
Done.
| |
| 266 | |
| 182 DISALLOW_COPY_AND_ASSIGN(FaviconHelper); | 267 DISALLOW_COPY_AND_ASSIGN(FaviconHelper); |
| 183 }; | 268 }; |
| 184 | 269 |
| 185 #endif // CHROME_BROWSER_FAVICON_HELPER_H__ | 270 #endif // CHROME_BROWSER_FAVICON_HELPER_H__ |
| OLD | NEW |