summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorxiyuan@chromium.org <xiyuan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-02-06 00:16:40 +0000
committerxiyuan@chromium.org <xiyuan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-02-06 00:16:40 +0000
commita3354454938083e933e2c988777a1c53d94b4277 (patch)
tree5cbfca015873e7c56eccefe80d1a979e500b33cb
parent50a376f0d18e4f76a3ab04c46c66df965b6b2192 (diff)
downloadchromium_src-a3354454938083e933e2c988777a1c53d94b4277.zip
chromium_src-a3354454938083e933e2c988777a1c53d94b4277.tar.gz
chromium_src-a3354454938083e933e2c988777a1c53d94b4277.tar.bz2
Rebuild app menu in ToolbarView::RunAppMenu
When "enable-udd-profiles" switch is set, update profile submenu and rebuild app menu if necessary. BUG=30417 TEST=Verify that comment 5 in issue 30417 is fixed. Review URL: http://codereview.chromium.org/571015 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@38281 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--app/menus/simple_menu_model.h11
-rw-r--r--chrome/browser/app_menu_model.cc39
-rw-r--r--chrome/browser/app_menu_model.h20
-rw-r--r--chrome/browser/views/toolbar_view.cc2
-rw-r--r--views/controls/menu/native_menu_win.cc8
5 files changed, 62 insertions, 18 deletions
diff --git a/app/menus/simple_menu_model.h b/app/menus/simple_menu_model.h
index 882e227..59e741e 100644
--- a/app/menus/simple_menu_model.h
+++ b/app/menus/simple_menu_model.h
@@ -1,6 +1,6 @@
-// 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.
+// Copyright (c) 2010 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.
#ifndef APP_MENUS_SIMPLE_MENU_MODEL_H_
#define APP_MENUS_SIMPLE_MENU_MODEL_H_
@@ -75,6 +75,11 @@ class SimpleMenuModel : public MenuModel {
void InsertSubMenuAt(int index, const string16& label, MenuModel* model);
void InsertSubMenuWithStringIdAt(int index, int string_id, MenuModel* model);
+ // Clears all items. Note that it does not free MenuModel of submenu.
+ void Clear() {
+ items_.clear();
+ }
+
// Returns the index of the item that has the given |command_id|. Returns
// -1 if not found.
int GetIndexOfCommandId(int command_id);
diff --git a/chrome/browser/app_menu_model.cc b/chrome/browser/app_menu_model.cc
index 7ecaa57..dd5ce6a 100644
--- a/chrome/browser/app_menu_model.cc
+++ b/chrome/browser/app_menu_model.cc
@@ -1,9 +1,11 @@
-// 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.
+// Copyright (c) 2010 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/app_menu_model.h"
+#include <algorithm>
+
#include "app/l10n_util.h"
#include "base/command_line.h"
#include "chrome/app/chrome_dll_resource.h"
@@ -43,9 +45,6 @@ void AppMenuModel::Build() {
// done. See OnGetProfilesDone().
const CommandLine& command_line = *CommandLine::ForCurrentProcess();
if (command_line.HasSwitch(switches::kEnableUserDataDirProfiles)) {
- // Triggers profile list refresh in case it's changed.
- UserDataManager::Get()->RefreshUserDataDirProfiles();
-
if (!profiles_menu_contents_.get()) {
profiles_menu_contents_.reset(new menus::SimpleMenuModel(delegate()));
BuildProfileSubMenu();
@@ -91,15 +90,28 @@ void AppMenuModel::Build() {
}
}
-void AppMenuModel::BuildProfileSubMenu() {
+bool AppMenuModel::BuildProfileSubMenu() {
// Nothing to do if the menu has gone away.
if (!profiles_menu_contents_.get())
- return;
+ return false;
+
+ // Triggers profile list refresh in case it's changed.
+ UserDataManager::Get()->RefreshUserDataDirProfiles();
// Use the list of profiles in the browser.
const std::vector<std::wstring>& profiles =
browser_->user_data_dir_profiles();
+ // Check if profiles have changed.
+ if (!ProfilesChanged(profiles))
+ return false;
+
+ // Update known profiles.
+ known_profiles_.assign(profiles.begin(), profiles.end());
+
+ // Clear old profile menu items.
+ profiles_menu_contents_->Clear();
+
// Add direct submenu items for profiles.
std::vector<std::wstring>::const_iterator iter = profiles.begin();
for (int i = IDC_NEW_WINDOW_PROFILE_0;
@@ -119,6 +131,17 @@ void AppMenuModel::BuildProfileSubMenu() {
profiles_menu_contents_->AddItemWithStringId(
IDC_NEW_PROFILE,
IDS_SELECT_PROFILE_DIALOG_NEW_PROFILE_ENTRY);
+
+ return true;
+}
+
+bool AppMenuModel::ProfilesChanged(
+ const std::vector<std::wstring>& profiles) const {
+ if (profiles.size() != known_profiles_.size())
+ return true;
+
+ return !std::equal(profiles.begin(), profiles.end(),
+ known_profiles_.begin());
}
string16 AppMenuModel::GetSyncMenuLabel() const {
diff --git a/chrome/browser/app_menu_model.h b/chrome/browser/app_menu_model.h
index a3d7e0e..b0daac7 100644
--- a/chrome/browser/app_menu_model.h
+++ b/chrome/browser/app_menu_model.h
@@ -1,10 +1,13 @@
-// 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.
+// Copyright (c) 2010 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.
#ifndef CHROME_BROWSER_APP_MENU_MODEL_H_
#define CHROME_BROWSER_APP_MENU_MODEL_H_
+#include <set>
+#include <vector>
+
#include "app/menus/simple_menu_model.h"
#include "base/ref_counted.h"
#include "base/scoped_ptr.h"
@@ -24,9 +27,14 @@ class AppMenuModel : public menus::SimpleMenuModel {
virtual bool IsLabelDynamicAt(int index) const;
virtual string16 GetLabelAt(int index) const;
+ // Build/update profile submenu. Return true if profiles submenu is built or
+ // updated. False otherwise.
+ bool BuildProfileSubMenu();
+
private:
void Build();
- void BuildProfileSubMenu();
+
+ bool ProfilesChanged(const std::vector<std::wstring>& profiles) const;
string16 GetSyncMenuLabel() const;
bool IsSyncItem(int index) const;
@@ -34,6 +42,10 @@ class AppMenuModel : public menus::SimpleMenuModel {
// Contents of the profiles menu to populate with profile names.
scoped_ptr<menus::SimpleMenuModel> profiles_menu_contents_;
+ // Profile names that are in profiles_menu_contents_. This is used to
+ // detect profile change.
+ std::vector<std::wstring> known_profiles_;
+
Browser* browser_; // weak
DISALLOW_COPY_AND_ASSIGN(AppMenuModel);
diff --git a/chrome/browser/views/toolbar_view.cc b/chrome/browser/views/toolbar_view.cc
index 0762ce2..cde3b64 100644
--- a/chrome/browser/views/toolbar_view.cc
+++ b/chrome/browser/views/toolbar_view.cc
@@ -706,5 +706,7 @@ void ToolbarView::RunPageMenu(const gfx::Point& pt) {
}
void ToolbarView::RunAppMenu(const gfx::Point& pt) {
+ if (app_menu_model_->BuildProfileSubMenu())
+ app_menu_menu_->Rebuild();
app_menu_menu_->RunMenuAt(pt, views::Menu2::ALIGN_TOPRIGHT);
}
diff --git a/views/controls/menu/native_menu_win.cc b/views/controls/menu/native_menu_win.cc
index 9553b73..630c7bb 100644
--- a/views/controls/menu/native_menu_win.cc
+++ b/views/controls/menu/native_menu_win.cc
@@ -1,6 +1,6 @@
-// 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.
+// Copyright (c) 2010 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 "views/controls/menu/native_menu_win.h"
@@ -334,6 +334,8 @@ void NativeMenuWin::CancelMenu() {
void NativeMenuWin::Rebuild() {
ResetNativeMenu();
+ items_.clear();
+
owner_draw_ = model_->HasIcons() || owner_draw_;
first_item_index_ = model_->GetFirstItemIndex(GetNativeMenu());
for (int menu_index = first_item_index_;