| /* |
| * Copyright (C) 2015 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #include "device.h" |
| |
| static const char* REGULAR_HEADERS[] = { |
| "Volume up/down move highlight.", |
| "Power button activates.", |
| "", |
| NULL |
| }; |
| |
| static const char* LONG_PRESS_HEADERS[] = { |
| "Any button cycles highlight.", |
| "Long-press activates.", |
| "", |
| NULL |
| }; |
| |
| static const char* MENU_ITEMS[] = { |
| "Reboot system now", |
| "Reboot to bootloader", |
| "Apply update from ADB", |
| "Apply update from SD card", |
| "Wipe data/factory reset", |
| "Wipe cache partition", |
| "Mount /system", |
| "View recovery logs", |
| "Power off", |
| NULL |
| }; |
| |
| const char* const* Device::GetMenuHeaders() { |
| return ui_->HasThreeButtons() ? REGULAR_HEADERS : LONG_PRESS_HEADERS; |
| } |
| |
| const char* const* Device::GetMenuItems() { |
| return MENU_ITEMS; |
| } |
| |
| Device::BuiltinAction Device::InvokeMenuItem(int menu_position) { |
| switch (menu_position) { |
| case 0: return REBOOT; |
| case 1: return REBOOT_BOOTLOADER; |
| case 2: return APPLY_ADB_SIDELOAD; |
| case 3: return APPLY_SDCARD; |
| case 4: return WIPE_DATA; |
| case 5: return WIPE_CACHE; |
| case 6: return MOUNT_SYSTEM; |
| case 7: return VIEW_RECOVERY_LOGS; |
| case 8: return SHUTDOWN; |
| default: return NO_ACTION; |
| } |
| } |
| |
| int Device::HandleMenuKey(int key, int visible) { |
| if (!visible) { |
| return kNoAction; |
| } |
| |
| switch (key) { |
| case KEY_DOWN: |
| case KEY_VOLUMEDOWN: |
| return kHighlightDown; |
| |
| case KEY_UP: |
| case KEY_VOLUMEUP: |
| return kHighlightUp; |
| |
| case KEY_ENTER: |
| case KEY_POWER: |
| return kInvokeItem; |
| |
| default: |
| // If you have all of the above buttons, any other buttons |
| // are ignored. Otherwise, any button cycles the highlight. |
| return ui_->HasThreeButtons() ? kNoAction : kHighlightDown; |
| } |
| } |