summaryrefslogtreecommitdiff
path: root/sway/handlers.c
diff options
context:
space:
mode:
authorDrew DeVault <[email protected]>2017-06-14 19:02:15 -0400
committerGitHub <[email protected]>2017-06-14 19:02:15 -0400
commit4e663ab44f5320f20ec2376f24ea1eb3b458f2c2 (patch)
treedcb3b74f1dde93bce8657b7509662ffd7db667d0 /sway/handlers.c
parenteb6e38c86d2deb37cc6f378f8644c4a530fd7448 (diff)
parent298f56353ef155f6a2ccc977c96b2ff5d971e65e (diff)
Merge pull request #1199 from SirCmpwn/server-decoration
Implement KDE's server-side decoration protocol
Diffstat (limited to 'sway/handlers.c')
-rw-r--r--sway/handlers.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/sway/handlers.c b/sway/handlers.c
index a912b991..39261e3d 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -345,6 +345,8 @@ static bool handle_view_created(wlc_handle handle) {
swayc_t *current_ws = swayc_active_workspace();
bool return_to_workspace = false;
struct wl_client *client = wlc_view_get_wl_client(handle);
+ struct wl_resource *resource = wlc_surface_get_wl_resource(
+ wlc_view_get_surface(handle));
pid_t pid;
struct panel_config *panel_config = NULL;
struct background_config *background_config = NULL;
@@ -483,6 +485,14 @@ static bool handle_view_created(wlc_handle handle) {
if (workspace && workspace->fullscreen) {
set_focused_container(workspace->fullscreen);
}
+ for (int i = 0; i < decoration_state.csd_resources->length; ++i) {
+ struct wl_resource *res = decoration_state.csd_resources->items[i];
+ if (res == resource) {
+ list_del(decoration_state.csd_resources, i);
+ server_decoration_enable_csd(handle);
+ break;
+ }
+ }
} else {
swayc_t *output = swayc_parent_by_type(focused, C_OUTPUT);
wlc_handle *h = malloc(sizeof(wlc_handle));