diff options
author | simon.hong81@gmail.com <simon.hong81@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-10-23 17:16:25 +0000 |
---|---|---|
committer | simon.hong81@gmail.com <simon.hong81@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-10-23 17:16:25 +0000 |
commit | 3fced99a1af83ffc1aa07fec83f96c65c4eaa591 (patch) | |
tree | bb31c35c83af236ee295b93b73025ddccbcace0b | |
parent | 35f1db63561965c8744a23c3eccd89bf944dd070 (diff) | |
download | chromium_src-3fced99a1af83ffc1aa07fec83f96c65c4eaa591.zip chromium_src-3fced99a1af83ffc1aa07fec83f96c65c4eaa591.tar.gz chromium_src-3fced99a1af83ffc1aa07fec83f96c65c4eaa591.tar.bz2 |
Change GetBrowserItemIndex() to GetLauncherItemIndexForType()
Makes GetBrowserItemIndex() more general function to get item index.
Move this function to ./ash/launcher/launcher_item_util.h
R=sky@chromium.org
BUG=NONE
TEST=browser_tests, ash_unittests
Review URL: https://codereview.chromium.org/27369004
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@230456 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | ash/ash.gyp | 4 | ||||
-rw-r--r-- | ash/launcher/launcher_model_util.cc (renamed from ash/shelf/shelf_util.cc) | 8 | ||||
-rw-r--r-- | ash/launcher/launcher_model_util.h | 25 | ||||
-rw-r--r-- | ash/shelf/shelf_util.h | 19 | ||||
-rw-r--r-- | ash/shell.cc | 14 | ||||
-rw-r--r-- | ash/test/test_launcher_delegate.cc | 1 | ||||
-rw-r--r-- | chrome/browser/ui/ash/launcher/browser_shortcut_launcher_item_controller.cc | 7 | ||||
-rw-r--r-- | chrome/browser/ui/ash/launcher/chrome_launcher_controller.cc | 5 | ||||
-rw-r--r-- | chrome/browser/ui/ash/launcher/chrome_launcher_controller_browsertest.cc | 14 |
9 files changed, 48 insertions, 49 deletions
diff --git a/ash/ash.gyp b/ash/ash.gyp index df74c49..d8aeaaa 100644 --- a/ash/ash.gyp +++ b/ash/ash.gyp @@ -162,6 +162,8 @@ 'launcher/launcher_model.cc', 'launcher/launcher_model.h', 'launcher/launcher_model_observer.h', + 'launcher/launcher_model_util.cc', + 'launcher/launcher_model_util.h', 'launcher/launcher_types.cc', 'launcher/launcher_types.h', 'magnifier/magnification_controller.cc', @@ -213,8 +215,6 @@ 'shelf/shelf_tooltip_manager.cc', 'shelf/shelf_tooltip_manager.h', 'shelf/shelf_types.h', - 'shelf/shelf_util.cc', - 'shelf/shelf_util.h', 'shelf/shelf_view.cc', 'shelf/shelf_view.h', 'shelf/shelf_widget.cc', diff --git a/ash/shelf/shelf_util.cc b/ash/launcher/launcher_model_util.cc index 07dfbbe..b1d63a4 100644 --- a/ash/shelf/shelf_util.cc +++ b/ash/launcher/launcher_model_util.cc @@ -2,16 +2,16 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "ash/shelf/shelf_util.h" +#include "ash/launcher/launcher_model_util.h" #include "ash/launcher/launcher_model.h" -#include "ash/launcher/launcher_types.h" namespace ash { -int GetBrowserItemIndex(const LauncherModel& launcher_model) { +int GetLauncherItemIndexForType(LauncherItemType type, + const LauncherModel& launcher_model) { for (size_t i = 0; i < launcher_model.items().size(); i++) { - if (launcher_model.items()[i].type == ash::TYPE_BROWSER_SHORTCUT) + if (launcher_model.items()[i].type == type) return i; } return -1; diff --git a/ash/launcher/launcher_model_util.h b/ash/launcher/launcher_model_util.h new file mode 100644 index 0000000..9cc9932 --- /dev/null +++ b/ash/launcher/launcher_model_util.h @@ -0,0 +1,25 @@ +// Copyright 2013 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 ASH_LAUNCHER_LAUNCHER_MODEL_UTIL_H_ +#define ASH_LAUNCHER_LAUNCHER_MODEL_UTIL_H_ + +#include "ash/ash_export.h" +#include "ash/launcher/launcher_types.h" + +namespace ash { + +class LauncherModel; + +// Return the index of the |type| from a given |launcher_model|. +// Note: +// * If there are many items for |type| in the |launcher_model|, an index of +// first item will be returned. +// * If there is no item for |type|, -1 will be returned. +ASH_EXPORT int GetLauncherItemIndexForType(LauncherItemType type, + const LauncherModel& launcher_model); + +} // namespace ash + +#endif // ASH_LAUNCHER_LAUNCHER_MODEL_UTIL_H_ diff --git a/ash/shelf/shelf_util.h b/ash/shelf/shelf_util.h deleted file mode 100644 index daf6c0f..0000000 --- a/ash/shelf/shelf_util.h +++ /dev/null @@ -1,19 +0,0 @@ -// Copyright 2013 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 ASH_SHELF_SHELF_UTIL_H_ -#define ASH_SHELF_SHELF_UTIL_H_ - -#include "ash/ash_export.h" - -namespace ash { - -class LauncherModel; - -// Return the index of the browser item from a given |launcher_model|. -ASH_EXPORT int GetBrowserItemIndex(const LauncherModel& launcher_model); - -} // namespace ash - -#endif // ASH_SHELF_SHELF_UTIL_H_ diff --git a/ash/shell.cc b/ash/shell.cc index 6e25c52..b87a946 100644 --- a/ash/shell.cc +++ b/ash/shell.cc @@ -33,6 +33,7 @@ #include "ash/launcher/launcher_item_delegate.h" #include "ash/launcher/launcher_item_delegate_manager.h" #include "ash/launcher/launcher_model.h" +#include "ash/launcher/launcher_model_util.h" #include "ash/magnifier/magnification_controller.h" #include "ash/magnifier/partial_magnification_controller.h" #include "ash/root_window_controller.h" @@ -40,7 +41,6 @@ #include "ash/session_state_delegate.h" #include "ash/shelf/app_list_shelf_item_delegate.h" #include "ash/shelf/shelf_layout_manager.h" -#include "ash/shelf/shelf_util.h" #include "ash/shelf/shelf_widget.h" #include "ash/shell_delegate.h" #include "ash/shell_factory.h" @@ -491,16 +491,12 @@ LauncherDelegate* Shell::GetLauncherDelegate() { scoped_ptr<LauncherItemDelegate> controller( new internal::AppListShelfItemDelegate); - ash::LauncherID app_list_id = 0; - // TODO(simon.hong81): Make function for this in shelf_util.h // Finding the launcher model's location of the app list and setting its // LauncherItemDelegate. - for (size_t i = 0; i < launcher_model_->items().size(); ++i) { - if (launcher_model_->items()[i].type == ash::TYPE_APP_LIST) { - app_list_id = launcher_model_->items()[i].id; - break; - } - } + int app_list_index = + ash::GetLauncherItemIndexForType(ash::TYPE_APP_LIST, *launcher_model_); + DCHECK_GE(app_list_index, 0); + ash::LauncherID app_list_id = launcher_model_->items()[app_list_index].id; DCHECK(app_list_id); launcher_item_delegate_manager_->SetLauncherItemDelegate( app_list_id, diff --git a/ash/test/test_launcher_delegate.cc b/ash/test/test_launcher_delegate.cc index 98f1db0..1867980 100644 --- a/ash/test/test_launcher_delegate.cc +++ b/ash/test/test_launcher_delegate.cc @@ -6,7 +6,6 @@ #include "ash/launcher/launcher_item_delegate_manager.h" #include "ash/launcher/launcher_model.h" -#include "ash/shelf/shelf_util.h" #include "ash/shell.h" #include "ash/test/test_launcher_item_delegate.h" #include "base/strings/string_util.h" diff --git a/chrome/browser/ui/ash/launcher/browser_shortcut_launcher_item_controller.cc b/chrome/browser/ui/ash/launcher/browser_shortcut_launcher_item_controller.cc index 8412877..2ee9a09 100644 --- a/chrome/browser/ui/ash/launcher/browser_shortcut_launcher_item_controller.cc +++ b/chrome/browser/ui/ash/launcher/browser_shortcut_launcher_item_controller.cc @@ -8,7 +8,7 @@ #include "ash/launcher/launcher.h" #include "ash/launcher/launcher_model.h" -#include "ash/shelf/shelf_util.h" +#include "ash/launcher/launcher_model_util.h" #include "ash/shell.h" #include "ash/wm/window_util.h" #include "chrome/browser/profiles/profile.h" @@ -60,8 +60,9 @@ void BrowserShortcutLauncherItemController::UpdateBrowserItemState() { ash::LauncherModel* model = launcher_controller()->model(); // Determine the new browser's active state and change if necessary. - size_t browser_index = ash::GetBrowserItemIndex(*model); - DCHECK_GE(browser_index, 0u); + int browser_index = + ash::GetLauncherItemIndexForType(ash::TYPE_BROWSER_SHORTCUT, *model); + DCHECK_GE(browser_index, 0); ash::LauncherItem browser_item = model->items()[browser_index]; ash::LauncherItemStatus browser_status = ash::STATUS_CLOSED; diff --git a/chrome/browser/ui/ash/launcher/chrome_launcher_controller.cc b/chrome/browser/ui/ash/launcher/chrome_launcher_controller.cc index 5bca6e2..0e934f0 100644 --- a/chrome/browser/ui/ash/launcher/chrome_launcher_controller.cc +++ b/chrome/browser/ui/ash/launcher/chrome_launcher_controller.cc @@ -11,9 +11,9 @@ #include "ash/launcher/launcher.h" #include "ash/launcher/launcher_item_delegate_manager.h" #include "ash/launcher/launcher_model.h" +#include "ash/launcher/launcher_model_util.h" #include "ash/root_window_controller.h" #include "ash/shelf/shelf_layout_manager.h" -#include "ash/shelf/shelf_util.h" #include "ash/shelf/shelf_widget.h" #include "ash/shell.h" #include "ash/wm/window_util.h" @@ -962,7 +962,8 @@ void ChromeLauncherController::ActivateWindowOrMinimizeIfActive( } ash::LauncherID ChromeLauncherController::GetIDByWindow(aura::Window* window) { - int browser_index = ash::GetBrowserItemIndex(*model_); + int browser_index = + ash::GetLauncherItemIndexForType(ash::TYPE_BROWSER_SHORTCUT, *model_); DCHECK_GE(browser_index, 0); ash::LauncherID browser_id = model_->items()[browser_index].id; diff --git a/chrome/browser/ui/ash/launcher/chrome_launcher_controller_browsertest.cc b/chrome/browser/ui/ash/launcher/chrome_launcher_controller_browsertest.cc index 68f56da..16eaf72 100644 --- a/chrome/browser/ui/ash/launcher/chrome_launcher_controller_browsertest.cc +++ b/chrome/browser/ui/ash/launcher/chrome_launcher_controller_browsertest.cc @@ -12,7 +12,7 @@ #include "ash/launcher/launcher.h" #include "ash/launcher/launcher_button.h" #include "ash/launcher/launcher_model.h" -#include "ash/shelf/shelf_util.h" +#include "ash/launcher/launcher_model_util.h" #include "ash/shelf/shelf_view.h" #include "ash/shell.h" #include "ash/test/app_list_controller_test_api.h" @@ -269,11 +269,7 @@ class LauncherAppBrowserTest : public ExtensionBrowserTest { // Get the index of an item which has the given type. int GetIndexOfLauncherItemType(ash::LauncherItemType type) { - for (int i = 0; i < model_->item_count(); i++) { - if (model_->items()[i].type == type) - return i; - } - return -1; + return ash::GetLauncherItemIndexForType(type, *model_); } // Try to rip off |item_index|. @@ -1031,7 +1027,7 @@ IN_PROC_BROWSER_TEST_F(LauncherAppBrowserTest, Navigation) { IN_PROC_BROWSER_TEST_F(LauncherAppBrowserTest, TabDragAndDrop) { TabStripModel* tab_strip_model1 = browser()->tab_strip_model(); EXPECT_EQ(1, tab_strip_model1->count()); - int browser_index = ash::GetBrowserItemIndex(*model_); + int browser_index = GetIndexOfLauncherItemType(ash::TYPE_BROWSER_SHORTCUT); EXPECT_TRUE(browser_index >= 0); EXPECT_EQ(1u, chrome::GetTotalBrowserCount()); @@ -1174,7 +1170,7 @@ IN_PROC_BROWSER_TEST_F(LauncherAppBrowserTest, RefocusFilterLaunch) { IN_PROC_BROWSER_TEST_F(LauncherAppBrowserTest, ActivationStateCheck) { TabStripModel* tab_strip = browser()->tab_strip_model(); // Get the browser item index - int browser_index = ash::GetBrowserItemIndex(*controller_->model()); + int browser_index = GetIndexOfLauncherItemType(ash::TYPE_BROWSER_SHORTCUT); EXPECT_TRUE(browser_index >= 0); // Even though we are just comming up, the browser should be active. @@ -1838,7 +1834,7 @@ IN_PROC_BROWSER_TEST_F(LauncherAppBrowserTest, MatchingLauncherIDandActiveTab) { aura::Window* window = browser()->window()->GetNativeWindow(); - int browser_index = ash::GetBrowserItemIndex(*model_); + int browser_index = GetIndexOfLauncherItemType(ash::TYPE_BROWSER_SHORTCUT); ash::LauncherID browser_id = model_->items()[browser_index].id; EXPECT_EQ(browser_id, controller_->GetIDByWindow(window)); |