summaryrefslogtreecommitdiffstats
path: root/ui.h
diff options
context:
space:
mode:
authorTao Bao <tbao@google.com>2018-05-29 23:25:33 +0200
committerandroid-build-merger <android-build-merger@google.com>2018-05-29 23:25:33 +0200
commitf31290439c7048efb1ff473d799aff383d21462b (patch)
tree9e1cd4e38380de9d4def93bea3a35e8b6301d6d6 /ui.h
parentMerge "updater: Add Commmand class to manage BBOTA commands." am: a488bd992f am: 89d65805c6 (diff)
parentMerge "ui: Use std::thread to create input/progress threads." am: b8634ca793 (diff)
downloadandroid_bootable_recovery-f31290439c7048efb1ff473d799aff383d21462b.tar
android_bootable_recovery-f31290439c7048efb1ff473d799aff383d21462b.tar.gz
android_bootable_recovery-f31290439c7048efb1ff473d799aff383d21462b.tar.bz2
android_bootable_recovery-f31290439c7048efb1ff473d799aff383d21462b.tar.lz
android_bootable_recovery-f31290439c7048efb1ff473d799aff383d21462b.tar.xz
android_bootable_recovery-f31290439c7048efb1ff473d799aff383d21462b.tar.zst
android_bootable_recovery-f31290439c7048efb1ff473d799aff383d21462b.zip
Diffstat (limited to 'ui.h')
-rw-r--r--ui.h20
1 files changed, 7 insertions, 13 deletions
diff --git a/ui.h b/ui.h
index a74b14f85..75390d83c 100644
--- a/ui.h
+++ b/ui.h
@@ -17,12 +17,13 @@
#ifndef RECOVERY_UI_H
#define RECOVERY_UI_H
-#include <linux/input.h>
+#include <linux/input.h> // KEY_MAX
#include <pthread.h>
-#include <time.h>
+#include <atomic>
#include <functional>
#include <string>
+#include <thread>
#include <vector>
// Abstract class for controlling the user interface during recovery.
@@ -51,7 +52,7 @@ class RecoveryUI {
RecoveryUI();
- virtual ~RecoveryUI() {}
+ virtual ~RecoveryUI();
// Initializes the object; called before anything else. UI texts will be initialized according to
// the given locale. Returns true on success.
@@ -172,12 +173,6 @@ class RecoveryUI {
OFF
};
- struct key_timer_t {
- RecoveryUI* ui;
- int key_code;
- int count;
- };
-
// The sensitivity when detecting a swipe.
const int kTouchLowThreshold;
const int kTouchHighThreshold;
@@ -186,12 +181,10 @@ class RecoveryUI {
void OnTouchDetected(int dx, int dy);
int OnInputEvent(int fd, uint32_t epevents);
void ProcessKey(int key_code, int updown);
+ void TimeKey(int key_code, int count);
bool IsUsbConnected();
- static void* time_key_helper(void* cookie);
- void time_key(int key_code, int count);
-
bool InitScreensaver();
// Key event input queue
@@ -223,7 +216,8 @@ class RecoveryUI {
bool touch_swiping_;
bool is_bootreason_recovery_ui_;
- pthread_t input_thread_;
+ std::thread input_thread_;
+ std::atomic<bool> input_thread_stopped_{ false };
ScreensaverState screensaver_state_;