summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsimon.hong81@gmail.com <simon.hong81@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98>2013-10-23 17:16:25 +0000
committersimon.hong81@gmail.com <simon.hong81@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98>2013-10-23 17:16:25 +0000
commit3fced99a1af83ffc1aa07fec83f96c65c4eaa591 (patch)
treebb31c35c83af236ee295b93b73025ddccbcace0b
parent35f1db63561965c8744a23c3eccd89bf944dd070 (diff)
downloadchromium_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.gyp4
-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.h25
-rw-r--r--ash/shelf/shelf_util.h19
-rw-r--r--ash/shell.cc14
-rw-r--r--ash/test/test_launcher_delegate.cc1
-rw-r--r--chrome/browser/ui/ash/launcher/browser_shortcut_launcher_item_controller.cc7
-rw-r--r--chrome/browser/ui/ash/launcher/chrome_launcher_controller.cc5
-rw-r--r--chrome/browser/ui/ash/launcher/chrome_launcher_controller_browsertest.cc14
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));