aboutsummaryrefslogtreecommitdiff
path: root/sway/handlers.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2015-12-18 19:29:44 -0500
committerDrew DeVault <sir@cmpwn.com>2015-12-18 19:30:19 -0500
commit3282163f64291cfd63611110ab63e37051e80501 (patch)
tree7e89557c10e4bcc8415e482ad37106cc2e334236 /sway/handlers.c
parenteefc93db43ab6d5d308970afa43919a68bde2b79 (diff)
Implement compositor support for swaylock
This makes swaylock more or less work.
Diffstat (limited to 'sway/handlers.c')
-rw-r--r--sway/handlers.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/sway/handlers.c b/sway/handlers.c
index 136ef577..3161c677 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -331,6 +331,10 @@ static void handle_view_state_request(wlc_handle view, enum wlc_view_state_bit s
static bool handle_key(wlc_handle view, uint32_t time, const struct wlc_modifiers *modifiers,
uint32_t key, enum wlc_key_state state) {
+ if (desktop_shell.is_locked) {
+ return EVENT_PASSTHROUGH;
+ }
+
if (locked_view_focus && state == WLC_KEY_STATE_PRESSED) {
return EVENT_PASSTHROUGH;
}
@@ -383,6 +387,10 @@ static bool handle_key(wlc_handle view, uint32_t time, const struct wlc_modifier
}
static bool handle_pointer_motion(wlc_handle handle, uint32_t time, const struct wlc_point *origin) {
+ if (desktop_shell.is_locked) {
+ return EVENT_PASSTHROUGH;
+ }
+
struct wlc_point new_origin = *origin;
// Switch to adjacent output if touching output edge.
//