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

Unified Diff: chrome/browser/ui/toolbar/back_forward_menu_model.h

Issue 2928005: Retrieve favicons from history as NavigationEntries are converted from TabNav... Base URL: http://src.chromium.org/svn/trunk/src/
Patch Set: Updated to compile against trunk. Created 9 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/toolbar/back_forward_menu_model.h
diff --git a/chrome/browser/ui/toolbar/back_forward_menu_model.h b/chrome/browser/ui/toolbar/back_forward_menu_model.h
index b1bb08c6d3a1b58c028c91a0fcc416a994369606..655369dae1d608c49354096f9e611b9457f51256 100644
--- a/chrome/browser/ui/toolbar/back_forward_menu_model.h
+++ b/chrome/browser/ui/toolbar/back_forward_menu_model.h
@@ -6,11 +6,13 @@
#define CHROME_BROWSER_UI_TOOLBAR_BACK_FORWARD_MENU_MODEL_H_
#pragma once
+#include <set>
#include <string>
#include "base/basictypes.h"
#include "base/gtest_prod_util.h"
#include "base/string16.h"
+#include "chrome/browser/favicon_service.h"
#include "ui/base/models/menu_model.h"
#include "webkit/glue/window_open_disposition.h"
@@ -53,7 +55,7 @@ class BackForwardMenuModel : public ui::MenuModel {
ui::Accelerator* accelerator) const;
virtual bool IsItemCheckedAt(int index) const;
virtual int GetGroupIdAt(int index) const;
- virtual bool GetIconAt(int index, SkBitmap* icon) const;
+ virtual bool GetIconAt(int index, SkBitmap* icon);
virtual ui::ButtonMenuItemModel* GetButtonMenuItemAt(int index) const;
virtual bool IsEnabledAt(int index) const;
virtual MenuModel* GetSubmenuModelAt(int index) const;
@@ -65,7 +67,28 @@ class BackForwardMenuModel : public ui::MenuModel {
// Is the item at |index| a separator?
bool IsSeparator(int index) const;
+ // Set the delegate for triggering OnIconChanged.
+ virtual void SetMenuModelDelegate(ui::MenuModelDelegate* menu_model_delegate);
+
+ protected:
+ ui::MenuModelDelegate* menu_model_delegate() { return menu_model_delegate_; }
+
private:
+ friend class BackFwdMenuModelTest;
+ FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, BasicCase);
+ FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, MaxItemsTest);
+ FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, ChapterStops);
+ FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, EscapeLabel);
+ FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, FaviconLoadTest);
+
+ // Requests a favicon from the FaviconService. Called by GetIconAt if the
+ // NavigationEntry has an invalid favicon.
+ void FetchFavicon(NavigationEntry* entry);
+
+ // Callback from the favicon service.
+ void OnFavIconDataAvailable(FaviconService::Handle handle,
+ history::FaviconData favicon);
+
// Allows the unit test to use its own dummy tab contents.
void set_test_tab_contents(TabContents* test_tab_contents) {
test_tab_contents_ = test_tab_contents;
@@ -160,11 +183,15 @@ class BackForwardMenuModel : public ui::MenuModel {
// back button.
ModelType model_type_;
- friend class BackFwdMenuModelTest;
- FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, BasicCase);
- FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, MaxItemsTest);
- FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, ChapterStops);
- FRIEND_TEST_ALL_PREFIXES(BackFwdMenuModelTest, EscapeLabel);
+ // Keeps track of which favicons have already been requested from the history
+ // to prevent duplicate requests, identified by NavigationEntry->unique_id().
+ std::set<int> requested_favicons_;
+
+ // Used for loading favicons from history.
+ CancelableRequestConsumerTSimple<int> load_consumer_;
+
+ // Used for receiving notifications when an icon is changed.
+ ui::MenuModelDelegate* menu_model_delegate_;
sky 2011/03/18 17:54:11 This isn't initialized in the constructor.
DISALLOW_COPY_AND_ASSIGN(BackForwardMenuModel);
};

Powered by Google App Engine
This is Rietveld 408576698