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

Side by Side Diff: ash/accelerators/accelerator_table.cc

Issue 1177773002: Deprecating high-conflict accelerators (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Added deprecation for the Shift+Esc Created 5 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
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 "ash/accelerators/accelerator_table.h" 5 #include "ash/accelerators/accelerator_table.h"
6 6
7 #include "base/basictypes.h" 7 #include "base/basictypes.h"
8 #include "chrome/grit/generated_resources.h"
8 9
9 namespace ash { 10 namespace ash {
10 11
11 const AcceleratorData kAcceleratorData[] = { 12 const AcceleratorData kAcceleratorData[] = {
12 // We have to define 3 entries for Shift+Alt. VKEY_[LR]MENU might be sent to 13 // We have to define 3 entries for Shift+Alt. VKEY_[LR]MENU might be sent to
13 // the accelerator controller when RenderWidgetHostViewAura is focused, and 14 // the accelerator controller when RenderWidgetHostViewAura is focused, and
14 // VKEY_MENU might be when it's not (e.g. when NativeWidgetAura is focused). 15 // VKEY_MENU might be when it's not (e.g. when NativeWidgetAura is focused).
15 { false, ui::VKEY_LMENU, ui::EF_SHIFT_DOWN, NEXT_IME }, 16 { false, ui::VKEY_LMENU, ui::EF_SHIFT_DOWN, NEXT_IME },
16 { false, ui::VKEY_MENU, ui::EF_SHIFT_DOWN, NEXT_IME }, 17 { false, ui::VKEY_MENU, ui::EF_SHIFT_DOWN, NEXT_IME },
17 { false, ui::VKEY_RMENU, ui::EF_SHIFT_DOWN, NEXT_IME }, 18 { false, ui::VKEY_RMENU, ui::EF_SHIFT_DOWN, NEXT_IME },
(...skipping 28 matching lines...) Expand all
46 { true, ui::VKEY_MEDIA_LAUNCH_APP1, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, 47 { true, ui::VKEY_MEDIA_LAUNCH_APP1, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
47 TAKE_PARTIAL_SCREENSHOT }, 48 TAKE_PARTIAL_SCREENSHOT },
48 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_NONE, BRIGHTNESS_DOWN }, 49 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_NONE, BRIGHTNESS_DOWN },
49 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_ALT_DOWN, KEYBOARD_BRIGHTNESS_DOWN }, 50 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_ALT_DOWN, KEYBOARD_BRIGHTNESS_DOWN },
50 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_NONE, BRIGHTNESS_UP }, 51 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_NONE, BRIGHTNESS_UP },
51 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_ALT_DOWN, KEYBOARD_BRIGHTNESS_UP }, 52 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_ALT_DOWN, KEYBOARD_BRIGHTNESS_UP },
52 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN, 53 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN,
53 MAGNIFY_SCREEN_ZOOM_OUT}, 54 MAGNIFY_SCREEN_ZOOM_OUT},
54 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN, 55 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN,
55 MAGNIFY_SCREEN_ZOOM_IN}, 56 MAGNIFY_SCREEN_ZOOM_IN},
56 { true, ui::VKEY_L, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, LOCK_SCREEN },
57 // The lock key on Chrome OS keyboards produces F13 scancodes. 57 // The lock key on Chrome OS keyboards produces F13 scancodes.
58 { true, ui::VKEY_F13, ui::EF_NONE, LOCK_PRESSED }, 58 { true, ui::VKEY_F13, ui::EF_NONE, LOCK_PRESSED },
59 { false, ui::VKEY_F13, ui::EF_NONE, LOCK_RELEASED }, 59 { false, ui::VKEY_F13, ui::EF_NONE, LOCK_RELEASED },
60 // Generic keyboards can use VKEY_SLEEP to mimic ChromeOS keyboard's lock key. 60 // Generic keyboards can use VKEY_SLEEP to mimic ChromeOS keyboard's lock key.
61 { true, ui::VKEY_SLEEP, ui::EF_NONE, LOCK_PRESSED }, 61 { true, ui::VKEY_SLEEP, ui::EF_NONE, LOCK_PRESSED },
62 { false, ui::VKEY_SLEEP, ui::EF_NONE, LOCK_RELEASED }, 62 { false, ui::VKEY_SLEEP, ui::EF_NONE, LOCK_RELEASED },
63 { true, ui::VKEY_POWER, ui::EF_NONE, POWER_PRESSED }, 63 { true, ui::VKEY_POWER, ui::EF_NONE, POWER_PRESSED },
64 { false, ui::VKEY_POWER, ui::EF_NONE, POWER_RELEASED }, 64 { false, ui::VKEY_POWER, ui::EF_NONE, POWER_RELEASED },
65 { true, ui::VKEY_M, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, 65 { true, ui::VKEY_M, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN,
66 OPEN_FILE_MANAGER }, 66 OPEN_FILE_MANAGER },
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after
133 { true, ui::VKEY_OEM_2, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN, 133 { true, ui::VKEY_OEM_2, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN,
134 SHOW_KEYBOARD_OVERLAY }, 134 SHOW_KEYBOARD_OVERLAY },
135 { true, ui::VKEY_OEM_2, 135 { true, ui::VKEY_OEM_2,
136 ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN, 136 ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN,
137 SHOW_KEYBOARD_OVERLAY }, 137 SHOW_KEYBOARD_OVERLAY },
138 { true, ui::VKEY_F14, ui::EF_NONE, SHOW_KEYBOARD_OVERLAY }, 138 { true, ui::VKEY_F14, ui::EF_NONE, SHOW_KEYBOARD_OVERLAY },
139 { true, ui::VKEY_N, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, 139 { true, ui::VKEY_N, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN,
140 SHOW_MESSAGE_CENTER_BUBBLE }, 140 SHOW_MESSAGE_CENTER_BUBBLE },
141 { true, ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN, 141 { true, ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN,
142 SHOW_SYSTEM_TRAY_BUBBLE }, 142 SHOW_SYSTEM_TRAY_BUBBLE },
143 { true, ui::VKEY_ESCAPE, ui::EF_SHIFT_DOWN, SHOW_TASK_MANAGER },
144 { true, ui::VKEY_1, ui::EF_ALT_DOWN, LAUNCH_APP_0 }, 143 { true, ui::VKEY_1, ui::EF_ALT_DOWN, LAUNCH_APP_0 },
145 { true, ui::VKEY_2, ui::EF_ALT_DOWN, LAUNCH_APP_1 }, 144 { true, ui::VKEY_2, ui::EF_ALT_DOWN, LAUNCH_APP_1 },
146 { true, ui::VKEY_3, ui::EF_ALT_DOWN, LAUNCH_APP_2 }, 145 { true, ui::VKEY_3, ui::EF_ALT_DOWN, LAUNCH_APP_2 },
147 { true, ui::VKEY_4, ui::EF_ALT_DOWN, LAUNCH_APP_3 }, 146 { true, ui::VKEY_4, ui::EF_ALT_DOWN, LAUNCH_APP_3 },
148 { true, ui::VKEY_5, ui::EF_ALT_DOWN, LAUNCH_APP_4 }, 147 { true, ui::VKEY_5, ui::EF_ALT_DOWN, LAUNCH_APP_4 },
149 { true, ui::VKEY_6, ui::EF_ALT_DOWN, LAUNCH_APP_5 }, 148 { true, ui::VKEY_6, ui::EF_ALT_DOWN, LAUNCH_APP_5 },
150 { true, ui::VKEY_7, ui::EF_ALT_DOWN, LAUNCH_APP_6 }, 149 { true, ui::VKEY_7, ui::EF_ALT_DOWN, LAUNCH_APP_6 },
151 { true, ui::VKEY_8, ui::EF_ALT_DOWN, LAUNCH_APP_7 }, 150 { true, ui::VKEY_8, ui::EF_ALT_DOWN, LAUNCH_APP_7 },
152 { true, ui::VKEY_9, ui::EF_ALT_DOWN, LAUNCH_LAST_APP }, 151 { true, ui::VKEY_9, ui::EF_ALT_DOWN, LAUNCH_LAST_APP },
153 152
(...skipping 21 matching lines...) Expand all
175 { false, ui::VKEY_PRIOR, ui::EF_SHIFT_DOWN, ACCESSIBLE_FOCUS_PREVIOUS}, 174 { false, ui::VKEY_PRIOR, ui::EF_SHIFT_DOWN, ACCESSIBLE_FOCUS_PREVIOUS},
176 { false, ui::VKEY_END, ui::EF_SHIFT_DOWN, ACCESSIBLE_FOCUS_NEXT}, 175 { false, ui::VKEY_END, ui::EF_SHIFT_DOWN, ACCESSIBLE_FOCUS_NEXT},
177 { false, ui::VKEY_NEXT, ui::EF_SHIFT_DOWN, ACCESSIBLE_FOCUS_NEXT}, 176 { false, ui::VKEY_NEXT, ui::EF_SHIFT_DOWN, ACCESSIBLE_FOCUS_NEXT},
178 177
179 // TODO(yusukes): Handle VKEY_MEDIA_STOP, and 178 // TODO(yusukes): Handle VKEY_MEDIA_STOP, and
180 // VKEY_MEDIA_LAUNCH_MAIL. 179 // VKEY_MEDIA_LAUNCH_MAIL.
181 }; 180 };
182 181
183 const size_t kAcceleratorDataLength = arraysize(kAcceleratorData); 182 const size_t kAcceleratorDataLength = arraysize(kAcceleratorData);
184 183
184 // Instructions for how to deprecate and replace an Accelerator:
185 //
186 // 1- Remove the old deprecated accelerator from the above list.
187 // 2- Add an entry for it in the following |kDeprecatedAccelerators| list.
188 // 3- That entry should contain the following:
189 // - The deprecated accelerator data you removed from above.
190 // - The new accelerator that should replace it.
191 // - Both the new and old accelerators MUST map to the same
192 // |AcceleratorAction|.
193 // - Define a histogram for this action in |histograms.xml| in the form
194 // "Ash.Accelerators.{ActionName}" and include the name of this histogram
195 // in this entry.
196 // - The ID of the localized notification message to give the users telling
197 // them about the deprecation (Add one in |generated_resources.grd|.
198 // Search for the comment <!-- Deprecated Accelerators Messages -->).
199 // - {true or false} whether the notification should be displayed every time
200 // the user uses the deprecated accelerator.
201 // - {true or false} whether the deprecated accelerator is still enabled (we
202 // don't disable a deprecated accelerator abruptly).
203
204 const DeprecatedAcceleratorData kDeprecatedAccelerators[] = {
205 {{true, ui::VKEY_ESCAPE, ui::EF_SHIFT_DOWN, SHOW_TASK_MANAGER},
206 {true, ui::VKEY_ESCAPE, ui::EF_COMMAND_DOWN, SHOW_TASK_MANAGER},
207 "Ash.Accelerators.ShowTaskManager",
208 IDS_DEPRECATED_SHOW_TASK_MANAGER_MSG,
209 true,
210 true},
211 #if defined(OS_CHROMEOS)
212 {{true, ui::VKEY_L, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN, LOCK_SCREEN},
213 {true, ui::VKEY_L, ui::EF_COMMAND_DOWN, LOCK_SCREEN},
214 "Ash.Accelerators.LockScreen",
215 IDS_DEPRECATED_LOCK_SCREEN_MSG,
216 true,
217 true},
218 #endif // defined(OS_CHROMEOS)
219 };
220
221 const size_t kDeprecatedAcceleratorsLength = arraysize(kDeprecatedAccelerators);
222
185 const AcceleratorData kDebugAcceleratorData[] = { 223 const AcceleratorData kDebugAcceleratorData[] = {
186 #if defined(OS_CHROMEOS) 224 #if defined(OS_CHROMEOS)
187 // Extra shortcut for debug build to control magnifier on linux desktop. 225 // Extra shortcut for debug build to control magnifier on linux desktop.
188 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_CONTROL_DOWN, 226 { true, ui::VKEY_BRIGHTNESS_DOWN, ui::EF_CONTROL_DOWN,
189 MAGNIFY_SCREEN_ZOOM_OUT}, 227 MAGNIFY_SCREEN_ZOOM_OUT},
190 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_CONTROL_DOWN, MAGNIFY_SCREEN_ZOOM_IN}, 228 { true, ui::VKEY_BRIGHTNESS_UP, ui::EF_CONTROL_DOWN, MAGNIFY_SCREEN_ZOOM_IN},
191 // Extra shortcuts to lock the screen on linux desktop. 229 // Extra shortcuts to lock the screen on linux desktop.
192 { true, ui::VKEY_L, ui::EF_ALT_DOWN, LOCK_SCREEN }, 230 { true, ui::VKEY_L, ui::EF_ALT_DOWN, LOCK_SCREEN },
193 { true, ui::VKEY_POWER, ui::EF_SHIFT_DOWN, LOCK_PRESSED }, 231 { true, ui::VKEY_POWER, ui::EF_SHIFT_DOWN, LOCK_PRESSED },
194 { false, ui::VKEY_POWER, ui::EF_SHIFT_DOWN, LOCK_RELEASED }, 232 { false, ui::VKEY_POWER, ui::EF_SHIFT_DOWN, LOCK_RELEASED },
(...skipping 223 matching lines...) Expand 10 before | Expand all | Expand 10 after
418 WINDOW_MINIMIZE, 456 WINDOW_MINIMIZE,
419 TOGGLE_FULLSCREEN, 457 TOGGLE_FULLSCREEN,
420 TOGGLE_MAXIMIZED, 458 TOGGLE_MAXIMIZED,
421 WINDOW_POSITION_CENTER, 459 WINDOW_POSITION_CENTER,
422 ROTATE_WINDOW, 460 ROTATE_WINDOW,
423 }; 461 };
424 462
425 const size_t kActionsNeedingWindowLength = arraysize(kActionsNeedingWindow); 463 const size_t kActionsNeedingWindowLength = arraysize(kActionsNeedingWindow);
426 464
427 } // namespace ash 465 } // namespace ash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698