Adding sticky and warp patches

This commit is contained in:
bakkeby 2019-09-15 00:43:35 +02:00
parent 713c4e6197
commit 30e0a3b5e4
11 changed files with 83 additions and 5 deletions

View File

@ -13,7 +13,7 @@ Refer to [https://dwm.suckless.org/](https://dwm.suckless.org/) for details on t
### Changelog: ### Changelog:
2019-09-14 - Added setborderpx, selfrestart and push (no master variant) patches 2019-09-14 - Added setborderpx, selfrestart and push (no master variant), sticky and warp patches
2019-09-13 - Added titlecolor and push patches 2019-09-13 - Added titlecolor and push patches
@ -128,12 +128,15 @@ Refer to [https://dwm.suckless.org/](https://dwm.suckless.org/) for details on t
- [statuspadding](https://dwm.suckless.org/patches/statuspadding/) - [statuspadding](https://dwm.suckless.org/patches/statuspadding/)
- adds configuration options for horizontal and vertical padding in the status bar - adds configuration options for horizontal and vertical padding in the status bar
- [systray](https://dwm.suckless.org/patches/systray/) - [sticky](https://dwm.suckless.org/patches/sticky/)
- adds system tray in the status bar - adds toggleable keyboard shortcut to make a client 'sticky', i.e. visible on all tags
- [switchtag](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-switchtag-6.2.diff) - [switchtag](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-switchtag-6.2.diff)
- when an application opens on a specific tab this patch adds the option to also switch to that tag when the application starts - when an application opens on a specific tab this patch adds the option to also switch to that tag when the application starts
- [systray](https://dwm.suckless.org/patches/systray/)
- adds system tray in the status bar
- [tagallmon](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-tagallmon-6.2.diff) - [tagallmon](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-tagallmon-6.2.diff)
- move all visible windows to an adjacent monitor - move all visible windows to an adjacent monitor
@ -152,6 +155,9 @@ Refer to [https://dwm.suckless.org/](https://dwm.suckless.org/) for details on t
- [vanitygaps](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-vanitygaps-6.2.diff) - [vanitygaps](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-vanitygaps-6.2.diff)
- adds configurable gaps between windows differentiating between outer, inner, horizontal and vertical gaps - adds configurable gaps between windows differentiating between outer, inner, horizontal and vertical gaps
- [warp](https://dwm.suckless.org/patches/warp/)
- warps the mouse cursor to the center of the currently focused window or screen when the mouse cursor is (a) on a different screen or (b) on top of a different window
- [windowrolerule](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-windowrolerule-6.2.diff) - [windowrolerule](https://github.com/bakkeby/dwm-vanitygaps/blob/master/patches/dwm-windowrolerule-6.2.diff)
- sometimes a single application opens different windows depending on the task at hand and this is often reflected in the WM_WINDOW_ROLE(STRING) x property - sometimes a single application opens different windows depending on the task at hand and this is often reflected in the WM_WINDOW_ROLE(STRING) x property
- this patch adds the role field to the rule configuration so that one can differentiate between, say, Firefox "browser" vs "Preferences" vs "Manager" or Google-chrome "browser" vs "pop-up". - this patch adds the role field to the rule configuration so that one can differentiate between, say, Firefox "browser" vs "Preferences" vs "Manager" or Google-chrome "browser" vs "pop-up".

View File

@ -299,6 +299,9 @@ static Key keys[] = {
#if TOGGLEFULLSCREEN_PATCH #if TOGGLEFULLSCREEN_PATCH
{ MODKEY, XK_y, togglefullscreen, {0} }, { MODKEY, XK_y, togglefullscreen, {0} },
#endif // TOGGLEFULLSCREEN_PATCH #endif // TOGGLEFULLSCREEN_PATCH
#if STICKY_PATCH
{ MODKEY, XK_s, togglesticky, {0} },
#endif // STICKY_PATCH
{ MODKEY, XK_0, view, {.ui = ~0 } }, { MODKEY, XK_0, view, {.ui = ~0 } },
{ MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } }, { MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } },
{ MODKEY, XK_comma, focusmon, {.i = -1 } }, { MODKEY, XK_comma, focusmon, {.i = -1 } },

17
dwm.c
View File

@ -50,9 +50,14 @@
#define CLEANMASK(mask) (mask & ~(numlockmask|LockMask) & (ShiftMask|ControlMask|Mod1Mask|Mod2Mask|Mod3Mask|Mod4Mask|Mod5Mask)) #define CLEANMASK(mask) (mask & ~(numlockmask|LockMask) & (ShiftMask|ControlMask|Mod1Mask|Mod2Mask|Mod3Mask|Mod4Mask|Mod5Mask))
#define INTERSECT(x,y,w,h,m) (MAX(0, MIN((x)+(w),(m)->wx+(m)->ww) - MAX((x),(m)->wx)) \ #define INTERSECT(x,y,w,h,m) (MAX(0, MIN((x)+(w),(m)->wx+(m)->ww) - MAX((x),(m)->wx)) \
* MAX(0, MIN((y)+(h),(m)->wy+(m)->wh) - MAX((y),(m)->wy))) * MAX(0, MIN((y)+(h),(m)->wy+(m)->wh) - MAX((y),(m)->wy)))
#if ATTACHASIDE_PATCH #if ATTACHASIDE_PATCH && STICKY_PATCH
#define ISVISIBLEONTAG(C, T) ((C->tags & T) || C->issticky)
#define ISVISIBLE(C) ISVISIBLEONTAG(C, C->mon->tagset[C->mon->seltags])
#elif ATTACHASIDE_PATCH
#define ISVISIBLEONTAG(C, T) ((C->tags & T)) #define ISVISIBLEONTAG(C, T) ((C->tags & T))
#define ISVISIBLE(C) ISVISIBLEONTAG(C, C->mon->tagset[C->mon->seltags]) #define ISVISIBLE(C) ISVISIBLEONTAG(C, C->mon->tagset[C->mon->seltags])
#elif STICKY_PATCH
#define ISVISIBLE(C) ((C->tags & C->mon->tagset[C->mon->seltags]) || C->issticky)
#else #else
#define ISVISIBLE(C) ((C->tags & C->mon->tagset[C->mon->seltags])) #define ISVISIBLE(C) ((C->tags & C->mon->tagset[C->mon->seltags]))
#endif // ATTACHASIDE_PATCH #endif // ATTACHASIDE_PATCH
@ -138,6 +143,9 @@ struct Client {
#if CENTER_PATCH #if CENTER_PATCH
int iscentered; int iscentered;
#endif // CENTER_PATCH #endif // CENTER_PATCH
#if STICKY_PATCH
int issticky;
#endif // STICKY_PATCH
Client *next; Client *next;
Client *snext; Client *snext;
Monitor *mon; Monitor *mon;
@ -1323,6 +1331,9 @@ focusmon(const Arg *arg)
unfocus(selmon->sel, 0); unfocus(selmon->sel, 0);
selmon = m; selmon = m;
focus(NULL); focus(NULL);
#if WARP_PATCH
warp(selmon->sel);
#endif // WARP_PATCH
} }
void void
@ -2007,6 +2018,10 @@ restack(Monitor *m)
} }
XSync(dpy, False); XSync(dpy, False);
while (XCheckMaskEvent(dpy, EnterWindowMask, &ev)); while (XCheckMaskEvent(dpy, EnterWindowMask, &ev));
#if WARP_PATCH
if (m == selmon && (m->tagset[m->seltags] & m->sel->tags) && selmon->lt[selmon->sellt] != &layouts[2])
warp(m->sel);
#endif // WARP_PATCH
} }
void void

View File

@ -58,6 +58,10 @@
#include "setborderpx.c" #include "setborderpx.c"
#endif #endif
#if STICKY_PATCH
#include "sticky.c"
#endif
#if SYSTRAY_PATCH #if SYSTRAY_PATCH
#include "systray.c" #include "systray.c"
#endif #endif
@ -78,6 +82,10 @@
#include "vanitygaps.c" #include "vanitygaps.c"
#endif #endif
#if WARP_PATCH
#include "warp.c"
#endif
#if ZOOMSWAP_PATCH #if ZOOMSWAP_PATCH
#include "zoomswap.c" #include "zoomswap.c"
#endif #endif

View File

@ -54,6 +54,10 @@
#include "setborderpx.h" #include "setborderpx.h"
#endif #endif
#if STICKY_PATCH
#include "sticky.h"
#endif
#if SYSTRAY_PATCH #if SYSTRAY_PATCH
#include "systray.h" #include "systray.h"
#endif #endif

View File

@ -34,7 +34,7 @@ pushup(const Arg *arg)
if (selmon->clients == c) if (selmon->clients == c)
selmon->clients = sel; selmon->clients = sel;
else { else {
for (c f selmon->clients; c->next != sel->next; c = c->next); for (c = selmon->clients; c->next != sel->next; c = c->next);
c->next = sel; c->next = sel;
} }
} else { } else {

8
patch/sticky.c Normal file
View File

@ -0,0 +1,8 @@
void
togglesticky(const Arg *arg)
{
if (!selmon->sel)
return;
selmon->sel->issticky = !selmon->sel->issticky;
arrange(selmon);
}

1
patch/sticky.h Normal file
View File

@ -0,0 +1 @@
static void togglesticky(const Arg *arg);

21
patch/warp.c Normal file
View File

@ -0,0 +1,21 @@
void
warp(const Client *c)
{
int x, y;
if (!c) {
XWarpPointer(dpy, None, root, 0, 0, 0, 0, selmon->wx + selmon->ww/2, selmon->wy + selmon->wh/2);
return;
}
if (!getrootptr(&x, &y) ||
(x > c->x - c->bw &&
y > c->y - c->bw &&
x < c->x + c->w + c->bw*2 &&
y < c->y + c->h + c->bw*2) ||
(y > c->mon->by && y < c->mon->by + bh) ||
(c->mon->topbar && !y))
return;
XWarpPointer(dpy, None, c->win, 0, 0, 0, 0, c->w / 2, c->h / 2);
}

1
patch/warp.h Normal file
View File

@ -0,0 +1 @@
static void warp(const Client *c);

View File

@ -210,6 +210,11 @@
*/ */
#define STATUSPADDING_PATCH 0 #define STATUSPADDING_PATCH 0
/* Adds toggleable keyboard shortcut to make a client 'sticky', i.e. visible on all tags.
* https://dwm.suckless.org/patches/sticky/
*/
#define STICKY_PATCH 0
/* The systray patch adds systray for the status bar. /* The systray patch adds systray for the status bar.
* https://dwm.suckless.org/patches/systray/ * https://dwm.suckless.org/patches/systray/
*/ */
@ -265,6 +270,12 @@
*/ */
#define VANITYGAPS_PATCH 0 #define VANITYGAPS_PATCH 0
/* This patch warps the mouse cursor to the center of the currently focused window or screen
* when the mouse cursor is (a) on a different screen or (b) on top of a different window.
* https://dwm.suckless.org/patches/warp/
*/
#define WARP_PATCH 0
/* Sometimes a single application opens different windows depending on the task /* Sometimes a single application opens different windows depending on the task
* at hand and this is often reflected in the WM_WINDOW_ROLE(STRING) x property. * at hand and this is often reflected in the WM_WINDOW_ROLE(STRING) x property.
* This patch adds the role field to the rule configuration so that one can * This patch adds the role field to the rule configuration so that one can