diff options
author | Elliott Hughes <enh@google.com> | 2015-04-10 00:59:07 +0200 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2015-04-10 00:59:07 +0200 |
commit | 7b66aaebefb64e75597b33dbfac90072a8e32e9b (patch) | |
tree | d3dd7ef908ce61cf4ef495b28122c745dbb24f03 /default_device.cpp | |
parent | am 06522ef5: Merge "Remove some commented-out code." (diff) | |
parent | Merge "Move default implementations into Device." (diff) | |
download | android_bootable_recovery-7b66aaebefb64e75597b33dbfac90072a8e32e9b.tar android_bootable_recovery-7b66aaebefb64e75597b33dbfac90072a8e32e9b.tar.gz android_bootable_recovery-7b66aaebefb64e75597b33dbfac90072a8e32e9b.tar.bz2 android_bootable_recovery-7b66aaebefb64e75597b33dbfac90072a8e32e9b.tar.lz android_bootable_recovery-7b66aaebefb64e75597b33dbfac90072a8e32e9b.tar.xz android_bootable_recovery-7b66aaebefb64e75597b33dbfac90072a8e32e9b.tar.zst android_bootable_recovery-7b66aaebefb64e75597b33dbfac90072a8e32e9b.zip |
Diffstat (limited to 'default_device.cpp')
-rw-r--r-- | default_device.cpp | 90 |
1 files changed, 23 insertions, 67 deletions
diff --git a/default_device.cpp b/default_device.cpp index ed601f6c6..d7dd45283 100644 --- a/default_device.cpp +++ b/default_device.cpp @@ -14,80 +14,36 @@ * limitations under the License. */ -#include <linux/input.h> - -#include "common.h" #include "device.h" #include "screen_ui.h" -static const char* HEADERS[] = { - "Volume up/down to move highlight.", - "Power button to select.", - "", - NULL -}; - -static const char* ITEMS[] = { - "Reboot system now", - "Reboot to bootloader", - "Apply update from ADB", - "Apply update from SD card", - "Wipe data/factory reset", - "Wipe cache partition", - "View recovery logs", - "Power off", - NULL -}; - class DefaultDevice : public Device { - public: - DefaultDevice() : - ui(new ScreenRecoveryUI) { - } - - RecoveryUI* GetUI() { return ui; } - - int HandleMenuKey(int key, int visible) { - if (visible) { - 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; - } - } - - return kNoAction; + public: + DefaultDevice() : Device(new ScreenRecoveryUI) { + } + + // TODO: make this handle more cases, and move the default implementation into Device too. + int HandleMenuKey(int key, int visible) { + if (visible) { + 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; + } } - BuiltinAction 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_EXT; - case 4: return WIPE_DATA; - case 5: return WIPE_CACHE; - case 6: return READ_RECOVERY_LASTLOG; - case 7: return SHUTDOWN; - default: return NO_ACTION; - } - } - - const char* const* GetMenuHeaders() { return HEADERS; } - const char* const* GetMenuItems() { return ITEMS; } - - private: - RecoveryUI* ui; + return kNoAction; + } }; Device* make_device() { - return new DefaultDevice(); + return new DefaultDevice; } |