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

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: Fix review issues. Created 4 years, 6 months 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 "base/macros.h" 9 #include "base/macros.h"
10 #include "build/build_config.h" 10 #include "build/build_config.h"
11 #include "chrome/app/chrome_command_ids.h" 11 #include "chrome/app/chrome_command_ids.h"
12 #include "ui/base/accelerators/accelerator.h" 12 #include "ui/base/accelerators/accelerator.h"
13 #include "ui/events/event_constants.h" 13 #include "ui/events/event_constants.h"
14 14
15 #if defined(USE_ASH) 15 #if defined(USE_ASH)
16 #include "ash/accelerators/accelerator_table.h" 16 #include "ash/accelerators/accelerator_table.h"
17 #endif 17 #endif
18 18
19 namespace chrome { 19 namespace chrome {
20 namespace { 20 namespace {
21 21
22 // For many commands, the Mac equivalent uses Cmd instead of Ctrl. We only need 22 // 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. 23 // 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. 24 // 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) 25 #if defined(OS_MACOSX)
27 const ui::EventFlags kPlatformModifier = ui::EF_COMMAND_DOWN; 26 const ui::EventFlags kPlatformModifier = ui::EF_COMMAND_DOWN;
28 #else 27 #else
29 const ui::EventFlags kPlatformModifier = ui::EF_CONTROL_DOWN; 28 const ui::EventFlags kPlatformModifier = ui::EF_CONTROL_DOWN;
30 #endif 29 #endif
31 30
32 // NOTE: Keep this list in the same (mostly-alphabetical) order as 31 // NOTE: Keep this list in the same (mostly-alphabetical) order as
33 // the Windows accelerators in ../../app/chrome_dll.rc. 32 // 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: 33 // 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 34 // http://blogs.msdn.com/b/oldnewthing/archive/2004/03/29/101121.aspx
36 const AcceleratorMapping kAcceleratorMap[] = { 35 const AcceleratorMapping kAcceleratorMap[] = {
37 { ui::VKEY_LEFT, ui::EF_ALT_DOWN, IDC_BACK }, 36 { ui::VKEY_LEFT, ui::EF_ALT_DOWN, IDC_BACK },
38 { ui::VKEY_BACK, ui::EF_NONE, IDC_BACKSPACE_BACK }, 37 { ui::VKEY_D, kPlatformModifier, IDC_BOOKMARK_PAGE },
tapted 2016/06/22 03:06:09 why this? It looks like you're removing backspace
themblsha 2016/06/24 18:22:15 No good reason, probably clumsiness on my part: th
39 { ui::VKEY_D, ui::EF_CONTROL_DOWN, IDC_BOOKMARK_PAGE }, 38 { ui::VKEY_D, ui::EF_SHIFT_DOWN | kPlatformModifier,
40 { ui::VKEY_D, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
41 IDC_BOOKMARK_ALL_TABS }, 39 IDC_BOOKMARK_ALL_TABS },
42 { ui::VKEY_W, ui::EF_CONTROL_DOWN, IDC_CLOSE_TAB }, 40 { ui::VKEY_W, kPlatformModifier, IDC_CLOSE_TAB },
43 { ui::VKEY_W, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_CLOSE_WINDOW }, 41 { ui::VKEY_W, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_CLOSE_WINDOW },
44 { ui::VKEY_F, ui::EF_CONTROL_DOWN, IDC_FIND }, 42 { ui::VKEY_F, kPlatformModifier, IDC_FIND },
45 { ui::VKEY_G, ui::EF_CONTROL_DOWN, IDC_FIND_NEXT }, 43 { ui::VKEY_G, kPlatformModifier, IDC_FIND_NEXT },
46 { ui::VKEY_G, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_FIND_PREVIOUS }, 44 { ui::VKEY_G, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_FIND_PREVIOUS },
47 { ui::VKEY_D, ui::EF_ALT_DOWN, IDC_FOCUS_LOCATION }, 45 { ui::VKEY_D, ui::EF_ALT_DOWN, IDC_FOCUS_LOCATION },
48 { ui::VKEY_L, ui::EF_CONTROL_DOWN, IDC_FOCUS_LOCATION }, 46 { ui::VKEY_L, kPlatformModifier, IDC_FOCUS_LOCATION },
49 { ui::VKEY_K, ui::EF_CONTROL_DOWN, IDC_FOCUS_SEARCH }, 47 { ui::VKEY_K, ui::EF_CONTROL_DOWN, IDC_FOCUS_SEARCH },
50 { ui::VKEY_E, ui::EF_CONTROL_DOWN, IDC_FOCUS_SEARCH }, 48 { 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 }, 49 { 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 }, 50 { 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 }, 51 { ui::VKEY_A, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_INFOBARS },
54 { ui::VKEY_RIGHT, ui::EF_ALT_DOWN, IDC_FORWARD }, 52 { ui::VKEY_RIGHT, ui::EF_ALT_DOWN, IDC_FORWARD },
55 { ui::VKEY_BACK, ui::EF_SHIFT_DOWN, IDC_BACKSPACE_FORWARD },
tapted 2016/06/22 03:06:09 this too - I don't think this should be removed
themblsha 2016/06/24 18:22:15 Thanks!
56 { ui::VKEY_I, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_DEV_TOOLS }, 53 { 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 }, 54 { ui::VKEY_F12, ui::EF_NONE, IDC_DEV_TOOLS_TOGGLE },
58 { ui::VKEY_J, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 55 { ui::VKEY_J, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
59 IDC_DEV_TOOLS_CONSOLE }, 56 IDC_DEV_TOOLS_CONSOLE },
60 { ui::VKEY_C, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 57 { ui::VKEY_C, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
61 IDC_DEV_TOOLS_INSPECT }, 58 IDC_DEV_TOOLS_INSPECT },
62 { ui::VKEY_O, ui::EF_CONTROL_DOWN, IDC_OPEN_FILE }, 59 { ui::VKEY_O, kPlatformModifier, IDC_OPEN_FILE },
63 { ui::VKEY_P, ui::EF_CONTROL_DOWN, IDC_PRINT}, 60 { ui::VKEY_P, kPlatformModifier, IDC_PRINT },
64 #if defined(ENABLE_BASIC_PRINTING) 61 #if defined(ENABLE_BASIC_PRINTING)
65 { ui::VKEY_P, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_BASIC_PRINT}, 62 { ui::VKEY_P, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_BASIC_PRINT},
66 #endif // ENABLE_BASIC_PRINTING 63 #endif // ENABLE_BASIC_PRINTING
67 { ui::VKEY_R, ui::EF_CONTROL_DOWN, IDC_RELOAD }, 64 { ui::VKEY_R, kPlatformModifier, IDC_RELOAD },
68 { ui::VKEY_R, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 65 { ui::VKEY_R, ui::EF_SHIFT_DOWN | kPlatformModifier,
69 IDC_RELOAD_BYPASSING_CACHE }, 66 IDC_RELOAD_BYPASSING_CACHE },
70 { ui::VKEY_HOME, ui::EF_ALT_DOWN, IDC_HOME }, 67 { ui::VKEY_HOME, ui::EF_ALT_DOWN, IDC_HOME },
71 { ui::VKEY_S, ui::EF_CONTROL_DOWN, IDC_SAVE_PAGE }, 68 { ui::VKEY_S, kPlatformModifier, IDC_SAVE_PAGE },
72 { ui::VKEY_9, kPlatformModifier, IDC_SELECT_LAST_TAB }, 69 { ui::VKEY_9, ui::EF_CONTROL_DOWN, IDC_SELECT_LAST_TAB },
tapted 2016/06/22 03:06:10 why this change? Cmd+9 to select the last tab work
themblsha 2016/06/24 18:22:15 Because it isn't present in the accelerators_cocoa
tapted 2016/06/28 05:19:54 This isn't a good rationale. How does Cmd+9 work o
73 { ui::VKEY_NUMPAD9, kPlatformModifier, IDC_SELECT_LAST_TAB }, 70 { ui::VKEY_NUMPAD9, ui::EF_CONTROL_DOWN, IDC_SELECT_LAST_TAB },
74 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) 71 #if defined(OS_LINUX) && !defined(OS_CHROMEOS)
75 { ui::VKEY_9, ui::EF_ALT_DOWN, IDC_SELECT_LAST_TAB }, 72 { ui::VKEY_9, ui::EF_ALT_DOWN, IDC_SELECT_LAST_TAB },
76 { ui::VKEY_NUMPAD9, ui::EF_ALT_DOWN, IDC_SELECT_LAST_TAB }, 73 { 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 }, 74 { 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, 75 { ui::VKEY_PRIOR, ui::EF_CONTROL_DOWN | ui::EF_SHIFT_DOWN,
79 IDC_MOVE_TAB_PREVIOUS }, 76 IDC_MOVE_TAB_PREVIOUS },
80 #endif 77 #endif
81 { ui::VKEY_TAB, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB }, 78 { ui::VKEY_TAB, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB },
82 { ui::VKEY_NEXT, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB }, 79 { ui::VKEY_NEXT, ui::EF_CONTROL_DOWN, IDC_SELECT_NEXT_TAB },
83 { ui::VKEY_TAB, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 80 { ui::VKEY_TAB, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
(...skipping 27 matching lines...) Expand all
111 { ui::VKEY_5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 }, 108 { ui::VKEY_5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 },
112 { ui::VKEY_NUMPAD5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 }, 109 { ui::VKEY_NUMPAD5, ui::EF_ALT_DOWN, IDC_SELECT_TAB_4 },
113 { ui::VKEY_6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 }, 110 { ui::VKEY_6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 },
114 { ui::VKEY_NUMPAD6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 }, 111 { ui::VKEY_NUMPAD6, ui::EF_ALT_DOWN, IDC_SELECT_TAB_5 },
115 { ui::VKEY_7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 }, 112 { ui::VKEY_7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 },
116 { ui::VKEY_NUMPAD7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 }, 113 { ui::VKEY_NUMPAD7, ui::EF_ALT_DOWN, IDC_SELECT_TAB_6 },
117 { ui::VKEY_8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 }, 114 { ui::VKEY_8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 },
118 { ui::VKEY_NUMPAD8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 }, 115 { ui::VKEY_NUMPAD8, ui::EF_ALT_DOWN, IDC_SELECT_TAB_7 },
119 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_BAR }, 116 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_BAR },
120 #endif 117 #endif
121 { ui::VKEY_B, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 118 { ui::VKEY_B, ui::EF_SHIFT_DOWN | kPlatformModifier,
122 IDC_SHOW_BOOKMARK_BAR }, 119 IDC_SHOW_BOOKMARK_BAR },
123 { ui::VKEY_O, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 120 { ui::VKEY_O, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
124 IDC_SHOW_BOOKMARK_MANAGER }, 121 IDC_SHOW_BOOKMARK_MANAGER },
125 { ui::VKEY_J, ui::EF_CONTROL_DOWN, IDC_SHOW_DOWNLOADS }, 122 { ui::VKEY_J, ui::EF_CONTROL_DOWN, IDC_SHOW_DOWNLOADS },
126 { ui::VKEY_H, ui::EF_CONTROL_DOWN, IDC_SHOW_HISTORY }, 123 { ui::VKEY_H, ui::EF_CONTROL_DOWN, IDC_SHOW_HISTORY },
127 { ui::VKEY_F, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU}, 124 { ui::VKEY_F, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU},
128 { ui::VKEY_E, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU}, 125 { ui::VKEY_E, ui::EF_ALT_DOWN, IDC_SHOW_APP_MENU},
129 { ui::VKEY_ESCAPE, ui::EF_NONE, IDC_STOP }, 126 { ui::VKEY_ESCAPE, ui::EF_NONE, IDC_STOP },
130 { ui::VKEY_U, ui::EF_CONTROL_DOWN, IDC_VIEW_SOURCE }, 127 { ui::VKEY_U, kPlatformModifier | ui::EF_ALT_DOWN, IDC_VIEW_SOURCE },
tapted 2016/06/22 03:06:09 you can't just add alt here - it will change other
themblsha 2016/06/24 18:22:15 It was that same original commit at fault again. S
131 { ui::VKEY_OEM_MINUS, ui::EF_CONTROL_DOWN, IDC_ZOOM_MINUS }, 128 { ui::VKEY_OEM_MINUS, kPlatformModifier, IDC_ZOOM_MINUS },
132 { ui::VKEY_SUBTRACT, ui::EF_CONTROL_DOWN, IDC_ZOOM_MINUS }, 129 { ui::VKEY_SUBTRACT, kPlatformModifier, IDC_ZOOM_MINUS },
133 { ui::VKEY_0, ui::EF_CONTROL_DOWN, IDC_ZOOM_NORMAL }, 130 { ui::VKEY_0, kPlatformModifier, IDC_ZOOM_NORMAL },
134 { ui::VKEY_NUMPAD0, ui::EF_CONTROL_DOWN, IDC_ZOOM_NORMAL }, 131 { ui::VKEY_NUMPAD0, kPlatformModifier, IDC_ZOOM_NORMAL },
135 { ui::VKEY_OEM_PLUS, ui::EF_CONTROL_DOWN, IDC_ZOOM_PLUS }, 132 { ui::VKEY_OEM_PLUS, kPlatformModifier, IDC_ZOOM_PLUS },
136 { ui::VKEY_ADD, ui::EF_CONTROL_DOWN, IDC_ZOOM_PLUS }, 133 { ui::VKEY_ADD, kPlatformModifier, IDC_ZOOM_PLUS },
134 #if !defined(OS_MACOSX)
tapted 2016/06/22 03:06:09 nit: blank line above
themblsha 2016/06/24 18:22:15 Done.
137 { ui::VKEY_F1, ui::EF_NONE, IDC_HELP_PAGE_VIA_KEYBOARD }, 135 { ui::VKEY_F1, ui::EF_NONE, IDC_HELP_PAGE_VIA_KEYBOARD },
tapted 2016/06/22 03:06:10 Comment here like // Function keys aren't mapped
themblsha 2016/06/24 18:22:15 Done.
138 { ui::VKEY_F3, ui::EF_NONE, IDC_FIND_NEXT }, 136 { ui::VKEY_F3, ui::EF_NONE, IDC_FIND_NEXT },
139 { ui::VKEY_F3, ui::EF_SHIFT_DOWN, IDC_FIND_PREVIOUS }, 137 { ui::VKEY_F3, ui::EF_SHIFT_DOWN, IDC_FIND_PREVIOUS },
140 { ui::VKEY_F4, ui::EF_CONTROL_DOWN, IDC_CLOSE_TAB }, 138 { ui::VKEY_F4, ui::EF_CONTROL_DOWN, IDC_CLOSE_TAB },
141 { ui::VKEY_F4, ui::EF_ALT_DOWN, IDC_CLOSE_WINDOW }, 139 { ui::VKEY_F4, ui::EF_ALT_DOWN, IDC_CLOSE_WINDOW },
142 { ui::VKEY_F5, ui::EF_NONE, IDC_RELOAD }, 140 { ui::VKEY_F5, ui::EF_NONE, IDC_RELOAD },
143 { ui::VKEY_F5, ui::EF_CONTROL_DOWN, IDC_RELOAD_BYPASSING_CACHE }, 141 { ui::VKEY_F5, ui::EF_CONTROL_DOWN, IDC_RELOAD_BYPASSING_CACHE },
144 { ui::VKEY_F5, ui::EF_SHIFT_DOWN, IDC_RELOAD_BYPASSING_CACHE }, 142 { ui::VKEY_F5, ui::EF_SHIFT_DOWN, IDC_RELOAD_BYPASSING_CACHE },
145 { ui::VKEY_F6, ui::EF_NONE, IDC_FOCUS_NEXT_PANE }, 143 { ui::VKEY_F6, ui::EF_NONE, IDC_FOCUS_NEXT_PANE },
146 { ui::VKEY_F6, ui::EF_SHIFT_DOWN, IDC_FOCUS_PREVIOUS_PANE }, 144 { ui::VKEY_F6, ui::EF_SHIFT_DOWN, IDC_FOCUS_PREVIOUS_PANE },
147 { ui::VKEY_F10, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 145 { ui::VKEY_F10, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
148 { ui::VKEY_F11, ui::EF_NONE, IDC_FULLSCREEN }, 146 { ui::VKEY_F11, ui::EF_NONE, IDC_FULLSCREEN },
147 #endif // !OS_MACOSX
149 148
150 // Platform-specific key maps. 149 // Platform-specific key maps.
151 #if defined(OS_LINUX) 150 #if defined(OS_LINUX)
152 { ui::VKEY_BROWSER_BACK, ui::EF_NONE, IDC_BACK }, 151 { ui::VKEY_BROWSER_BACK, ui::EF_NONE, IDC_BACK },
153 { ui::VKEY_BROWSER_FORWARD, ui::EF_NONE, IDC_FORWARD }, 152 { ui::VKEY_BROWSER_FORWARD, ui::EF_NONE, IDC_FORWARD },
154 { ui::VKEY_BROWSER_HOME, ui::EF_NONE, IDC_HOME }, 153 { ui::VKEY_BROWSER_HOME, ui::EF_NONE, IDC_HOME },
155 { ui::VKEY_BROWSER_REFRESH, ui::EF_NONE, IDC_RELOAD }, 154 { ui::VKEY_BROWSER_REFRESH, ui::EF_NONE, IDC_RELOAD },
156 { ui::VKEY_BROWSER_REFRESH, ui::EF_CONTROL_DOWN, IDC_RELOAD_BYPASSING_CACHE }, 155 { 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 }, 156 { ui::VKEY_BROWSER_REFRESH, ui::EF_SHIFT_DOWN, IDC_RELOAD_BYPASSING_CACHE },
158 #endif // defined(OS_LINUX) 157 #endif // defined(OS_LINUX)
159 158
160 #if defined(OS_CHROMEOS) 159 #if defined(OS_CHROMEOS)
161 // On Chrome OS, VKEY_BROWSER_SEARCH is handled in Ash. 160 // On Chrome OS, VKEY_BROWSER_SEARCH is handled in Ash.
162 { ui::VKEY_BACK, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 161 { ui::VKEY_BACK, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
163 IDC_CLEAR_BROWSING_DATA }, 162 IDC_CLEAR_BROWSING_DATA },
164 { ui::VKEY_OEM_2, ui::EF_CONTROL_DOWN, IDC_HELP_PAGE_VIA_KEYBOARD }, 163 { 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, 164 { ui::VKEY_OEM_2, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
166 IDC_HELP_PAGE_VIA_KEYBOARD }, 165 IDC_HELP_PAGE_VIA_KEYBOARD },
167 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_MANAGER }, 166 { ui::VKEY_BROWSER_FAVORITES, ui::EF_NONE, IDC_SHOW_BOOKMARK_MANAGER },
168 { ui::VKEY_BROWSER_STOP, ui::EF_NONE, IDC_STOP }, 167 { ui::VKEY_BROWSER_STOP, ui::EF_NONE, IDC_STOP },
169 { ui::VKEY_P, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN, 168 { ui::VKEY_P, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN,
170 IDC_TOUCH_HUD_PROJECTION_TOGGLE }, 169 IDC_TOUCH_HUD_PROJECTION_TOGGLE },
171 #else // OS_CHROMEOS 170 #elif defined(OS_MACOSX)
171 // Mac-specific shortcuts are defined in a Mac section below.
tapted 2016/06/22 03:06:09 I don't think this is right - we should keep the #
themblsha 2016/06/24 18:22:15 Ok, added a few more rules to the GetAcceleratorLi
172 #else // !OS_MACOSX
172 { ui::VKEY_ESCAPE, ui::EF_SHIFT_DOWN, IDC_TASK_MANAGER }, 173 { ui::VKEY_ESCAPE, ui::EF_SHIFT_DOWN, IDC_TASK_MANAGER },
173 { ui::VKEY_DELETE, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 174 { ui::VKEY_DELETE, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
174 IDC_CLEAR_BROWSING_DATA }, 175 IDC_CLEAR_BROWSING_DATA },
175 { ui::VKEY_LMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 176 { ui::VKEY_LMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
176 { ui::VKEY_MENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 177 { ui::VKEY_MENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
177 { ui::VKEY_RMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR }, 178 { ui::VKEY_RMENU, ui::EF_NONE, IDC_FOCUS_MENU_BAR },
178 // On Windows, all VKEY_BROWSER_* keys except VKEY_BROWSER_SEARCH are handled 179 // On Windows, all VKEY_BROWSER_* keys except VKEY_BROWSER_SEARCH are handled
179 // via WM_APPCOMMAND. 180 // via WM_APPCOMMAND.
180 { ui::VKEY_BROWSER_SEARCH, ui::EF_NONE, IDC_FOCUS_SEARCH }, 181 { ui::VKEY_BROWSER_SEARCH, ui::EF_NONE, IDC_FOCUS_SEARCH },
181 { ui::VKEY_M, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_SHOW_AVATAR_MENU}, 182 { ui::VKEY_M, ui::EF_SHIFT_DOWN | kPlatformModifier, IDC_SHOW_AVATAR_MENU },
182 // On ChromeOS, these keys are assigned to change UI scale. 183 // On ChromeOS, 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_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, 185 { ui::VKEY_OEM_MINUS, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
185 IDC_ZOOM_MINUS }, 186 IDC_ZOOM_MINUS },
186 // For each entry here add an entry into kChromeCmdId2AshActionId below 187 // For each entry here add an entry into kChromeCmdId2AshActionId below
187 // if Ash has a corresponding accelerator. 188 // if Ash has a corresponding accelerator.
188 #if defined(GOOGLE_CHROME_BUILD) 189 #if defined(GOOGLE_CHROME_BUILD)
189 { ui::VKEY_I, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FEEDBACK }, 190 { ui::VKEY_I, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, IDC_FEEDBACK },
190 #endif 191 #endif
191 { ui::VKEY_Q, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_EXIT }, 192 { 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 { ui::VKEY_N, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
193 IDC_NEW_INCOGNITO_WINDOW }, 194 IDC_NEW_INCOGNITO_WINDOW },
194 { ui::VKEY_T, ui::EF_CONTROL_DOWN, IDC_NEW_TAB }, 195 { ui::VKEY_T, ui::EF_CONTROL_DOWN, IDC_NEW_TAB },
tapted 2016/06/22 03:06:10 e.g. this should just be changed like ui::EF_CONTR
themblsha 2016/06/24 18:22:15 Good idea, squashed a couple more of duplicate ite
195 { ui::VKEY_N, ui::EF_CONTROL_DOWN, IDC_NEW_WINDOW }, 196 { 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 { ui::VKEY_T, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, IDC_RESTORE_TAB },
197 #endif 198 #endif // !OS_CHROMEOS && !OS_MACOSX
199
200 #if defined(OS_MACOSX)
201 // VKEY_OEM_4 is Left Brace '[{' key.
202 { ui::VKEY_OEM_4, ui::EF_COMMAND_DOWN, IDC_BACK },
203 #if defined(ENABLE_BASIC_PRINTING)
tapted 2016/06/22 03:06:09 this is always true on Mac, so we don't need to ch
themblsha 2016/06/24 18:22:15 Done.
204 { ui::VKEY_P, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_BASIC_PRINT },
205 #endif // ENABLE_BASIC_PRINTING
206 { ui::VKEY_BACK, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
207 IDC_CLEAR_BROWSING_DATA },
208 { ui::VKEY_C, ui::EF_COMMAND_DOWN, IDC_CONTENT_CONTEXT_COPY },
tapted 2016/06/22 03:06:09 this isn't mapped for other platforms - why does m
themblsha 2016/06/24 18:22:15 This was implemented in https://codereview.chromiu
209 { ui::VKEY_X, ui::EF_COMMAND_DOWN, IDC_CONTENT_CONTEXT_CUT },
210 { ui::VKEY_V, ui::EF_COMMAND_DOWN, IDC_CONTENT_CONTEXT_PASTE },
211 { ui::VKEY_V, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
212 IDC_CONTENT_CONTEXT_PASTE_AND_MATCH_STYLE },
213 { ui::VKEY_Z, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
214 IDC_CONTENT_CONTEXT_REDO },
215 { ui::VKEY_A, ui::EF_COMMAND_DOWN, IDC_CONTENT_CONTEXT_SELECTALL },
216 { ui::VKEY_Z, ui::EF_COMMAND_DOWN, IDC_CONTENT_CONTEXT_UNDO },
217 { ui::VKEY_I, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_DEV_TOOLS },
218 { ui::VKEY_J, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_DEV_TOOLS_CONSOLE },
219 { ui::VKEY_I, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
220 IDC_EMAIL_PAGE_LOCATION },
221 { ui::VKEY_Q, ui::EF_COMMAND_DOWN, IDC_EXIT },
222 { ui::VKEY_F, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN, IDC_FOCUS_SEARCH },
223 // VKEY_OEM_6 is Right Brace ']}' key.
224 { ui::VKEY_OEM_6, ui::EF_COMMAND_DOWN, IDC_FORWARD },
225 { ui::VKEY_F, ui::EF_COMMAND_DOWN | ui::EF_CONTROL_DOWN, IDC_FULLSCREEN },
226 // VKEY_OEM_2 is Slash '/?' key
227 { ui::VKEY_OEM_2, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
228 IDC_HELP_PAGE_VIA_MENU },
229 { ui::VKEY_H, ui::EF_COMMAND_DOWN, IDC_HIDE_APP },
230 { ui::VKEY_H, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN, IDC_HOME },
231 { ui::VKEY_M, ui::EF_COMMAND_DOWN, IDC_MINIMIZE_WINDOW },
232 { ui::VKEY_N, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN,
233 IDC_NEW_INCOGNITO_WINDOW },
234 { ui::VKEY_T, ui::EF_COMMAND_DOWN, IDC_NEW_TAB },
235 { ui::VKEY_N, ui::EF_COMMAND_DOWN, IDC_NEW_WINDOW },
236 { ui::VKEY_T, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN, IDC_RESTORE_TAB },
237 { ui::VKEY_RIGHT, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN,
238 IDC_SELECT_NEXT_TAB },
239 { ui::VKEY_LEFT, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN,
240 IDC_SELECT_PREVIOUS_TAB },
241 { ui::VKEY_B, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN,
242 IDC_SHOW_BOOKMARK_MANAGER },
243 { ui::VKEY_J, ui::EF_COMMAND_DOWN | ui::EF_SHIFT_DOWN, IDC_SHOW_DOWNLOADS },
244 { ui::VKEY_Y, ui::EF_COMMAND_DOWN, IDC_SHOW_HISTORY },
245 { ui::VKEY_OEM_PERIOD, ui::EF_COMMAND_DOWN, IDC_STOP },
246 #endif // OS_MACOSX
198 }; 247 };
199 const size_t kAcceleratorMapLength = arraysize(kAcceleratorMap); 248 const size_t kAcceleratorMapLength = arraysize(kAcceleratorMap);
200 249
201 #if defined(USE_ASH) 250 #if defined(USE_ASH)
202 // Below we map Chrome command ids to Ash action ids for commands that have 251 // Below we map Chrome command ids to Ash action ids for commands that have
203 // an shortcut that is handled by Ash (instead of Chrome). Adding entries 252 // an shortcut that is handled by Ash (instead of Chrome). Adding entries
204 // here will show shortcut text on menus. See comment above. 253 // here will show shortcut text on menus. See comment above.
205 struct ChromeCmdId2AshActionId { 254 struct ChromeCmdId2AshActionId {
206 const int chrome_cmd_id; 255 const int chrome_cmd_id;
207 const ash::AcceleratorAction ash_action_id; 256 const ash::AcceleratorAction ash_action_id;
(...skipping 12 matching lines...) Expand all
220 { IDC_TOUCH_HUD_PROJECTION_TOGGLE, ash::TOUCH_HUD_PROJECTION_TOGGLE }, 269 { IDC_TOUCH_HUD_PROJECTION_TOGGLE, ash::TOUCH_HUD_PROJECTION_TOGGLE },
221 #endif 270 #endif
222 }; 271 };
223 const size_t kChromeCmdId2AshActionIdLength = 272 const size_t kChromeCmdId2AshActionIdLength =
224 arraysize(kChromeCmdId2AshActionId); 273 arraysize(kChromeCmdId2AshActionId);
225 #endif // defined(USE_ASH) 274 #endif // defined(USE_ASH)
226 275
227 } // namespace 276 } // namespace
228 277
229 std::vector<AcceleratorMapping> GetAcceleratorList() { 278 std::vector<AcceleratorMapping> GetAcceleratorList() {
230 return std::vector<AcceleratorMapping>( 279 static std::vector<AcceleratorMapping> accelerators;
tapted 2016/06/22 03:06:09 Chome doesn't allow statics of non-primitive type
themblsha 2016/06/24 18:22:15 I thought there was a compile-time warning for thi
tapted 2016/06/28 05:19:54 There probably should be :). We detect static init
231 kAcceleratorMap, kAcceleratorMap + kAcceleratorMapLength); 280 if (accelerators.empty()) {
281 accelerators = std::vector<AcceleratorMapping>(
tapted 2016/06/22 03:06:09 The idiomatic way to do this is probably accelera
themblsha 2016/06/24 18:22:15 No real preference there, thanks for the suggestio
282 kAcceleratorMap, kAcceleratorMap + kAcceleratorMapLength);
283 #if defined(OS_MACOSX)
284 // Alt, Control and accelerators without modifiers are not very typical for
tapted 2016/06/22 03:06:09 I think we need a "harder" rule here for Mac -- we
285 // native Mac apps. Simplify the kAcceleratorMap table by filtering them
286 // out.
287 auto it = std::remove_if(accelerators.begin(), accelerators.end(),
288 [](const AcceleratorMapping& m) {
289 if (m.modifiers & ui::EF_COMMAND_DOWN) {
290 // Command is Mac-specific, so this accelerator should be enabled.
291 return false;
292 }
293 return m.modifiers == ui::EF_NONE ||
tapted 2016/06/22 03:06:09 why ui::EF_NONE ? Seems we might want those - most
themblsha 2016/06/24 18:22:15 Good ones seem to be: IDC_STOP 33006 modifiers:; k
294 m.modifiers & ui::EF_ALT_DOWN ||
295 m.modifiers & ui::EF_CONTROL_DOWN;
tapted 2016/06/22 03:06:10 Ctrl + PageUp switches tabs on Mac, so this doesn'
themblsha 2016/06/24 18:22:15 Good ones seem to be: IDC_SELECT_NEXT_TAB 34016 mo
296 });
297 accelerators.erase(it, accelerators.end());
298 #endif // OS_MACOSX
299 }
300 return accelerators;
232 } 301 }
233 302
234 bool GetAshAcceleratorForCommandId(int command_id, 303 bool GetAshAcceleratorForCommandId(int command_id,
235 ui::Accelerator* accelerator) { 304 ui::Accelerator* accelerator) {
236 #if defined(USE_ASH) 305 #if defined(USE_ASH)
237 for (size_t i = 0; i < kChromeCmdId2AshActionIdLength; ++i) { 306 for (size_t i = 0; i < kChromeCmdId2AshActionIdLength; ++i) {
238 if (command_id == kChromeCmdId2AshActionId[i].chrome_cmd_id) { 307 if (command_id == kChromeCmdId2AshActionId[i].chrome_cmd_id) {
239 for (size_t j = 0; j < ash::kAcceleratorDataLength; ++j) { 308 for (size_t j = 0; j < ash::kAcceleratorDataLength; ++j) {
240 if (kChromeCmdId2AshActionId[i].ash_action_id == 309 if (kChromeCmdId2AshActionId[i].ash_action_id ==
241 ash::kAcceleratorData[j].action) { 310 ash::kAcceleratorData[j].action) {
242 *accelerator = ui::Accelerator(ash::kAcceleratorData[j].keycode, 311 *accelerator = ui::Accelerator(ash::kAcceleratorData[j].keycode,
243 ash::kAcceleratorData[j].modifiers); 312 ash::kAcceleratorData[j].modifiers);
244 return true; 313 return true;
245 } 314 }
246 } 315 }
247 } 316 }
248 } 317 }
249 #endif // defined(USE_ASH) 318 #endif // defined(USE_ASH)
250 return false; 319 return false;
251 } 320 }
252 321
253 bool GetStandardAcceleratorForCommandId(int command_id, 322 bool GetStandardAcceleratorForCommandId(int command_id,
254 ui::Accelerator* accelerator) { 323 ui::Accelerator* accelerator) {
255 // The standard Ctrl-X, Ctrl-V and Ctrl-C are not defined as accelerators 324 // The standard Ctrl-X, Ctrl-V and Ctrl-C are not defined as accelerators
256 // anywhere else. 325 // anywhere else.
257 switch (command_id) { 326 switch (command_id) {
258 case IDC_CUT: 327 case IDC_CUT:
259 *accelerator = ui::Accelerator(ui::VKEY_X, ui::EF_CONTROL_DOWN); 328 *accelerator = ui::Accelerator(ui::VKEY_X, kPlatformModifier);
260 return true; 329 return true;
261 case IDC_COPY: 330 case IDC_COPY:
262 *accelerator = ui::Accelerator(ui::VKEY_C, ui::EF_CONTROL_DOWN); 331 *accelerator = ui::Accelerator(ui::VKEY_C, kPlatformModifier);
263 return true; 332 return true;
264 case IDC_PASTE: 333 case IDC_PASTE:
265 *accelerator = ui::Accelerator(ui::VKEY_V, ui::EF_CONTROL_DOWN); 334 *accelerator = ui::Accelerator(ui::VKEY_V, kPlatformModifier);
266 return true; 335 return true;
267 } 336 }
268 return false; 337 return false;
269 } 338 }
270 339
271 } // namespace chrome 340 } // namespace chrome
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698