aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/extensions.h9
-rw-r--r--sway/extensions.c51
-rw-r--r--sway/handlers.c34
-rw-r--r--sway/layout.c22
-rw-r--r--swaybar/main.c36
5 files changed, 130 insertions, 22 deletions
diff --git a/include/extensions.h b/include/extensions.h
index 2fca23c1..1ef7d920 100644
--- a/include/extensions.h
+++ b/include/extensions.h
@@ -1,6 +1,7 @@
#ifndef _SWAY_EXTENSIONS_H
#define _SWAY_EXTENSIONS_H
+#include "wayland-desktop-shell-server-protocol.h"
#include "list.h"
#include "wlc/wlc-wayland.h"
@@ -9,8 +10,16 @@ struct background_config {
wlc_resource surface;
};
+struct panel_config {
+ wlc_handle output;
+ wlc_resource surface;
+};
+
struct desktop_shell_state {
list_t *backgrounds;
+ list_t *panels;
+ enum desktop_shell_panel_position panel_position;
+ struct wlc_size panel_size;
};
extern struct desktop_shell_state desktop_shell;
diff --git a/sway/extensions.c b/sway/extensions.c
index aa51b474..1f8e9a7c 100644
--- a/sway/extensions.c
+++ b/sway/extensions.c
@@ -2,6 +2,7 @@
#include <wlc/wlc.h>
#include <wlc/wlc-wayland.h>
#include "wayland-desktop-shell-server-protocol.h"
+#include "layout.h"
#include "log.h"
#include "extensions.h"
@@ -20,13 +21,55 @@ static void set_background(struct wl_client *client, struct wl_resource *resourc
list_add(desktop_shell.backgrounds, config);
}
+static void set_panel(struct wl_client *client, struct wl_resource *resource,
+ struct wl_resource *_output, struct wl_resource *surface) {
+ wlc_handle output = wlc_handle_from_wl_output_resource(_output);
+ if (!output) {
+ return;
+ }
+ sway_log(L_DEBUG, "Setting surface %p as panel for output %d", surface, (int)output);
+ struct panel_config *config = malloc(sizeof(struct panel_config));
+ config->output = output;
+ config->surface = wlc_resource_from_wl_surface_resource(surface);
+ list_add(desktop_shell.panels, config);
+ desktop_shell.panel_size = *wlc_surface_get_size(config->surface);
+ arrange_windows(&root_container, -1, -1);
+}
+
+static void set_lock_surface(struct wl_client *client, struct wl_resource *resource, struct wl_resource *surface) {
+ sway_log(L_ERROR, "desktop_set_lock_surface is not currently supported");
+}
+
+static void unlock(struct wl_client *client, struct wl_resource *resource) {
+ sway_log(L_ERROR, "desktop_unlock is not currently supported");
+}
+
+static void set_grab_surface(struct wl_client *client, struct wl_resource *resource, struct wl_resource *surface) {
+ sway_log(L_ERROR, "desktop_set_grab_surface is not currently supported");
+}
+
+static void desktop_ready(struct wl_client *client, struct wl_resource *resource) {
+ // nop
+}
+
+static void set_panel_position(struct wl_client *client, struct wl_resource *resource, uint32_t position) {
+ desktop_shell.panel_position = position;
+ arrange_windows(&root_container, -1, -1);
+}
+
static struct desktop_shell_interface desktop_shell_implementation = {
- .set_background = set_background
+ .set_background = set_background,
+ .set_panel = set_panel,
+ .set_lock_surface = set_lock_surface,
+ .unlock = unlock,
+ .set_grab_surface = set_grab_surface,
+ .desktop_ready = desktop_ready,
+ .set_panel_position = set_panel_position
};
static void desktop_shell_bind(struct wl_client *client, void *data,
unsigned int version, unsigned int id) {
- if (version > 1) {
+ if (version > 3) {
// Unsupported version
return;
}
@@ -40,6 +83,8 @@ static void desktop_shell_bind(struct wl_client *client, void *data,
}
void register_extensions(void) {
- wl_global_create(wlc_get_wl_display(), &desktop_shell_interface, 1, NULL, desktop_shell_bind);
+ wl_global_create(wlc_get_wl_display(), &desktop_shell_interface, 3, NULL, desktop_shell_bind);
desktop_shell.backgrounds = create_list();
+ desktop_shell.panels = create_list();
+ desktop_shell.panel_position = DESKTOP_SHELL_PANEL_POSITION_BOTTOM;
}
diff --git a/sway/handlers.c b/sway/handlers.c
index 267a8f3a..2029ae84 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -72,11 +72,43 @@ static void handle_output_destroyed(wlc_handle output) {
}
static void handle_output_pre_render(wlc_handle output) {
+ struct wlc_size resolution = *wlc_output_get_resolution(output);
+
int i;
for (i = 0; i < desktop_shell.backgrounds->length; ++i) {
struct background_config *config = desktop_shell.backgrounds->items[i];
if (config->output == output) {
- wlc_surface_render(config->surface, &(struct wlc_geometry){ wlc_origin_zero, *wlc_output_get_resolution(output) });
+ wlc_surface_render(config->surface, &(struct wlc_geometry){ wlc_origin_zero, resolution });
+ break;
+ }
+ }
+
+ for (i = 0; i < desktop_shell.panels->length; ++i) {
+ struct panel_config *config = desktop_shell.panels->items[i];
+ if (config->output == output) {
+ struct wlc_size size = *wlc_surface_get_size(config->surface);
+ struct wlc_geometry geo = {
+ .size = size
+ };
+ switch (desktop_shell.panel_position) {
+ case DESKTOP_SHELL_PANEL_POSITION_TOP:
+ geo.origin = (struct wlc_origin){ 0, 0 };
+ break;
+ case DESKTOP_SHELL_PANEL_POSITION_BOTTOM:
+ geo.origin = (struct wlc_origin){ 0, resolution.h - size.h };
+ break;
+ case DESKTOP_SHELL_PANEL_POSITION_LEFT:
+ geo.origin = (struct wlc_origin){ 0, 0 };
+ break;
+ case DESKTOP_SHELL_PANEL_POSITION_RIGHT:
+ geo.origin = (struct wlc_origin){ resolution.w - size.w, 0 };
+ break;
+ }
+ wlc_surface_render(config->surface, &geo);
+ if (size.w != desktop_shell.panel_size.w || size.h != desktop_shell.panel_size.h) {
+ desktop_shell.panel_size = size;
+ arrange_windows(&root_container, -1, -1);
+ }
break;
}
}
diff --git a/sway/layout.c b/sway/layout.c
index de186886..70980ec3 100644
--- a/sway/layout.c
+++ b/sway/layout.c
@@ -1,6 +1,7 @@
#include <stdlib.h>
#include <stdbool.h>
#include <wlc/wlc.h>
+#include "extensions.h"
#include "layout.h"
#include "log.h"
#include "list.h"
@@ -426,6 +427,27 @@ static void arrange_windows_r(swayc_t *container, double width, double height) {
}
return;
case C_OUTPUT:
+ for (i = 0; i < desktop_shell.panels->length; ++i) {
+ struct panel_config *config = desktop_shell.panels->items[i];
+ if (config->output == container->handle) {
+ struct wlc_size size = *wlc_surface_get_size(config->surface);
+ switch (desktop_shell.panel_position) {
+ case DESKTOP_SHELL_PANEL_POSITION_TOP:
+ y += size.h; height -= size.h;
+ break;
+ case DESKTOP_SHELL_PANEL_POSITION_BOTTOM:
+ height -= size.h;
+ break;
+ case DESKTOP_SHELL_PANEL_POSITION_LEFT:
+ x += size.w; width -= size.w;
+ break;
+ case DESKTOP_SHELL_PANEL_POSITION_RIGHT:
+ width -= size.w;
+ break;
+ }
+ }
+ }
+
container->width = width;
container->height = height;
x = 0, y = 0;
diff --git a/swaybar/main.c b/swaybar/main.c
index dfdda9ca..b25d8252 100644
--- a/swaybar/main.c
+++ b/swaybar/main.c
@@ -25,34 +25,34 @@ struct colors {
struct registry *registry;
struct window *window;
struct colors colors = {
- .background = 0x00000000,
- .statusline = 0xffffffff,
- .seperator = 0x666666ff,
+ .background = 0x000000FF,
+ .statusline = 0xFFFFFFFF,
+ .seperator = 0x666666FF,
.focused_workspace = {
- .border = 0x4c7899ff,
- .background = 0x285577ff,
- .text = 0xffffffff
+ .border = 0x4C7899FF,
+ .background = 0x285577FF,
+ .text = 0xFFFFFFFF
},
.active_workspace = {
- .border = 0x333333ff,
- .background = 0x5f676aff,
- .text = 0xffffffff
+ .border = 0x333333FF,
+ .background = 0x5F676AFF,
+ .text = 0xFFFFFFFF
},
.inactive_workspace = {
- .border = 0x333333ff,
- .background = 0x222222ff,
- .text = 0x888888ff
+ .border = 0x333333FF,
+ .background = 0x222222FF,
+ .text = 0x888888FF
},
.urgent_workspace = {
- .border = 0x2f343aff,
- .background = 0x900000ff,
- .text = 0xffffffff
+ .border = 0x2F343AFF,
+ .background = 0x900000FF,
+ .text = 0xFFFFFFFF
},
.binding_mode = {
- .border = 0x2f343aff,
- .background = 0x900000ff,
- .text = 0xffffffff
+ .border = 0x2F343AFF,
+ .background = 0x900000FF,
+ .text = 0xFFFFFFFF
},
};