Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(48)

Side by Side Diff: chrome/browser/ui/views/accelerator_table.cc

Issue 2074643003: MacViews: Views accelerators table should match the Cocoa one. (Closed) Base URL: ssh://bitbucket.browser.yandex-team.ru/chromium/src.git@master
Patch Set: #ifdef out the Alt accelerators, sort the #if !Mac accelerators, fix includes. Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/views/accelerator_table.h" 5 #include "chrome/browser/ui/views/accelerator_table.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <algorithm>
10 #include <initializer_list>
11 #include <set>
12 #include <tuple>
tapted 2016/11/11 00:02:19 I think you can remove all of these now
themblsha 2016/11/11 12:20:33 Done.
13
9 #include "base/macros.h" 14 #include "base/macros.h"
10 #include "build/build_config.h" 15 #include "build/build_config.h"
11 #include "chrome/app/chrome_command_ids.h" 16 #include "chrome/app/chrome_command_ids.h"
12 #include "ui/base/accelerators/accelerator.h" 17 #include "ui/base/accelerators/accelerator.h"
13 #include "ui/events/event_constants.h" 18 #include "ui/events/event_constants.h"
14 19
15 #if defined(USE_ASH) 20 #if defined(USE_ASH)
16 #include "ash/common/accelerators/accelerator_table.h" // nogncheck 21 #include "ash/common/accelerators/accelerator_table.h" // nogncheck
17 #endif 22 #endif
18 23
19 namespace chrome { 24 namespace chrome {
20 namespace { 25 namespace {
21 26
22 // For many commands, the Mac equivalent uses Cmd instead of Ctrl. We only need 27 // For many commands, the Mac equivalent uses Cmd instead of Ctrl. We only need
23 // to list the ones that do not have a key equivalent in the main menu, i.e. 28 // to list the ones that do not have a key equivalent in the main menu, i.e.
24 // only the ones in global_keyboard_shortcuts_mac.mm. 29 // only the ones in global_keyboard_shortcuts_mac.mm.
25 // TODO(jackhou): If-def out the accelerators that should not be on Mac.
26 #if defined(OS_MACOSX) 30 #if defined(OS_MACOSX)
27 const ui::EventFlags kPlatformModifier = ui::EF_COMMAND_DOWN; 31 const ui::EventFlags kPlatformModifier = ui::EF_COMMAND_DOWN;
28 #else 32 #else
29 const ui::EventFlags kPlatformModifier = ui::EF_CONTROL_DOWN; 33 const ui::EventFlags kPlatformModifier = ui::EF_CONTROL_DOWN;
30 #endif 34 #endif
31 35
32 // NOTE: Keep this list in the same (mostly-alphabetical) order as 36 // NOTE: Keep this list in the same (mostly-alphabetical) order as
tapted 2016/11/11 00:02:18 Perhaps update this comment. Something like, "Betw
themblsha 2016/11/11 12:20:32 Thanks!
33 // the Windows accelerators in ../../app/chrome_dll.rc. 37 // the Windows accelerators in ../../app/chrome_dll.rc.
34 // Do not use Ctrl-Alt as a shortcut modifier, as it is used by i18n keyboards: 38 // Do not use Ctrl-Alt as a shortcut modifier, as it is used by i18n keyboards:
35 // http://blogs.msdn.com/b/oldnewthing/archive/2004/03/29/101121.aspx 39 // http://blogs.msdn.com/b/oldnewthing/archive/2004/03/29/101121.aspx
36 const AcceleratorMapping kAcceleratorMap[] = { 40 const AcceleratorMapping kAcceleratorMap[] = {
37 { ui::VKEY_LEFT, ui::EF_ALT_DOWN, IDC_BACK },
38 { ui::VKEY_BACK, ui::EF_NONE, IDC_BACKSPACE_BACK }, 41 { ui::VKEY_BACK, ui::EF_NONE, IDC_BACKSPACE_BACK },
39 { ui::VKEY_D, ui::EF_CONTROL_DOWN, IDC_BOOKMARK_PAGE }, 42 { ui::VKEY_D, kPlatformModifier, IDC_BOOKMARK_PAGE },
40 { ui::VKEY_D, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 43 { ui::VKEY_D, ui::EF_SHIFT_DOWN | kPlatformModifier,
41 IDC_BOOKMARK_ALL_TABS }, 44 IDC_BOOKMARK_ALL_TABS },
42 { ui::VKEY_W, ui::EF_CONTROL_DOWN, IDC_CLOSE_TAB }, 45 { ui::VKEY_W, kPlatformModifier, IDC_CLOSE_TAB },
43 { ui::VKEY_W, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_CLOSE_WINDOW }, 46 { ui::VKEY_W, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_CLOSE_WINDOW },
44 { ui::VKEY_F, ui::EF_CONTROL_DOWN, IDC_FIND }, 47 { ui::VKEY_F, kPlatformModifier, IDC_FIND },
45 { ui::VKEY_G, ui::EF_CONTROL_DOWN, IDC_FIND_NEXT }, 48 { ui::VKEY_G, kPlatformModifier, IDC_FIND_NEXT },
46 { ui::VKEY_G, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_FIND_PREVIOUS }, 49 { ui::VKEY_G, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_FIND_PREVIOUS },
47 { ui::VKEY_D, ui::EF_ALT_DOWN, IDC_FOCUS_LOCATION }, 50 { ui::VKEY_L, kPlatformModifier, IDC_FOCUS_LOCATION },
48 { ui::VKEY_L, ui::EF_CONTROL_DOWN, IDC_FOCUS_LOCATION },
49 { ui::VKEY_K, ui::EF_CONTROL_DOWN, IDC_FOCUS_SEARCH },
50 { ui::VKEY_E, ui::EF_CONTROL_DOWN, IDC_FOCUS_SEARCH },
51 { ui::VKEY_T, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_TOOLBAR },
52 { ui::VKEY_B, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_BOOKMARKS },
53 { ui::VKEY_A, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_INFOBARS },
54 { ui::VKEY_RIGHT, ui::EF_ALT_DOWN, IDC_FORWARD },
55 { ui::VKEY_BACK, ui::EF_SHIFT_DOWN, IDC_BACKSPACE_FORWARD }, 51 { ui::VKEY_BACK, ui::EF_SHIFT_DOWN, IDC_BACKSPACE_FORWARD },
56 { ui::VKEY_I, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_DEV_TOOLS },
57 { ui::VKEY_F12, ui::EF_NONE, IDC_DEV_TOOLS_TOGGLE }, 52 { ui::VKEY_F12, ui::EF_NONE, IDC_DEV_TOOLS_TOGGLE },
58 { ui::VKEY_J, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 53 { ui::VKEY_O, kPlatformModifier, IDC_OPEN_FILE },
59 IDC_DEV_TOOLS_CONSOLE }, 54 { ui::VKEY_P, kPlatformModifier, IDC_PRINT },
60 { ui::VKEY_C, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 55 { ui::VKEY_R, kPlatformModifier, IDC_RELOAD },
61 IDC_DEV_TOOLS_INSPECT }, 56 { ui::VKEY_R, ui::EF_SHIFT_DOWN | kPlatformModifier,
62 { ui::VKEY_O, ui::EF_CONTROL_DOWN, IDC_OPEN_FILE },
63 { ui::VKEY_P, ui::EF_CONTROL_DOWN, IDC_PRINT},
64 #if defined(ENABLE_BASIC_PRINTING)
65 { ui::VKEY_P, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_BASIC_PRINT},
66 #endif // ENABLE_BASIC_PRINTING
67 { ui::VKEY_R, ui::EF_CONTROL_DOWN, IDC_RELOAD },
68 { ui::VKEY_R, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
69 IDC_RELOAD_BYPASSING_CACHE }, 57 IDC_RELOAD_BYPASSING_CACHE },
70 { ui::VKEY_HOME, ui::EF_ALT_DOWN, IDC_HOME }, 58 { ui::VKEY_S, kPlatformModifier, IDC_SAVE_PAGE },
71 { ui::VKEY_S, ui::EF_CONTROL_DOWN, IDC_SAVE_PAGE },
72 { ui::VKEY_9, kPlatformModifier, IDC_SELECT_LAST_TAB }, 59 { ui::VKEY_9, kPlatformModifier, IDC_SELECT_LAST_TAB },
73 { ui::VKEY_NUMPAD9, kPlatformModifier, IDC_SELECT_LAST_TAB }, 60 { ui::VKEY_NUMPAD9, kPlatformModifier, IDC_SELECT_LAST_TAB },
74 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) 61 #if defined(OS_LINUX) && !defined(OS_CHROMEOS)
75 { ui::VKEY_9, ui::EF_ALT_DOWN, IDC_SELECT_LAST_TAB }, 62 { ui::VKEY_9, ui::EF_ALT_DOWN, IDC_SELECT_LAST_TAB },
76 { ui::VKEY_NUMPAD9, ui::EF_ALT_DOWN, IDC_SELECT_LAST_TAB }, 63 { ui::VKEY_NUMPAD9, ui::EF_ALT_DOWN, IDC_SELECT_LAST_TAB },
77 { ui::VKEY_NEXT, ui::EF_CONTROL_DOWN | ui::EF_SHIFT_DOWN, IDC_MOVE_TAB_NEXT }, 64 { ui::VKEY_NEXT, ui::EF_CONTROL_DOWN | ui::EF_SHIFT_DOWN, IDC_MOVE_TAB_NEXT },
78 { ui::VKEY_PRIOR, ui::EF_CONTROL_DOWN | ui::EF_SHIFT_DOWN, 65 { ui::VKEY_PRIOR, ui::EF_CONTROL_DOWN | ui::EF_SHIFT_DOWN,
79 IDC_MOVE_TAB_PREVIOUS }, 66 IDC_MOVE_TAB_PREVIOUS },
80 #endif 67 #endif
81 { ui::VKEY_TAB, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB }, 68 { ui::VKEY_TAB, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB },
tapted 2016/11/11 00:02:19 The "Control modifier is rarely used on Mac, so we
themblsha 2016/11/11 12:20:33 Done.
82 { ui::VKEY_NEXT, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB }, 69 { ui::VKEY_NEXT, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB },
83 { ui::VKEY_TAB, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 70 { ui::VKEY_TAB, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
84 IDC_SELECT_PREVIOUS_TAB }, 71 IDC_SELECT_PREVIOUS_TAB },
85 { ui::VKEY_PRIOR, ui::EF_CONTROL_DOWN, IDC_SELECT_PREVIOUS_TAB }, 72 { ui::VKEY_PRIOR, ui::EF_CONTROL_DOWN, IDC_SELECT_PREVIOUS_TAB },
86 { ui::VKEY_1, kPlatformModifier, IDC_SELECT_TAB_0 }, 73 { ui::VKEY_1, kPlatformModifier, IDC_SELECT_TAB_0 },
87 { ui::VKEY_NUMPAD1, kPlatformModifier, IDC_SELECT_TAB_0 }, 74 { ui::VKEY_NUMPAD1, kPlatformModifier, IDC_SELECT_TAB_0 },
88 { ui::VKEY_2, kPlatformModifier, IDC_SELECT_TAB_1 }, 75 { ui::VKEY_2, kPlatformModifier, IDC_SELECT_TAB_1 },
89 { ui::VKEY_NUMPAD2, kPlatformModifier, IDC_SELECT_TAB_1 }, 76 { ui::VKEY_NUMPAD2, kPlatformModifier, IDC_SELECT_TAB_1 },
90 { ui::VKEY_3, kPlatformModifier, IDC_SELECT_TAB_2 }, 77 { ui::VKEY_3, kPlatformModifier, IDC_SELECT_TAB_2 },
91 { ui::VKEY_NUMPAD3, kPlatformModifier, IDC_SELECT_TAB_2 }, 78 { ui::VKEY_NUMPAD3, kPlatformModifier, IDC_SELECT_TAB_2 },
(...skipping 18 matching lines...) Expand all
110 { ui::VKEY_NUMPAD4, ui::EF_ALT_DOWN, IDC_SELECT_TAB_3 }, 97 { ui::VKEY_NUMPAD4, ui::EF_ALT_DOWN, IDC_SELECT_TAB_3 },
111 { ui::VKEY_5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 }, 98 { ui::VKEY_5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 },
112 { ui::VKEY_NUMPAD5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 }, 99 { ui::VKEY_NUMPAD5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 },
113 { ui::VKEY_6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 }, 100 { ui::VKEY_6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 },
114 { ui::VKEY_NUMPAD6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 }, 101 { ui::VKEY_NUMPAD6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 },
115 { ui::VKEY_7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 }, 102 { ui::VKEY_7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 },
116 { ui::VKEY_NUMPAD7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 }, 103 { ui::VKEY_NUMPAD7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 },
117 { ui::VKEY_8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 }, 104 { ui::VKEY_8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 },
118 { ui::VKEY_NUMPAD8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 }, 105 { ui::VKEY_NUMPAD8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 },
119 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_BAR }, 106 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_BAR },
120 #endif 107 #endif
tapted 2016/11/11 00:02:18 // OS_LINIUX && !OS_CHROMEOS
themblsha 2016/11/11 12:20:32 Done.
121 { ui::VKEY_B, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 108 { ui::VKEY_B, ui::EF_SHIFT_DOWN | kPlatformModifier,
122 IDC_SHOW_BOOKMARK_BAR }, 109 IDC_SHOW_BOOKMARK_BAR },
123 { ui::VKEY_O, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
124 IDC_SHOW_BOOKMARK_MANAGER },
125 { ui::VKEY_J, ui::EF_CONTROL_DOWN, IDC_SHOW_DOWNLOADS },
126 { ui::VKEY_H, ui::EF_CONTROL_DOWN, IDC_SHOW_HISTORY },
127 { ui::VKEY_F, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU},
128 { ui::VKEY_E, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU},
129 { ui::VKEY_ESCAPE, ui::EF_NONE, IDC_STOP }, 110 { ui::VKEY_ESCAPE, ui::EF_NONE, IDC_STOP },
130 { ui::VKEY_U, ui::EF_CONTROL_DOWN, IDC_VIEW_SOURCE }, 111 { ui::VKEY_OEM_MINUS, kPlatformModifier, IDC_ZOOM_MINUS },
131 { ui::VKEY_OEM_MINUS, ui::EF_CONTROL_DOWN, IDC_ZOOM_MINUS }, 112 { ui::VKEY_SUBTRACT, kPlatformModifier, IDC_ZOOM_MINUS },
132 { ui::VKEY_SUBTRACT, ui::EF_CONTROL_DOWN, IDC_ZOOM_MINUS }, 113 { ui::VKEY_0, kPlatformModifier, IDC_ZOOM_NORMAL },
133 { ui::VKEY_0, ui::EF_CONTROL_DOWN, IDC_ZOOM_NORMAL }, 114 { ui::VKEY_NUMPAD0, kPlatformModifier, IDC_ZOOM_NORMAL },
134 { ui::VKEY_NUMPAD0, ui::EF_CONTROL_DOWN, IDC_ZOOM_NORMAL }, 115 { ui::VKEY_OEM_PLUS, kPlatformModifier, IDC_ZOOM_PLUS },
135 { ui::VKEY_OEM_PLUS, ui::EF_CONTROL_DOWN, IDC_ZOOM_PLUS }, 116 { ui::VKEY_ADD, kPlatformModifier, IDC_ZOOM_PLUS },
136 { ui::VKEY_ADD, ui::EF_CONTROL_DOWN, IDC_ZOOM_PLUS }, 117
118 #if !defined(OS_MACOSX) // Function keys aren't mapped on Mac.
137 { ui::VKEY_F1, ui::EF_NONE, IDC_HELP_PAGE_VIA_KEYBOARD }, 119 { ui::VKEY_F1, ui::EF_NONE, IDC_HELP_PAGE_VIA_KEYBOARD },
138 { ui::VKEY_F3, ui::EF_NONE, IDC_FIND_NEXT }, 120 { ui::VKEY_F3, ui::EF_NONE, IDC_FIND_NEXT },
139 { ui::VKEY_F3, ui::EF_SHIFT_DOWN, IDC_FIND_PREVIOUS }, 121 { ui::VKEY_F3, ui::EF_SHIFT_DOWN, IDC_FIND_PREVIOUS },
140 { ui::VKEY_F4, ui::EF_CONTROL_DOWN, IDC_CLOSE_TAB }, 122 { ui::VKEY_F4, ui::EF_CONTROL_DOWN, IDC_CLOSE_TAB },
141 { ui::VKEY_F4, ui::EF_ALT_DOWN, IDC_CLOSE_WINDOW }, 123 { ui::VKEY_F4, ui::EF_ALT_DOWN, IDC_CLOSE_WINDOW },
142 { ui::VKEY_F5, ui::EF_NONE, IDC_RELOAD }, 124 { ui::VKEY_F5, ui::EF_NONE, IDC_RELOAD },
143 { ui::VKEY_F5, ui::EF_CONTROL_DOWN, IDC_RELOAD_BYPASSING_CACHE }, 125 { ui::VKEY_F5, ui::EF_CONTROL_DOWN, IDC_RELOAD_BYPASSING_CACHE },
144 { ui::VKEY_F5, ui::EF_SHIFT_DOWN, IDC_RELOAD_BYPASSING_CACHE }, 126 { ui::VKEY_F5, ui::EF_SHIFT_DOWN, IDC_RELOAD_BYPASSING_CACHE },
145 { ui::VKEY_F6, ui::EF_NONE, IDC_FOCUS_NEXT_PANE }, 127 { ui::VKEY_F6, ui::EF_NONE, IDC_FOCUS_NEXT_PANE },
146 { ui::VKEY_F6, ui::EF_SHIFT_DOWN, IDC_FOCUS_PREVIOUS_PANE }, 128 { ui::VKEY_F6, ui::EF_SHIFT_DOWN, IDC_FOCUS_PREVIOUS_PANE },
147 { ui::VKEY_F10, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 129 { ui::VKEY_F10, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
148 { ui::VKEY_F11, ui::EF_NONE, IDC_FULLSCREEN }, 130 { ui::VKEY_F11, ui::EF_NONE, IDC_FULLSCREEN },
131 #endif // !OS_MACOSX
149 132
150 // Platform-specific key maps. 133 // Platform-specific key maps.
151 #if defined(OS_LINUX) 134 #if defined(OS_LINUX)
152 { ui::VKEY_BROWSER_BACK, ui::EF_NONE, IDC_BACK }, 135 { ui::VKEY_BROWSER_BACK, ui::EF_NONE, IDC_BACK },
153 { ui::VKEY_BROWSER_FORWARD, ui::EF_NONE, IDC_FORWARD }, 136 { ui::VKEY_BROWSER_FORWARD, ui::EF_NONE, IDC_FORWARD },
154 { ui::VKEY_BROWSER_HOME, ui::EF_NONE, IDC_HOME }, 137 { ui::VKEY_BROWSER_HOME, ui::EF_NONE, IDC_HOME },
155 { ui::VKEY_BROWSER_REFRESH, ui::EF_NONE, IDC_RELOAD }, 138 { ui::VKEY_BROWSER_REFRESH, ui::EF_NONE, IDC_RELOAD },
156 { ui::VKEY_BROWSER_REFRESH, ui::EF_CONTROL_DOWN, IDC_RELOAD_BYPASSING_CACHE }, 139 { ui::VKEY_BROWSER_REFRESH, ui::EF_CONTROL_DOWN, IDC_RELOAD_BYPASSING_CACHE },
157 { ui::VKEY_BROWSER_REFRESH, ui::EF_SHIFT_DOWN, IDC_RELOAD_BYPASSING_CACHE }, 140 { ui::VKEY_BROWSER_REFRESH, ui::EF_SHIFT_DOWN, IDC_RELOAD_BYPASSING_CACHE },
158 #endif // defined(OS_LINUX) 141 #endif // defined(OS_LINUX)
159 142
160 #if defined(OS_CHROMEOS) 143 #if defined(OS_CHROMEOS)
161 // On Chrome OS, VKEY_BROWSER_SEARCH is handled in Ash. 144 // On Chrome OS, VKEY_BROWSER_SEARCH is handled in Ash.
162 { ui::VKEY_BACK, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 145 { ui::VKEY_BACK, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
163 IDC_CLEAR_BROWSING_DATA }, 146 IDC_CLEAR_BROWSING_DATA },
164 { ui::VKEY_OEM_2, ui::EF_CONTROL_DOWN, IDC_HELP_PAGE_VIA_KEYBOARD }, 147 { ui::VKEY_OEM_2, ui::EF_CONTROL_DOWN, IDC_HELP_PAGE_VIA_KEYBOARD },
165 { ui::VKEY_OEM_2, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 148 { ui::VKEY_OEM_2, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
166 IDC_HELP_PAGE_VIA_KEYBOARD }, 149 IDC_HELP_PAGE_VIA_KEYBOARD },
167 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_MANAGER }, 150 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_MANAGER },
168 { ui::VKEY_BROWSER_STOP, ui::EF_NONE, IDC_STOP }, 151 { ui::VKEY_BROWSER_STOP, ui::EF_NONE, IDC_STOP },
169 { ui::VKEY_P, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN, 152 { ui::VKEY_P, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN,
170 IDC_TOUCH_HUD_PROJECTION_TOGGLE }, 153 IDC_TOUCH_HUD_PROJECTION_TOGGLE },
171 #else // OS_CHROMEOS 154 #else
tapted 2016/11/11 00:02:18 // !OS_CHROMEOS here?
themblsha 2016/11/11 12:20:32 Done.
172 { ui::VKEY_ESCAPE, ui::EF_SHIFT_DOWN, IDC_TASK_MANAGER }, 155 { ui::VKEY_ESCAPE, ui::EF_SHIFT_DOWN, IDC_TASK_MANAGER },
173 { ui::VKEY_DELETE, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
174 IDC_CLEAR_BROWSING_DATA },
175 { ui::VKEY_LMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 156 { ui::VKEY_LMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
176 { ui::VKEY_MENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 157 { ui::VKEY_MENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
177 { ui::VKEY_RMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 158 { ui::VKEY_RMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
178 // On Windows, all VKEY_BROWSER_* keys except VKEY_BROWSER_SEARCH are handled 159 // On Windows, all VKEY_BROWSER_* keys except VKEY_BROWSER_SEARCH are handled
179 // via WM_APPCOMMAND. 160 // via WM_APPCOMMAND.
180 { ui::VKEY_BROWSER_SEARCH, ui::EF_NONE, IDC_FOCUS_SEARCH }, 161 { ui::VKEY_BROWSER_SEARCH, ui::EF_NONE, IDC_FOCUS_SEARCH },
181 { ui::VKEY_M, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_SHOW_AVATAR_MENU}, 162 { ui::VKEY_M, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_SHOW_AVATAR_MENU },
163 // For each entry here add an entry into kChromeCmdId2AshActionId below
tapted 2016/11/11 00:02:19 It's unclear where this comment applies. Perhaps
themblsha 2016/11/11 12:20:32 Done.
164 // if Ash has a corresponding accelerator.
165 #if defined(GOOGLE_CHROME_BUILD) && !defined(OS_MACOSX)
166 { ui::VKEY_I, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FEEDBACK },
167 #endif // GOOGLE_CHROME_BUILD && !OS_MACOSX
168 #if !defined(OS_MACOSX)
169 { ui::VKEY_Q, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_EXIT },
170 #endif // !OS_MACOSX
171 { ui::VKEY_N, ui::EF_SHIFT_DOWN | kPlatformModifier,
172 IDC_NEW_INCOGNITO_WINDOW },
173 { ui::VKEY_T, kPlatformModifier, IDC_NEW_TAB },
174 { ui::VKEY_N, kPlatformModifier, IDC_NEW_WINDOW },
175 { ui::VKEY_T, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_RESTORE_TAB },
176 #endif // !OS_CHROMEOS
177
178 #if defined(OS_MACOSX)
179 // VKEY_OEM_4 is Left Brace '[{' key.
180 { ui::VKEY_OEM_4, ui::EF_COMMAND_DOWN, IDC_BACK },
181 { ui::VKEY_LEFT, ui::EF_COMMAND_DOWN, IDC_BACK },
182 #if defined(ENABLE_BASIC_PRINTING)
183 { ui::VKEY_P, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_BASIC_PRINT },
184 #endif // ENABLE_BASIC_PRINTING
185 { ui::VKEY_BACK, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
186 IDC_CLEAR_BROWSING_DATA },
187 { ui::VKEY_V, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
188 IDC_CONTENT_CONTEXT_PASTE_AND_MATCH_STYLE },
189 { ui::VKEY_Z, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
190 IDC_CONTENT_CONTEXT_REDO },
191 { ui::VKEY_A, ui::EF_COMMAND_DOWN, IDC_CONTENT_CONTEXT_SELECTALL },
192 { ui::VKEY_Z, ui::EF_COMMAND_DOWN, IDC_CONTENT_CONTEXT_UNDO },
193 { ui::VKEY_I, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_DEV_TOOLS },
194 { ui::VKEY_J, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_DEV_TOOLS_CONSOLE },
195 { ui::VKEY_C, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN, IDC_DEV_TOOLS_INSPECT},
196 { ui::VKEY_I, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
197 IDC_EMAIL_PAGE_LOCATION },
198 { ui::VKEY_Q, ui::EF_COMMAND_DOWN, IDC_EXIT },
199 { ui::VKEY_F, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_SEARCH },
200 // VKEY_OEM_6 is Right Brace ']}' key.
201 { ui::VKEY_OEM_6, ui::EF_COMMAND_DOWN, IDC_FORWARD },
202 { ui::VKEY_RIGHT, ui::EF_COMMAND_DOWN, IDC_FORWARD },
203 { ui::VKEY_F, ui::EF_COMMAND_DOWN | ui::EF_CONTROL_DOWN, IDC_FULLSCREEN },
204 // VKEY_OEM_2 is Slash '/?' key.
205 { ui::VKEY_OEM_2, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
206 IDC_HELP_PAGE_VIA_MENU },
207 { ui::VKEY_H, ui::EF_COMMAND_DOWN, IDC_HIDE_APP },
208 { ui::VKEY_H, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN, IDC_HOME },
209 { ui::VKEY_M, ui::EF_COMMAND_DOWN, IDC_MINIMIZE_WINDOW },
210 { ui::VKEY_RIGHT, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN,
211 IDC_SELECT_NEXT_TAB },
212 { ui::VKEY_LEFT, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN,
213 IDC_SELECT_PREVIOUS_TAB },
214 { ui::VKEY_B, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN,
215 IDC_SHOW_BOOKMARK_MANAGER },
216 { ui::VKEY_J, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN, IDC_SHOW_DOWNLOADS },
217 { ui::VKEY_L, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_SHOW_DOWNLOADS },
218 { ui::VKEY_Y, ui::EF_COMMAND_DOWN, IDC_SHOW_HISTORY },
219 { ui::VKEY_OEM_PERIOD, ui::EF_COMMAND_DOWN, IDC_STOP },
220 { ui::VKEY_U, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_VIEW_SOURCE },
221 #else
tapted 2016/11/11 00:02:18 // !OS_MACOSX
themblsha 2016/11/11 12:20:33 Done.
222 // Control modifier is rarely used on Mac, so we allow it only in several
tapted 2016/11/11 00:02:19 (move this - see previous comment)
themblsha 2016/11/11 12:20:32 Done.
223 // specific cases.
224 //
225 // Alt by itself (or with just shift) is never used on Mac since it's used
226 // to generate non-ASCII characters. Such commands are given Mac-specific
227 // bindings as well, so remove the mappings with Alt, but not those with
tapted 2016/11/11 00:02:18 -> "bindings as well. Mapping with just Alt appear
themblsha 2016/11/11 12:20:33 Yeah. Another option would be to parse this file w
228 // Command or Control.
229 { ui::VKEY_LEFT, ui::EF_ALT_DOWN, IDC_BACK },
230 #if defined(ENABLE_BASIC_PRINTING)
231 { ui::VKEY_P, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_BASIC_PRINT},
232 #endif // ENABLE_BASIC_PRINTING
233 #if !defined(OS_CHROMEOS)
234 { ui::VKEY_DELETE, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
235 IDC_CLEAR_BROWSING_DATA },
236 #endif // !OS_CHROMEOS
237 { ui::VKEY_I, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_DEV_TOOLS },
238 { ui::VKEY_J, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
239 IDC_DEV_TOOLS_CONSOLE },
240 { ui::VKEY_C, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
241 IDC_DEV_TOOLS_INSPECT },
242 { ui::VKEY_B, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_BOOKMARKS },
243 { ui::VKEY_A, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_INFOBARS },
244 { ui::VKEY_D, ui::EF_ALT_DOWN, IDC_FOCUS_LOCATION },
245 { ui::VKEY_E, ui::EF_CONTROL_DOWN, IDC_FOCUS_SEARCH },
246 { ui::VKEY_K, ui::EF_CONTROL_DOWN, IDC_FOCUS_SEARCH },
247 { ui::VKEY_T, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_TOOLBAR },
248 { ui::VKEY_RIGHT, ui::EF_ALT_DOWN, IDC_FORWARD },
249 { ui::VKEY_HOME, ui::EF_ALT_DOWN, IDC_HOME },
250 { ui::VKEY_E, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU},
251 { ui::VKEY_F, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU},
252 { ui::VKEY_O, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
253 IDC_SHOW_BOOKMARK_MANAGER },
254 { ui::VKEY_J, ui::EF_CONTROL_DOWN, IDC_SHOW_DOWNLOADS },
255 { ui::VKEY_H, ui::EF_CONTROL_DOWN, IDC_SHOW_HISTORY },
256 { ui::VKEY_U, ui::EF_CONTROL_DOWN, IDC_VIEW_SOURCE },
257 #if !defined(OS_CHROMEOS)
182 // On Chrome OS, these keys are assigned to change UI scale. 258 // On Chrome OS, these keys are assigned to change UI scale.
183 { ui::VKEY_OEM_PLUS, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_ZOOM_PLUS },
184 { ui::VKEY_OEM_MINUS, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 259 { ui::VKEY_OEM_MINUS, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
185 IDC_ZOOM_MINUS }, 260 IDC_ZOOM_MINUS },
186 // For each entry here add an entry into kChromeCmdId2AshActionId below 261 { ui::VKEY_OEM_PLUS, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
187 // if Ash has a corresponding accelerator. 262 IDC_ZOOM_PLUS },
188 #if defined(GOOGLE_CHROME_BUILD) 263 #endif // !OS_CHROMEOS
189 { ui::VKEY_I, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FEEDBACK }, 264 #endif // OS_MACOSX
190 #endif
191 { ui::VKEY_Q, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_EXIT },
192 { ui::VKEY_N, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
193 IDC_NEW_INCOGNITO_WINDOW },
194 { ui::VKEY_T, ui::EF_CONTROL_DOWN, IDC_NEW_TAB },
195 { ui::VKEY_N, ui::EF_CONTROL_DOWN, IDC_NEW_WINDOW },
196 { ui::VKEY_T, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_RESTORE_TAB },
197 #endif
198 }; 265 };
199 const size_t kAcceleratorMapLength = arraysize(kAcceleratorMap);
200 266
201 const int kRepeatableCommandIds[] = { 267 const int kRepeatableCommandIds[] = {
202 IDC_FIND_NEXT, 268 IDC_FIND_NEXT,
203 IDC_FIND_PREVIOUS, 269 IDC_FIND_PREVIOUS,
204 IDC_FOCUS_NEXT_PANE, 270 IDC_FOCUS_NEXT_PANE,
205 IDC_FOCUS_PREVIOUS_PANE, 271 IDC_FOCUS_PREVIOUS_PANE,
206 IDC_MOVE_TAB_NEXT, 272 IDC_MOVE_TAB_NEXT,
207 IDC_MOVE_TAB_PREVIOUS, 273 IDC_MOVE_TAB_PREVIOUS,
208 IDC_SELECT_NEXT_TAB, 274 IDC_SELECT_NEXT_TAB,
209 IDC_SELECT_PREVIOUS_TAB, 275 IDC_SELECT_PREVIOUS_TAB,
(...skipping 22 matching lines...) Expand all
232 { IDC_TOUCH_HUD_PROJECTION_TOGGLE, ash::TOUCH_HUD_PROJECTION_TOGGLE }, 298 { IDC_TOUCH_HUD_PROJECTION_TOGGLE, ash::TOUCH_HUD_PROJECTION_TOGGLE },
233 #endif 299 #endif
234 }; 300 };
235 const size_t kChromeCmdId2AshActionIdLength = 301 const size_t kChromeCmdId2AshActionIdLength =
236 arraysize(kChromeCmdId2AshActionId); 302 arraysize(kChromeCmdId2AshActionId);
237 #endif // defined(USE_ASH) 303 #endif // defined(USE_ASH)
238 304
239 } // namespace 305 } // namespace
240 306
241 std::vector<AcceleratorMapping> GetAcceleratorList() { 307 std::vector<AcceleratorMapping> GetAcceleratorList() {
242 return std::vector<AcceleratorMapping>( 308 CR_DEFINE_STATIC_LOCAL(
243 kAcceleratorMap, kAcceleratorMap + kAcceleratorMapLength); 309 std::vector<AcceleratorMapping>, accelerators,
310 (std::begin(kAcceleratorMap), std::end(kAcceleratorMap)));
311 return accelerators;
244 } 312 }
245 313
246 bool GetAshAcceleratorForCommandId(int command_id, 314 bool GetAshAcceleratorForCommandId(int command_id,
247 ui::Accelerator* accelerator) { 315 ui::Accelerator* accelerator) {
248 #if defined(USE_ASH) 316 #if defined(USE_ASH)
249 for (size_t i = 0; i < kChromeCmdId2AshActionIdLength; ++i) { 317 for (size_t i = 0; i < kChromeCmdId2AshActionIdLength; ++i) {
250 if (command_id == kChromeCmdId2AshActionId[i].chrome_cmd_id) { 318 if (command_id == kChromeCmdId2AshActionId[i].chrome_cmd_id) {
251 for (size_t j = 0; j < ash::kAcceleratorDataLength; ++j) { 319 for (size_t j = 0; j < ash::kAcceleratorDataLength; ++j) {
252 if (kChromeCmdId2AshActionId[i].ash_action_id == 320 if (kChromeCmdId2AshActionId[i].ash_action_id ==
253 ash::kAcceleratorData[j].action) { 321 ash::kAcceleratorData[j].action) {
254 *accelerator = ui::Accelerator(ash::kAcceleratorData[j].keycode, 322 *accelerator = ui::Accelerator(ash::kAcceleratorData[j].keycode,
255 ash::kAcceleratorData[j].modifiers); 323 ash::kAcceleratorData[j].modifiers);
256 return true; 324 return true;
257 } 325 }
258 } 326 }
259 } 327 }
260 } 328 }
261 #endif // defined(USE_ASH) 329 #endif // defined(USE_ASH)
262 return false; 330 return false;
263 } 331 }
264 332
265 bool GetStandardAcceleratorForCommandId(int command_id, 333 bool GetStandardAcceleratorForCommandId(int command_id,
266 ui::Accelerator* accelerator) { 334 ui::Accelerator* accelerator) {
267 // The standard Ctrl-X, Ctrl-V and Ctrl-C are not defined as accelerators 335 // The standard Ctrl-X, Ctrl-V and Ctrl-C are not defined as accelerators
268 // anywhere else. 336 // anywhere else.
269 switch (command_id) { 337 switch (command_id) {
270 case IDC_CUT: 338 case IDC_CUT:
271 *accelerator = ui::Accelerator(ui::VKEY_X, ui::EF_CONTROL_DOWN); 339 *accelerator = ui::Accelerator(ui::VKEY_X, kPlatformModifier);
272 return true; 340 return true;
273 case IDC_COPY: 341 case IDC_COPY:
274 *accelerator = ui::Accelerator(ui::VKEY_C, ui::EF_CONTROL_DOWN); 342 *accelerator = ui::Accelerator(ui::VKEY_C, kPlatformModifier);
275 return true; 343 return true;
276 case IDC_PASTE: 344 case IDC_PASTE:
277 *accelerator = ui::Accelerator(ui::VKEY_V, ui::EF_CONTROL_DOWN); 345 *accelerator = ui::Accelerator(ui::VKEY_V, kPlatformModifier);
278 return true; 346 return true;
279 } 347 }
280 return false; 348 return false;
281 } 349 }
282 350
283 bool IsCommandRepeatable(int command_id) { 351 bool IsCommandRepeatable(int command_id) {
284 for (size_t i = 0; i < kRepeatableCommandIdsLength; ++i) { 352 for (size_t i = 0; i < kRepeatableCommandIdsLength; ++i) {
285 if (kRepeatableCommandIds[i] == command_id) 353 if (kRepeatableCommandIds[i] == command_id)
286 return true; 354 return true;
287 } 355 }
288 return false; 356 return false;
289 } 357 }
290 358
291 } // namespace chrome 359 } // namespace chrome
OLDNEW
« no previous file with comments | « chrome/browser/global_keyboard_shortcuts_views_mac.mm ('k') | chrome/browser/ui/views/accelerator_table_unittest_mac.mm » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698