mirror of
https://github.com/mintycube/dwm.git
synced 2024-10-22 12:05:45 +00:00
Adding sticky and warp patches
This commit is contained in:
parent
713c4e6197
commit
30e0a3b5e4
12
README.md
12
README.md
@ -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".
|
||||||
|
@ -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
17
dwm.c
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
8
patch/sticky.c
Normal 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
1
patch/sticky.h
Normal file
@ -0,0 +1 @@
|
|||||||
|
static void togglesticky(const Arg *arg);
|
21
patch/warp.c
Normal file
21
patch/warp.c
Normal 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
1
patch/warp.h
Normal file
@ -0,0 +1 @@
|
|||||||
|
static void warp(const Client *c);
|
11
patches.h
11
patches.h
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user