| Index: chrome/browser/browser.cc
|
| diff --git a/chrome/browser/browser.cc b/chrome/browser/browser.cc
|
| index 832516c6298e395b06c13689051d341865b09ea1..07b16c1a74db4e19e125ed7c81a961ec522ee4d5 100644
|
| --- a/chrome/browser/browser.cc
|
| +++ b/chrome/browser/browser.cc
|
| @@ -236,6 +236,9 @@ Browser::Browser(Type type, Profile* profile)
|
| tab_restore_service_->AddObserver(this);
|
| TabRestoreServiceChanged(tab_restore_service_);
|
| }
|
| +
|
| + if (profile_->GetProfileSyncService())
|
| + profile_->GetProfileSyncService()->AddObserver(this);
|
| }
|
|
|
| Browser::~Browser() {
|
| @@ -243,6 +246,9 @@ Browser::~Browser() {
|
| DCHECK(!tabstrip_model_.HasNonPhantomTabs());
|
| tabstrip_model_.RemoveObserver(this);
|
|
|
| + if (profile_->GetProfileSyncService())
|
| + profile_->GetProfileSyncService()->RemoveObserver(this);
|
| +
|
| BrowserList::RemoveBrowser(this);
|
|
|
| #if defined(OS_WIN) || defined(OS_LINUX)
|
| @@ -1059,8 +1065,8 @@ void Browser::UpdateCommandsForFullscreenMode(bool is_fullscreen) {
|
| command_updater_.UpdateCommandEnabled(IDC_REPORT_BUG, show_main_ui);
|
| command_updater_.UpdateCommandEnabled(IDC_SHOW_BOOKMARK_BAR, show_main_ui);
|
| command_updater_.UpdateCommandEnabled(IDC_IMPORT_SETTINGS, show_main_ui);
|
| - command_updater_.UpdateCommandEnabled(
|
| - IDC_SYNC_BOOKMARKS, show_main_ui && ProfileSyncService::IsSyncEnabled());
|
| + command_updater_.UpdateCommandEnabled(IDC_SYNC_BOOKMARKS,
|
| + show_main_ui && profile_->IsSyncAccessible());
|
| command_updater_.UpdateCommandEnabled(IDC_OPTIONS, show_main_ui);
|
| command_updater_.UpdateCommandEnabled(IDC_EDIT_SEARCH_ENGINES, show_main_ui);
|
| command_updater_.UpdateCommandEnabled(IDC_VIEW_PASSWORDS, show_main_ui);
|
| @@ -3031,6 +3037,21 @@ void Browser::Observe(NotificationType type,
|
| }
|
| }
|
|
|
| +///////////////////////////////////////////////////////////////////////////////
|
| +// Browser, ProfileSyncServiceObserver implementation:
|
| +
|
| +void Browser::OnStateChanged() {
|
| + DCHECK(profile_->GetProfileSyncService());
|
| +
|
| +#if !defined(OS_MACOSX)
|
| + const bool show_main_ui = (type() == TYPE_NORMAL) && !window_->IsFullscreen();
|
| +#else
|
| + const bool show_main_ui = (type() == TYPE_NORMAL);
|
| +#endif
|
| +
|
| + command_updater_.UpdateCommandEnabled(IDC_SYNC_BOOKMARKS,
|
| + show_main_ui && profile_->IsSyncAccessible());
|
| +}
|
|
|
| ///////////////////////////////////////////////////////////////////////////////
|
| // Browser, Command and state updating (private):
|
|
|