diff --git a/config.def.h b/config.def.h index 81c3fc0..6f61588 100644 --- a/config.def.h +++ b/config.def.h @@ -5,6 +5,7 @@ static const unsigned int borderpx = 1; /* border pixel of windows */ static const unsigned int snap = 32; /* snap pixel */ static const int showbar = 1; /* 0 means no bar */ static const int topbar = 1; /* 0 means bottom bar */ +static const int allowkill = 1; /* allow killing clients by default? */ static const char *fonts[] = { "monospace:size=10" }; static const char dmenufont[] = "monospace:size=10"; static const char col_gray1[] = "#222222"; @@ -26,9 +27,9 @@ static const Rule rules[] = { * WM_CLASS(STRING) = instance, class * WM_NAME(STRING) = title */ - /* class instance title tags mask isfloating monitor */ - { "Gimp", NULL, NULL, 0, 1, -1 }, - { "Firefox", NULL, NULL, 1 << 8, 0, -1 }, + /* class instance title tags mask allowkill isfloating monitor */ + { "Gimp", NULL, NULL, 0, 1, 1, -1 }, + { "Firefox", NULL, NULL, 1 << 8, 1, 0, -1 }, }; /* layout(s) */ @@ -80,6 +81,7 @@ static const Key keys[] = { { MODKEY, XK_m, setlayout, {.v = &layouts[2]} }, { MODKEY, XK_space, setlayout, {0} }, { MODKEY|ShiftMask, XK_space, togglefloating, {0} }, + { MODKEY, XK_q, toggleallowkill,{0} }, { MODKEY, XK_0, view, {.ui = ~0 } }, { MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } }, { MODKEY, XK_comma, focusmon, {.i = -1 } }, diff --git a/dwm.c b/dwm.c index ab3a84c..6fe2271 100644 --- a/dwm.c +++ b/dwm.c @@ -92,6 +92,7 @@ struct Client { int bw, oldbw; unsigned int tags; int isfixed, isfloating, isurgent, neverfocus, oldstate, isfullscreen; + int allowkill; Client *next; Client *snext; Monitor *mon; @@ -136,6 +137,7 @@ typedef struct { const char *instance; const char *title; unsigned int tags; + int allowkill; int isfloating; int monitor; } Rule; @@ -210,6 +212,7 @@ static void tagmon(const Arg *arg); static void tile(Monitor *m); static void togglebar(const Arg *arg); static void togglefloating(const Arg *arg); +static void toggleallowkill(const Arg *arg); static void toggletag(const Arg *arg); static void toggleview(const Arg *arg); static void unfocus(Client *c, int setfocus); @@ -286,6 +289,7 @@ applyrules(Client *c) /* rule matching */ c->isfloating = 0; c->tags = 0; + c->allowkill = allowkill; XGetClassHint(dpy, c->win, &ch); class = ch.res_class ? ch.res_class : broken; instance = ch.res_name ? ch.res_name : broken; @@ -298,6 +302,7 @@ applyrules(Client *c) { c->isfloating = r->isfloating; c->tags |= r->tags; + c->allowkill = r->allowkill; for (m = mons; m && m->num != r->monitor; m = m->next); if (m) c->mon = m; @@ -1015,7 +1020,7 @@ keypress(XEvent *e) void killclient(const Arg *arg) { - if (!selmon->sel) + if (!selmon->sel || !selmon->sel->allowkill) return; if (!sendevent(selmon->sel, wmatom[WMDelete])) { XGrabServer(dpy); @@ -1721,6 +1726,13 @@ togglebar(const Arg *arg) arrange(selmon); } +void +toggleallowkill(const Arg *arg) +{ + if (!selmon->sel) return; + selmon->sel->allowkill = !selmon->sel->allowkill; +} + void togglefloating(const Arg *arg) {