summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDevin J. Pohly <djpohly@gmail.com>2021-04-09 12:53:15 -0500
committerDevin J. Pohly <djpohly@gmail.com>2021-04-09 12:53:15 -0500
commit77e75cf5549147946da2a5ebfbc63eecf8f82078 (patch)
tree967a91fca6bd20a568a2d9054e248d61bca57dbc
parent84b26ef1bae83cdf0f305d2c81d345c8ef73d0d0 (diff)
parent9071ce6c848ce214939fb84f85ae77de86de88d7 (diff)
Merge branch 'main' into wlroots-next
-rw-r--r--dwl.c45
1 files changed, 6 insertions, 39 deletions
diff --git a/dwl.c b/dwl.c
index 0deae84..d463985 100644
--- a/dwl.c
+++ b/dwl.c
@@ -32,6 +32,7 @@
#include <wlr/types/wlr_primary_selection.h>
#include <wlr/types/wlr_primary_selection_v1.h>
#include <wlr/types/wlr_screencopy_v1.h>
+#include <wlr/types/wlr_server_decoration.h>
#include <wlr/types/wlr_seat.h>
#include <wlr/types/wlr_viewporter.h>
#include <wlr/types/wlr_virtual_keyboard_v1.h>
@@ -228,18 +229,15 @@ static void createmon(struct wl_listener *listener, void *data);
static void createnotify(struct wl_listener *listener, void *data);
static void createlayersurface(struct wl_listener *listener, void *data);
static void createpointer(struct wlr_input_device *device);
-static void createxdeco(struct wl_listener *listener, void *data);
static void cursorframe(struct wl_listener *listener, void *data);
static void destroylayersurfacenotify(struct wl_listener *listener, void *data);
static void destroynotify(struct wl_listener *listener, void *data);
-static void destroyxdeco(struct wl_listener *listener, void *data);
static Monitor *dirtomon(enum wlr_direction dir);
static void focusclient(Client *c, int lift);
static void focusmon(const Arg *arg);
static void focusstack(const Arg *arg);
static void fullscreennotify(struct wl_listener *listener, void *data);
static Client *focustop(Monitor *m);
-static void getxdecomode(struct wl_listener *listener, void *data);
static void incnmaster(const Arg *arg);
static void inputdevice(struct wl_listener *listener, void *data);
static int keybinding(uint32_t mods, xkb_keysym_t sym);
@@ -312,7 +310,6 @@ static struct wl_list stack; /* stacking z-order */
static struct wl_list independents;
static struct wlr_idle *idle;
static struct wlr_layer_shell_v1 *layer_shell;
-static struct wlr_xdg_decoration_manager_v1 *xdeco_mgr;
static struct wlr_output_manager_v1 *output_mgr;
static struct wlr_virtual_keyboard_manager_v1 *virtual_keyboard_mgr;
@@ -344,7 +341,6 @@ static struct wl_listener layout_change = {.notify = updatemons};
static struct wl_listener new_input = {.notify = inputdevice};
static struct wl_listener new_virtual_keyboard = {.notify = virtualkeyboard};
static struct wl_listener new_output = {.notify = createmon};
-static struct wl_listener new_xdeco = {.notify = createxdeco};
static struct wl_listener new_xdg_surface = {.notify = createnotify};
static struct wl_listener new_layer_shell_surface = {.notify = createlayersurface};
static struct wl_listener output_mgr_apply = {.notify = outputmgrapply};
@@ -959,18 +955,6 @@ createpointer(struct wlr_input_device *device)
}
void
-createxdeco(struct wl_listener *listener, void *data)
-{
- struct wlr_xdg_toplevel_decoration_v1 *wlr_deco = data;
- Decoration *d = wlr_deco->data = calloc(1, sizeof(*d));
-
- LISTEN(&wlr_deco->events.request_mode, &d->request_mode, getxdecomode);
- LISTEN(&wlr_deco->events.destroy, &d->destroy, destroyxdeco);
-
- getxdecomode(&d->request_mode, wlr_deco);
-}
-
-void
cursorframe(struct wl_listener *listener, void *data)
{
/* This event is forwarded by the cursor when a pointer emits an frame
@@ -1021,17 +1005,6 @@ destroynotify(struct wl_listener *listener, void *data)
}
void
-destroyxdeco(struct wl_listener *listener, void *data)
-{
- struct wlr_xdg_toplevel_decoration_v1 *wlr_deco = data;
- Decoration *d = wlr_deco->data;
-
- wl_list_remove(&d->destroy.link);
- wl_list_remove(&d->request_mode.link);
- free(d);
-}
-
-void
togglefullscreen(const Arg *arg)
{
Client *sel = selclient();
@@ -1186,14 +1159,6 @@ focustop(Monitor *m)
}
void
-getxdecomode(struct wl_listener *listener, void *data)
-{
- struct wlr_xdg_toplevel_decoration_v1 *wlr_deco = data;
- wlr_xdg_toplevel_decoration_v1_set_mode(wlr_deco,
- WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE);
-}
-
-void
incnmaster(const Arg *arg)
{
selmon->nmaster = MAX(selmon->nmaster + arg->i, 0);
@@ -2051,9 +2016,11 @@ setup(void)
xdg_shell = wlr_xdg_shell_create(dpy);
wl_signal_add(&xdg_shell->events.new_surface, &new_xdg_surface);
- /* Use xdg_decoration protocol to negotiate server-side decorations */
- xdeco_mgr = wlr_xdg_decoration_manager_v1_create(dpy);
- wl_signal_add(&xdeco_mgr->events.new_toplevel_decoration, &new_xdeco);
+ /* Use decoration protocols to negotiate server-side decorations */
+ wlr_server_decoration_manager_set_default_mode(
+ wlr_server_decoration_manager_create(dpy),
+ WLR_SERVER_DECORATION_MANAGER_MODE_SERVER);
+ wlr_xdg_decoration_manager_v1_create(dpy);
/*
* Creates a cursor, which is a wlroots utility for tracking the cursor