aboutsummaryrefslogtreecommitdiff
path: root/swaylock/password.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2018-04-24 16:30:54 +0200
committerGitHub <noreply@github.com>2018-04-24 16:30:54 +0200
commit5024f0888581cde0a9bc6b86222c14a97890b479 (patch)
tree35941cb448213c81a4956360af05c53537809ff5 /swaylock/password.c
parent38c44f2f27f218ed7e61c9910491eef78551d8ea (diff)
parent2d884d4e4f8b8e7cac87f8096c0cc31535bd0642 (diff)
Merge pull request #1848 from snaggen/improved_key_handling
Improved key handling in swaylock
Diffstat (limited to 'swaylock/password.c')
-rw-r--r--swaylock/password.c30
1 files changed, 29 insertions, 1 deletions
diff --git a/swaylock/password.c b/swaylock/password.c
index c8df3de8..1ad5cd81 100644
--- a/swaylock/password.c
+++ b/swaylock/password.c
@@ -105,11 +105,39 @@ void swaylock_handle_key(struct swaylock_state *state,
state->auth_state = AUTH_STATE_INVALID;
render_frames(state);
break;
+ case XKB_KEY_Delete:
case XKB_KEY_BackSpace:
if (backspace(&state->password)) {
state->auth_state = AUTH_STATE_BACKSPACE;
- render_frames(state);
+ } else {
+ state->auth_state = AUTH_STATE_CLEAR;
}
+ render_frames(state);
+ break;
+ case XKB_KEY_Escape:
+ clear_password_buffer(&state->password);
+ state->auth_state = AUTH_STATE_CLEAR;
+ render_frames(state);
+ break;
+ case XKB_KEY_Caps_Lock:
+ /* The state is getting active after this
+ * so we need to manually toggle it */
+ state->xkb.caps_lock = !state->xkb.caps_lock;
+ state->auth_state = AUTH_STATE_INPUT_NOP;
+ render_frames(state);
+ break;
+ case XKB_KEY_Shift_L:
+ case XKB_KEY_Shift_R:
+ case XKB_KEY_Control_L:
+ case XKB_KEY_Control_R:
+ case XKB_KEY_Meta_L:
+ case XKB_KEY_Meta_R:
+ case XKB_KEY_Alt_L:
+ case XKB_KEY_Alt_R:
+ case XKB_KEY_Super_L:
+ case XKB_KEY_Super_R:
+ state->auth_state = AUTH_STATE_INPUT_NOP;
+ render_frames(state);
break;
default:
if (codepoint) {