From cab5e6b1dee0cc2ea7021e688fd58513a5a38973 Mon Sep 17 00:00:00 2001 From: Michael Stapelberg Date: Thu, 5 Jan 2012 01:07:29 +0000 Subject: [PATCH] Change the unlock indicator properly after pressing the 'escape' key --- i3lock.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/i3lock.c b/i3lock.c index d265009..4c9a807 100644 --- a/i3lock.c +++ b/i3lock.c @@ -253,6 +253,13 @@ static void handle_key_press(xcb_key_press_event_t *event) { input_position = 0; clear_password_memory(); password[input_position] = '\0'; + + /* Hide the unlock indicator after a bit if the password buffer is + * empty. */ + start_clear_indicator_timeout(); + unlock_state = STATE_BACKSPACE_ACTIVE; + redraw_screen(); + unlock_state = STATE_KEY_PRESSED; return; case XK_BackSpace: @@ -263,13 +270,12 @@ static void handle_key_press(xcb_key_press_event_t *event) { u8_dec(password, &input_position); password[input_position] = '\0'; - /* Clear this state after 2 seconds (unless the user enters another - * password during that time). */ + /* Hide the unlock indicator after a bit if the password buffer is + * empty. */ start_clear_indicator_timeout(); unlock_state = STATE_BACKSPACE_ACTIVE; redraw_screen(); unlock_state = STATE_KEY_PRESSED; - //printf("new input position = %d, new password = %s\n", input_position, password); return; }