abouttreesummaryrefslogcommitdiff
path: root/srcs/juloo.keyboard2/Pointers.java
diff options
context:
space:
mode:
authorJules Aguillon2023-02-12 23:14:57 +0100
committerJules Aguillon2023-02-12 23:14:57 +0100
commitc46e3b6c619b6af5825161d4960ea4829a44d429 (patch)
tree26d5a0b58bc6a3f292ebe8dade450d097bd26c39 /srcs/juloo.keyboard2/Pointers.java
parent5fac3459aaa0e10152668ba104a1a031b3adc50b (diff)
downloadunexpected-keyboard-c46e3b6c619b6af5825161d4960ea4829a44d429.tar.gz
unexpected-keyboard-c46e3b6c619b6af5825161d4960ea4829a44d429.zip
Modify keys after a long press
Diffstat (limited to 'srcs/juloo.keyboard2/Pointers.java')
-rw-r--r--srcs/juloo.keyboard2/Pointers.java17
1 files changed, 14 insertions, 3 deletions
diff --git a/srcs/juloo.keyboard2/Pointers.java b/srcs/juloo.keyboard2/Pointers.java
index ebb6221..acad456 100644
--- a/srcs/juloo.keyboard2/Pointers.java
+++ b/srcs/juloo.keyboard2/Pointers.java
@@ -369,10 +369,21 @@ public final class Pointers implements Handler.Callback
lockPointer(ptr, true);
return false;
}
- // Stop repeating: Latched key, special keys
- if (ptr.pointerId == -1 || (ptr.flags & KeyValue.FLAG_SPECIAL) != 0)
+ // Stop repeating: Latched key, no key
+ if (ptr.pointerId == -1 || ptr.value == null)
return false;
- _handler.onPointerHold(ptr.value, ptr.modifiers);
+ KeyValue kv = KeyModifier.modify_long_press(ptr.value);
+ if (!kv.equals(ptr.value))
+ {
+ ptr.value = kv;
+ ptr.flags = kv.getFlags();
+ _handler.onPointerDown(true);
+ return true;
+ }
+ // Stop repeating: Special keys
+ if (kv.hasFlags(KeyValue.FLAG_SPECIAL))
+ return false;
+ _handler.onPointerHold(kv, ptr.modifiers);
return true;
}