aboutsummaryrefslogtreecommitdiff
path: root/swaylock
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 /swaylock
parenteefc93db43ab6d5d308970afa43919a68bde2b79 (diff)
downloadsway-3282163f64291cfd63611110ab63e37051e80501.tar.xz
Implement compositor support for swaylock
This makes swaylock more or less work.
Diffstat (limited to 'swaylock')
-rw-r--r--swaylock/main.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/swaylock/main.c b/swaylock/main.c
index 4073da99..82b88731 100644
--- a/swaylock/main.c
+++ b/swaylock/main.c
@@ -108,7 +108,6 @@ int main(int argc, char **argv) {
if (!window) {
sway_abort("Failed to create surfaces.");
}
- lock_set_lock_surface(registry->swaylock, output->output, window->surface);
list_add(surfaces, window);
}
@@ -217,7 +216,17 @@ int main(int argc, char **argv) {
cairo_surface_destroy(image);
- while (wl_display_dispatch(registry->display) != -1);
+ bool locked = false;
+ while (wl_display_dispatch(registry->display) != -1) {
+ if (!locked) {
+ for (i = 0; i < registry->outputs->length; ++i) {
+ struct output_state *output = registry->outputs->items[i];
+ struct window *window = surfaces->items[i];
+ lock_set_lock_surface(registry->swaylock, output->output, window->surface);
+ }
+ locked = true;
+ }
+ }
for (i = 0; i < surfaces->length; ++i) {
struct window *window = surfaces->items[i];