1 /*
2  * Copyright (C) 2015 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #include "device.h"
18 
19 static const char* MENU_ITEMS[] = {
20     "Reboot system now",
21     "Reboot to bootloader",
22     "Apply update from ADB",
23     "Apply update from SD card",
24     "Wipe data/factory reset",
25     "Wipe cache partition",
26     "Mount /system",
27     "View recovery logs",
28     "Run graphics test",
29     "Power off",
30     NULL
31 };
32 
GetMenuItems()33 const char* const* Device::GetMenuItems() {
34   return MENU_ITEMS;
35 }
36 
InvokeMenuItem(int menu_position)37 Device::BuiltinAction Device::InvokeMenuItem(int menu_position) {
38   switch (menu_position) {
39     case 0: return REBOOT;
40     case 1: return REBOOT_BOOTLOADER;
41     case 2: return APPLY_ADB_SIDELOAD;
42     case 3: return APPLY_SDCARD;
43     case 4: return WIPE_DATA;
44     case 5: return WIPE_CACHE;
45     case 6: return MOUNT_SYSTEM;
46     case 7: return VIEW_RECOVERY_LOGS;
47     case 8: return RUN_GRAPHICS_TEST;
48     case 9: return SHUTDOWN;
49     default: return NO_ACTION;
50   }
51 }
52 
HandleMenuKey(int key,int visible)53 int Device::HandleMenuKey(int key, int visible) {
54   if (!visible) {
55     return kNoAction;
56   }
57 
58   switch (key) {
59     case KEY_DOWN:
60     case KEY_VOLUMEDOWN:
61       return kHighlightDown;
62 
63     case KEY_UP:
64     case KEY_VOLUMEUP:
65       return kHighlightUp;
66 
67     case KEY_ENTER:
68     case KEY_POWER:
69       return kInvokeItem;
70 
71     default:
72       // If you have all of the above buttons, any other buttons
73       // are ignored. Otherwise, any button cycles the highlight.
74       return ui_->HasThreeButtons() ? kNoAction : kHighlightDown;
75   }
76 }
77