summaryrefslogtreecommitdiff
path: root/swaylock/password.c
diff options
context:
space:
mode:
authorDrew DeVault <[email protected]>2018-10-24 18:54:22 +0200
committerGitHub <[email protected]>2018-10-24 18:54:22 +0200
commit41f744c224eb07990c2b202fde14d93c2474f343 (patch)
treefde160e685990c6d749d1ad8fa0cdddb4ee287b2 /swaylock/password.c
parent9658d4bcc564dd7c5c82aa1b8795cccedfaabb70 (diff)
parent9afcda59dba5787817b50a74c254ccb790549e3c (diff)
Merge pull request #2925 from ianyfan/swaylock
swaylock: exit early if unable to get input inhibitor
Diffstat (limited to 'swaylock/password.c')
-rw-r--r--swaylock/password.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/swaylock/password.c b/swaylock/password.c
index fecaecbf..6138e1fe 100644
--- a/swaylock/password.c
+++ b/swaylock/password.c
@@ -1,5 +1,6 @@
#define _XOPEN_SOURCE 500
#include <assert.h>
+#include <errno.h>
#include <pwd.h>
#include <stdlib.h>
#include <string.h>
@@ -97,7 +98,10 @@ void swaylock_handle_key(struct swaylock_state *state,
state->eventloop, 50, handle_preverify_timeout, state);
while (state->run_display && state->verify_password_timer) {
- wl_display_flush(state->display);
+ errno = 0;
+ if (wl_display_flush(state->display) == -1 && errno != EAGAIN) {
+ break;
+ }
loop_poll(state->eventloop);
bool ok = 1;