commit 73992a874ae01b87ebed5cf23f0e4cf2840af27d
parent 4a4a26111107d5f2827606cd630873d798bc8bf6
Author: Devin J. Pohly <djpohly@gmail.com>
Date: Thu, 23 Jul 2020 15:24:01 -0500
Merge pull request #16 from guidocella/killclient
Add killclient
Diffstat:
2 files changed, 15 insertions(+), 0 deletions(-)
diff --git a/config.def.h b/config.def.h
@@ -60,6 +60,7 @@ static const Key keys[] = {
{ MODKEY, XKB_KEY_h, setmfact, {.f = -0.05} },
{ MODKEY, XKB_KEY_l, setmfact, {.f = +0.05} },
{ MODKEY, XKB_KEY_Tab, view, {0} },
+ { MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_c, killclient, {0} },
{ MODKEY, XKB_KEY_t, setlayout, {.v = &layouts[0]} },
{ MODKEY, XKB_KEY_f, setlayout, {.v = &layouts[1]} },
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_space, togglefloating, {0} },
diff --git a/dwl.c b/dwl.c
@@ -171,6 +171,7 @@ static void inputdevice(struct wl_listener *listener, void *data);
static int keybinding(uint32_t mods, xkb_keysym_t sym);
static void keypress(struct wl_listener *listener, void *data);
static void keypressmod(struct wl_listener *listener, void *data);
+static void killclient(const Arg *arg);
static Client *lastfocused(void);
static void maprequest(struct wl_listener *listener, void *data);
static void motionabsolute(struct wl_listener *listener, void *data);
@@ -812,6 +813,19 @@ keypressmod(struct wl_listener *listener, void *data)
&kb->device->keyboard->modifiers);
}
+void
+killclient(const Arg *arg)
+{
+ Client *sel = selclient();
+ if (!sel)
+ return;
+
+ if (sel->isx11)
+ wlr_xwayland_surface_close(sel->xwayland_surface);
+ else
+ wlr_xdg_toplevel_send_close(sel->xdg_surface);
+}
+
Client *
lastfocused(void)
{