summaryrefslogtreecommitdiff
path: root/libs/input/InputVerifier.cpp
diff options
context:
space:
mode:
author Harry Cutts <hcutts@google.com> 2025-02-05 08:59:40 -0800
committer Android (Google) Code Review <android-gerrit@google.com> 2025-02-05 08:59:40 -0800
commit1a25e57a649f6198bdff99a590551f875baccf00 (patch)
treea9efadf6200be062a1855032b227c95a93535f53 /libs/input/InputVerifier.cpp
parentc95ea8177e9a6f1b8a768fe1adb66406c6ac5c3f (diff)
parent26640c99888043d5f41b5e209bb96efe76b7ef9e (diff)
Merge "InputVerifier: verify button events and states (attempt 2)" into main
Diffstat (limited to 'libs/input/InputVerifier.cpp')
-rw-r--r--libs/input/InputVerifier.cpp17
1 files changed, 13 insertions, 4 deletions
diff --git a/libs/input/InputVerifier.cpp b/libs/input/InputVerifier.cpp
index cec244539e..7811acefd0 100644
--- a/libs/input/InputVerifier.cpp
+++ b/libs/input/InputVerifier.cpp
@@ -17,6 +17,7 @@
#define LOG_TAG "InputVerifier"
#include <android-base/logging.h>
+#include <com_android_input_flags.h>
#include <input/InputVerifier.h>
#include "input_cxx_bridge.rs.h"
@@ -26,17 +27,23 @@ using android::input::RustPointerProperties;
using DeviceId = int32_t;
+namespace input_flags = com::android::input::flags;
+
namespace android {
// --- InputVerifier ---
InputVerifier::InputVerifier(const std::string& name)
- : mVerifier(android::input::verifier::create(rust::String::lossy(name))){};
+ : mVerifier(
+ android::input::verifier::create(rust::String::lossy(name),
+ input_flags::enable_button_state_verification())) {
+}
Result<void> InputVerifier::processMovement(DeviceId deviceId, int32_t source, int32_t action,
- uint32_t pointerCount,
+ int32_t actionButton, uint32_t pointerCount,
const PointerProperties* pointerProperties,
- const PointerCoords* pointerCoords, int32_t flags) {
+ const PointerCoords* pointerCoords, int32_t flags,
+ int32_t buttonState) {
std::vector<RustPointerProperties> rpp;
for (size_t i = 0; i < pointerCount; i++) {
rpp.emplace_back(RustPointerProperties{.id = pointerProperties[i].id});
@@ -44,7 +51,9 @@ Result<void> InputVerifier::processMovement(DeviceId deviceId, int32_t source, i
rust::Slice<const RustPointerProperties> properties{rpp.data(), rpp.size()};
rust::String errorMessage =
android::input::verifier::process_movement(*mVerifier, deviceId, source, action,
- properties, static_cast<uint32_t>(flags));
+ actionButton, properties,
+ static_cast<uint32_t>(flags),
+ static_cast<uint32_t>(buttonState));
if (errorMessage.empty()) {
return {};
} else {