| OLD | NEW |
| 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_controller.h" | 5 #include "ash/accelerators/accelerator_controller.h" |
| 6 | 6 |
| 7 #include "ash/accelerators/accelerator_table.h" | 7 #include "ash/accelerators/accelerator_table.h" |
| 8 #include "ash/ash_switches.h" | 8 #include "ash/ash_switches.h" |
| 9 #include "ash/aura/wm_window_aura.h" | 9 #include "ash/aura/wm_window_aura.h" |
| 10 #include "ash/common/accessibility_delegate.h" | 10 #include "ash/common/accessibility_delegate.h" |
| (...skipping 1017 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1028 ui::EF_NONE))); | 1028 ui::EF_NONE))); |
| 1029 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility()); | 1029 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility()); |
| 1030 EXPECT_FALSE(ProcessInController(ReleaseAccelerator(ui::VKEY_BROWSER_SEARCH, | 1030 EXPECT_FALSE(ProcessInController(ReleaseAccelerator(ui::VKEY_BROWSER_SEARCH, |
| 1031 ui::EF_NONE))); | 1031 ui::EF_NONE))); |
| 1032 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility()); | 1032 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility()); |
| 1033 #endif | 1033 #endif |
| 1034 } | 1034 } |
| 1035 | 1035 |
| 1036 TEST_F(AcceleratorControllerTest, ImeGlobalAccelerators) { | 1036 TEST_F(AcceleratorControllerTest, ImeGlobalAccelerators) { |
| 1037 // Test IME shortcuts. | 1037 // Test IME shortcuts. |
| 1038 { | 1038 ui::Accelerator control_space_down(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN); |
| 1039 ui::Accelerator control_space_down(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN); | 1039 control_space_down.set_type(ui::ET_KEY_PRESSED); |
| 1040 control_space_down.set_type(ui::ET_KEY_PRESSED); | 1040 ui::Accelerator control_space_up(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN); |
| 1041 ui::Accelerator control_space_up(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN); | 1041 control_space_up.set_type(ui::ET_KEY_RELEASED); |
| 1042 control_space_up.set_type(ui::ET_KEY_RELEASED); | 1042 const ui::Accelerator convert(ui::VKEY_CONVERT, ui::EF_NONE); |
| 1043 const ui::Accelerator convert(ui::VKEY_CONVERT, ui::EF_NONE); | 1043 const ui::Accelerator non_convert(ui::VKEY_NONCONVERT, ui::EF_NONE); |
| 1044 const ui::Accelerator non_convert(ui::VKEY_NONCONVERT, ui::EF_NONE); | 1044 const ui::Accelerator wide_half_1(ui::VKEY_DBE_SBCSCHAR, ui::EF_NONE); |
| 1045 const ui::Accelerator wide_half_1(ui::VKEY_DBE_SBCSCHAR, ui::EF_NONE); | 1045 const ui::Accelerator wide_half_2(ui::VKEY_DBE_DBCSCHAR, ui::EF_NONE); |
| 1046 const ui::Accelerator wide_half_2(ui::VKEY_DBE_DBCSCHAR, ui::EF_NONE); | 1046 const ui::Accelerator hangul(ui::VKEY_HANGUL, ui::EF_NONE); |
| 1047 const ui::Accelerator hangul(ui::VKEY_HANGUL, ui::EF_NONE); | 1047 EXPECT_FALSE(ProcessInController(control_space_down)); |
| 1048 EXPECT_FALSE(ProcessInController(control_space_down)); | 1048 EXPECT_FALSE(ProcessInController(control_space_up)); |
| 1049 EXPECT_FALSE(ProcessInController(control_space_up)); | 1049 EXPECT_FALSE(ProcessInController(convert)); |
| 1050 EXPECT_FALSE(ProcessInController(convert)); | 1050 EXPECT_FALSE(ProcessInController(non_convert)); |
| 1051 EXPECT_FALSE(ProcessInController(non_convert)); | 1051 EXPECT_FALSE(ProcessInController(wide_half_1)); |
| 1052 EXPECT_FALSE(ProcessInController(wide_half_1)); | 1052 EXPECT_FALSE(ProcessInController(wide_half_2)); |
| 1053 EXPECT_FALSE(ProcessInController(wide_half_2)); | 1053 EXPECT_FALSE(ProcessInController(hangul)); |
| 1054 EXPECT_FALSE(ProcessInController(hangul)); | 1054 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; |
| 1055 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; | 1055 GetController()->SetImeControlDelegate( |
| 1056 GetController()->SetImeControlDelegate( | 1056 std::unique_ptr<ImeControlDelegate>(delegate)); |
| 1057 std::unique_ptr<ImeControlDelegate>(delegate)); | 1057 EXPECT_EQ(0, delegate->handle_previous_ime_count()); |
| 1058 EXPECT_EQ(0, delegate->handle_previous_ime_count()); | 1058 EXPECT_TRUE(ProcessInController(control_space_down)); |
| 1059 EXPECT_TRUE(ProcessInController(control_space_down)); | 1059 EXPECT_EQ(1, delegate->handle_previous_ime_count()); |
| 1060 EXPECT_EQ(1, delegate->handle_previous_ime_count()); | 1060 EXPECT_TRUE(ProcessInController(control_space_up)); |
| 1061 EXPECT_TRUE(ProcessInController(control_space_up)); | 1061 EXPECT_EQ(1, delegate->handle_previous_ime_count()); |
| 1062 EXPECT_EQ(1, delegate->handle_previous_ime_count()); | 1062 EXPECT_EQ(0, delegate->handle_switch_ime_count()); |
| 1063 EXPECT_EQ(0, delegate->handle_switch_ime_count()); | 1063 EXPECT_TRUE(ProcessInController(convert)); |
| 1064 EXPECT_TRUE(ProcessInController(convert)); | 1064 EXPECT_EQ(1, delegate->handle_switch_ime_count()); |
| 1065 EXPECT_EQ(1, delegate->handle_switch_ime_count()); | 1065 EXPECT_TRUE(ProcessInController(non_convert)); |
| 1066 EXPECT_TRUE(ProcessInController(non_convert)); | 1066 EXPECT_EQ(2, delegate->handle_switch_ime_count()); |
| 1067 EXPECT_EQ(2, delegate->handle_switch_ime_count()); | 1067 EXPECT_TRUE(ProcessInController(wide_half_1)); |
| 1068 EXPECT_TRUE(ProcessInController(wide_half_1)); | 1068 EXPECT_EQ(3, delegate->handle_switch_ime_count()); |
| 1069 EXPECT_EQ(3, delegate->handle_switch_ime_count()); | 1069 EXPECT_TRUE(ProcessInController(wide_half_2)); |
| 1070 EXPECT_TRUE(ProcessInController(wide_half_2)); | 1070 EXPECT_EQ(4, delegate->handle_switch_ime_count()); |
| 1071 EXPECT_EQ(4, delegate->handle_switch_ime_count()); | 1071 EXPECT_TRUE(ProcessInController(hangul)); |
| 1072 EXPECT_TRUE(ProcessInController(hangul)); | 1072 EXPECT_EQ(5, delegate->handle_switch_ime_count()); |
| 1073 EXPECT_EQ(5, delegate->handle_switch_ime_count()); | |
| 1074 } | |
| 1075 | |
| 1076 // Test IME shortcuts that are triggered on key release. | |
| 1077 { | |
| 1078 const ui::Accelerator shift_alt_press(ui::VKEY_MENU, | |
| 1079 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1080 const ReleaseAccelerator shift_alt(ui::VKEY_MENU, ui::EF_SHIFT_DOWN); | |
| 1081 const ui::Accelerator alt_shift_press(ui::VKEY_SHIFT, | |
| 1082 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1083 const ReleaseAccelerator alt_shift(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); | |
| 1084 | |
| 1085 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; | |
| 1086 GetController()->SetImeControlDelegate( | |
| 1087 std::unique_ptr<ImeControlDelegate>(delegate)); | |
| 1088 EXPECT_EQ(0, delegate->handle_next_ime_count()); | |
| 1089 EXPECT_FALSE(ProcessInController(shift_alt_press)); | |
| 1090 EXPECT_TRUE(ProcessInController(shift_alt)); | |
| 1091 EXPECT_EQ(1, delegate->handle_next_ime_count()); | |
| 1092 EXPECT_FALSE(ProcessInController(alt_shift_press)); | |
| 1093 EXPECT_TRUE(ProcessInController(alt_shift)); | |
| 1094 EXPECT_EQ(2, delegate->handle_next_ime_count()); | |
| 1095 | |
| 1096 // We should NOT switch IME when e.g. Shift+Alt+X is pressed and X is | |
| 1097 // released. | |
| 1098 const ui::Accelerator shift_alt_x_press( | |
| 1099 ui::VKEY_X, | |
| 1100 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1101 const ReleaseAccelerator shift_alt_x(ui::VKEY_X, | |
| 1102 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1103 | |
| 1104 EXPECT_FALSE(ProcessInController(shift_alt_press)); | |
| 1105 EXPECT_FALSE(ProcessInController(shift_alt_x_press)); | |
| 1106 EXPECT_FALSE(ProcessInController(shift_alt_x)); | |
| 1107 EXPECT_TRUE(ProcessInController(shift_alt)); | |
| 1108 EXPECT_EQ(3, delegate->handle_next_ime_count()); | |
| 1109 | |
| 1110 // But we _should_ if X is either VKEY_RETURN or VKEY_SPACE. | |
| 1111 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way. | |
| 1112 const ui::Accelerator shift_alt_return_press( | |
| 1113 ui::VKEY_RETURN, | |
| 1114 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1115 const ReleaseAccelerator shift_alt_return( | |
| 1116 ui::VKEY_RETURN, | |
| 1117 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1118 | |
| 1119 EXPECT_FALSE(ProcessInController(shift_alt_press)); | |
| 1120 EXPECT_FALSE(ProcessInController(shift_alt_return_press)); | |
| 1121 EXPECT_FALSE(ProcessInController(shift_alt_return)); | |
| 1122 EXPECT_TRUE(ProcessInController(shift_alt)); | |
| 1123 EXPECT_EQ(4, delegate->handle_next_ime_count()); | |
| 1124 | |
| 1125 const ui::Accelerator shift_alt_space_press( | |
| 1126 ui::VKEY_SPACE, | |
| 1127 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1128 const ReleaseAccelerator shift_alt_space( | |
| 1129 ui::VKEY_SPACE, | |
| 1130 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1131 | |
| 1132 EXPECT_FALSE(ProcessInController(shift_alt_press)); | |
| 1133 EXPECT_FALSE(ProcessInController(shift_alt_space_press)); | |
| 1134 EXPECT_FALSE(ProcessInController(shift_alt_space)); | |
| 1135 EXPECT_TRUE(ProcessInController(shift_alt)); | |
| 1136 EXPECT_EQ(5, delegate->handle_next_ime_count()); | |
| 1137 } | |
| 1138 | |
| 1139 #if defined(OS_CHROMEOS) | |
| 1140 // Test IME shortcuts again with unnormalized accelerators (Chrome OS only). | |
| 1141 { | |
| 1142 const ui::Accelerator shift_alt_press(ui::VKEY_MENU, ui::EF_SHIFT_DOWN); | |
| 1143 const ReleaseAccelerator shift_alt(ui::VKEY_MENU, ui::EF_SHIFT_DOWN); | |
| 1144 const ui::Accelerator alt_shift_press(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); | |
| 1145 const ReleaseAccelerator alt_shift(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); | |
| 1146 | |
| 1147 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; | |
| 1148 GetController()->SetImeControlDelegate( | |
| 1149 std::unique_ptr<ImeControlDelegate>(delegate)); | |
| 1150 EXPECT_EQ(0, delegate->handle_next_ime_count()); | |
| 1151 EXPECT_FALSE(ProcessInController(shift_alt_press)); | |
| 1152 EXPECT_TRUE(ProcessInController(shift_alt)); | |
| 1153 EXPECT_EQ(1, delegate->handle_next_ime_count()); | |
| 1154 EXPECT_FALSE(ProcessInController(alt_shift_press)); | |
| 1155 EXPECT_TRUE(ProcessInController(alt_shift)); | |
| 1156 EXPECT_EQ(2, delegate->handle_next_ime_count()); | |
| 1157 | |
| 1158 // We should NOT switch IME when e.g. Shift+Alt+X is pressed and X is | |
| 1159 // released. | |
| 1160 const ui::Accelerator shift_alt_x_press( | |
| 1161 ui::VKEY_X, | |
| 1162 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1163 const ReleaseAccelerator shift_alt_x(ui::VKEY_X, | |
| 1164 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1165 | |
| 1166 EXPECT_FALSE(ProcessInController(shift_alt_press)); | |
| 1167 EXPECT_FALSE(ProcessInController(shift_alt_x_press)); | |
| 1168 EXPECT_FALSE(ProcessInController(shift_alt_x)); | |
| 1169 EXPECT_TRUE(ProcessInController(shift_alt)); | |
| 1170 EXPECT_EQ(3, delegate->handle_next_ime_count()); | |
| 1171 } | |
| 1172 #endif | |
| 1173 } | 1073 } |
| 1174 | 1074 |
| 1175 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way. | 1075 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way. |
| 1176 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsWorkaround139556) { | 1076 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsWorkaround139556) { |
| 1177 // The workaround for crbug.com/139556 depends on the fact that we don't | 1077 // The workaround for crbug.com/139556 depends on the fact that we don't |
| 1178 // use Shift+Alt+Enter/Space with ET_KEY_PRESSED as an accelerator. Test it. | 1078 // use Shift+Alt+Enter/Space with ET_KEY_PRESSED as an accelerator. Test it. |
| 1179 const ui::Accelerator shift_alt_return_press( | 1079 const ui::Accelerator shift_alt_return_press( |
| 1180 ui::VKEY_RETURN, | 1080 ui::VKEY_RETURN, |
| 1181 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | 1081 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); |
| 1182 EXPECT_FALSE(ProcessInController(shift_alt_return_press)); | 1082 EXPECT_FALSE(ProcessInController(shift_alt_return_press)); |
| 1183 const ui::Accelerator shift_alt_space_press( | 1083 const ui::Accelerator shift_alt_space_press( |
| 1184 ui::VKEY_SPACE, | 1084 ui::VKEY_SPACE, |
| 1185 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | 1085 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); |
| 1186 EXPECT_FALSE(ProcessInController(shift_alt_space_press)); | 1086 EXPECT_FALSE(ProcessInController(shift_alt_space_press)); |
| 1187 } | 1087 } |
| 1188 | 1088 |
| 1189 // Makes sure that the next IME accelerators doesn't conflict with other | |
| 1190 // accelerators that contain Alt+Shift when the wrong sequence is pressed. | |
| 1191 // crbug.com/527154. | |
| 1192 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsNoConflict) { | |
| 1193 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; | |
| 1194 GetController()->SetImeControlDelegate( | |
| 1195 std::unique_ptr<ImeControlDelegate>(delegate)); | |
| 1196 ui::test::EventGenerator& generator = GetEventGenerator(); | |
| 1197 | |
| 1198 // Correct sequence of a conflicting accelerator must not trigger next IME. | |
| 1199 // Alt (press) + Shift (press) + S (press) + S (release) + Shift (release) + | |
| 1200 // Alt (release). | |
| 1201 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN); | |
| 1202 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1203 generator.PressKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1204 generator.ReleaseKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1205 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); | |
| 1206 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE); | |
| 1207 EXPECT_EQ(0, delegate->handle_next_ime_count()); | |
| 1208 | |
| 1209 // Neither wrong sequences. | |
| 1210 // Wrong sequence 1: | |
| 1211 // Alt (press) + Shift (press) + S (press) + Shift (release) + S (release) + | |
| 1212 // Alt (release). | |
| 1213 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN); | |
| 1214 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1215 generator.PressKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1216 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); | |
| 1217 generator.ReleaseKey(ui::VKEY_S, ui::EF_ALT_DOWN); | |
| 1218 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE); | |
| 1219 EXPECT_EQ(0, delegate->handle_next_ime_count()); | |
| 1220 | |
| 1221 // Wrong sequence 2: | |
| 1222 // Alt (press) + Shift (press) + S (press) + Alt (release) + S (release) + | |
| 1223 // Shift (release). | |
| 1224 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN); | |
| 1225 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1226 generator.PressKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1227 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN); | |
| 1228 generator.ReleaseKey(ui::VKEY_S, ui::EF_SHIFT_DOWN); | |
| 1229 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_NONE); | |
| 1230 EXPECT_EQ(0, delegate->handle_next_ime_count()); | |
| 1231 | |
| 1232 // The two possible sequences of Alt+Shift both work for triggering the next | |
| 1233 // IME. | |
| 1234 // 1- Alt (press) + Shift (press) + Shift (release) + Alt (release). | |
| 1235 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN); | |
| 1236 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1237 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN); | |
| 1238 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_NONE); | |
| 1239 EXPECT_EQ(1, delegate->handle_next_ime_count()); | |
| 1240 | |
| 1241 // 2- Shift (press) + Alt (press) + Alt (release) + Shift (release). | |
| 1242 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN); | |
| 1243 generator.PressKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); | |
| 1244 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); | |
| 1245 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE); | |
| 1246 EXPECT_EQ(2, delegate->handle_next_ime_count()); | |
| 1247 } | |
| 1248 | |
| 1249 TEST_F(AcceleratorControllerTest, PreferredReservedAccelerators) { | 1089 TEST_F(AcceleratorControllerTest, PreferredReservedAccelerators) { |
| 1250 #if defined(OS_CHROMEOS) | 1090 #if defined(OS_CHROMEOS) |
| 1251 // Power key is reserved on chromeos. | 1091 // Power key is reserved on chromeos. |
| 1252 EXPECT_TRUE(GetController()->IsReserved( | 1092 EXPECT_TRUE(GetController()->IsReserved( |
| 1253 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); | 1093 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); |
| 1254 EXPECT_FALSE(GetController()->IsPreferred( | 1094 EXPECT_FALSE(GetController()->IsPreferred( |
| 1255 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); | 1095 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); |
| 1256 #endif | 1096 #endif |
| 1257 // ALT+Tab are not reserved but preferred. | 1097 // ALT+Tab are not reserved but preferred. |
| 1258 EXPECT_FALSE(GetController()->IsReserved( | 1098 EXPECT_FALSE(GetController()->IsReserved( |
| (...skipping 320 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1579 EXPECT_TRUE(IsMessageCenterEmpty()); | 1419 EXPECT_TRUE(IsMessageCenterEmpty()); |
| 1580 | 1420 |
| 1581 // If the action is LOCK_SCREEN, we must reset the state by unlocking the | 1421 // If the action is LOCK_SCREEN, we must reset the state by unlocking the |
| 1582 // screen before we proceed testing the rest of accelerators. | 1422 // screen before we proceed testing the rest of accelerators. |
| 1583 ResetStateIfNeeded(); | 1423 ResetStateIfNeeded(); |
| 1584 } | 1424 } |
| 1585 } | 1425 } |
| 1586 #endif // defined(OS_CHROMEOS) | 1426 #endif // defined(OS_CHROMEOS) |
| 1587 | 1427 |
| 1588 } // namespace ash | 1428 } // namespace ash |
| OLD | NEW |