| Index: chrome/browser/ui/toolbar/wrench_menu_model.cc
 | 
| diff --git a/chrome/browser/ui/toolbar/wrench_menu_model.cc b/chrome/browser/ui/toolbar/wrench_menu_model.cc
 | 
| index 0efd669b912a0192ab62ddcabf7713a3bf0807b5..cd8a114e7f158ba6936fdbbb0b1ca9081955e58c 100644
 | 
| --- a/chrome/browser/ui/toolbar/wrench_menu_model.cc
 | 
| +++ b/chrome/browser/ui/toolbar/wrench_menu_model.cc
 | 
| @@ -221,9 +221,6 @@ WrenchMenuModel::WrenchMenuModel(menus::AcceleratorProvider* provider,
 | 
|                   Source<Profile>(browser_->profile()));
 | 
|    registrar_.Add(this, NotificationType::NAV_ENTRY_COMMITTED,
 | 
|                   NotificationService::AllSources());
 | 
| -  registrar_.Add(this,
 | 
| -                 NotificationType::BACKGROUND_PAGE_TRACKER_CHANGED,
 | 
| -                 NotificationService::AllSources());
 | 
|  }
 | 
|  
 | 
|  WrenchMenuModel::~WrenchMenuModel() {
 | 
| @@ -235,7 +232,7 @@ bool WrenchMenuModel::DoesCommandIdDismissMenu(int command_id) const {
 | 
|    return command_id != IDC_ZOOM_MINUS && command_id != IDC_ZOOM_PLUS;
 | 
|  }
 | 
|  
 | 
| -bool WrenchMenuModel::IsLabelForCommandIdDynamic(int command_id) const {
 | 
| +bool WrenchMenuModel::IsItemForCommandIdDynamic(int command_id) const {
 | 
|    return command_id == IDC_ZOOM_PERCENT_DISPLAY ||
 | 
|  #if defined(OS_MACOSX)
 | 
|           command_id == IDC_FULLSCREEN ||
 | 
| @@ -244,6 +241,26 @@ bool WrenchMenuModel::IsLabelForCommandIdDynamic(int command_id) const {
 | 
|           command_id == IDC_VIEW_BACKGROUND_PAGES;
 | 
|  }
 | 
|  
 | 
| +bool WrenchMenuModel::GetIconForCommandId(int command_id,
 | 
| +                                          SkBitmap* bitmap) const {
 | 
| +  switch (command_id) {
 | 
| +    case IDC_VIEW_BACKGROUND_PAGES: {
 | 
| +      int num_pages = BackgroundPageTracker::GetInstance()->
 | 
| +          GetUnacknowledgedBackgroundPageCount();
 | 
| +      if (num_pages > 0) {
 | 
| +        *bitmap = GetBackgroundPageIcon();
 | 
| +        return true;
 | 
| +      } else {
 | 
| +        // No icon.
 | 
| +        return false;
 | 
| +      }
 | 
| +    }
 | 
| +    default:
 | 
| +      // No icon for other dynamic menu items.
 | 
| +      return false;
 | 
| +  }
 | 
| +}
 | 
| +
 | 
|  string16 WrenchMenuModel::GetLabelForCommandId(int command_id) const {
 | 
|    switch (command_id) {
 | 
|      case IDC_SYNC_BOOKMARKS:
 | 
| @@ -350,18 +367,6 @@ void WrenchMenuModel::Observe(NotificationType type,
 | 
|                                const NotificationSource& source,
 | 
|                                const NotificationDetails& details) {
 | 
|    switch (type.value) {
 | 
| -    case NotificationType::BACKGROUND_PAGE_TRACKER_CHANGED: {
 | 
| -      int num_pages = BackgroundPageTracker::GetInstance()->
 | 
| -          GetUnacknowledgedBackgroundPageCount();
 | 
| -      if (num_pages > 0) {
 | 
| -        SetIcon(GetIndexOfCommandId(IDC_VIEW_BACKGROUND_PAGES),
 | 
| -                GetBackgroundPageIcon());
 | 
| -      } else {
 | 
| -        // Just set a blank icon (no icon).
 | 
| -        SetIcon(GetIndexOfCommandId(IDC_VIEW_BACKGROUND_PAGES), SkBitmap());
 | 
| -      }
 | 
| -      break;
 | 
| -    }
 | 
|      case NotificationType::ZOOM_LEVEL_CHANGED:
 | 
|      case NotificationType::NAV_ENTRY_COMMITTED:
 | 
|        UpdateZoomControls();
 | 
| @@ -482,14 +487,6 @@ void WrenchMenuModel::Build() {
 | 
|            *rb.GetBitmapNamed(IDR_CONFLICT_MENU));
 | 
|  #endif
 | 
|  
 | 
| -  // Add an icon to the View Background Pages item if there are unacknowledged
 | 
| -  // pages.
 | 
| -  if (BackgroundPageTracker::GetInstance()->
 | 
| -      GetUnacknowledgedBackgroundPageCount() > 0) {
 | 
| -    SetIcon(GetIndexOfCommandId(IDC_VIEW_BACKGROUND_PAGES),
 | 
| -            GetBackgroundPageIcon());
 | 
| -  }
 | 
| -
 | 
|    AddItemWithStringId(IDC_HELP_PAGE, IDS_HELP_PAGE);
 | 
|    if (browser_defaults::kShowExitMenuItem) {
 | 
|      AddSeparator();
 | 
| 
 |