mirror of
https://github.com/mintycube/dwm.git
synced 2024-10-22 12:05:45 +00:00
Adding combo patch
This commit is contained in:
parent
e89f262323
commit
706e06be43
@ -13,7 +13,7 @@ Refer to [https://dwm.suckless.org/](https://dwm.suckless.org/) for details on t
|
|||||||
|
|
||||||
### Changelog:
|
### Changelog:
|
||||||
|
|
||||||
2019-09-11 - Added monitor rules patch.
|
2019-09-11 - Added monitor rules and combo patches
|
||||||
|
|
||||||
2019-09-10 - Minor tweaks to awesomebar patch (incl. alpha and systray compatibility). Added floatbordercolor patch.
|
2019-09-10 - Minor tweaks to awesomebar patch (incl. alpha and systray compatibility). Added floatbordercolor patch.
|
||||||
|
|
||||||
@ -59,6 +59,9 @@ Refer to [https://dwm.suckless.org/](https://dwm.suckless.org/) for details on t
|
|||||||
- [cfacts](https://dwm.suckless.org/patches/cfacts/)
|
- [cfacts](https://dwm.suckless.org/patches/cfacts/)
|
||||||
- the cfacts patch provides the ability to assign different weights to clients in their respective stack in tiled layout
|
- the cfacts patch provides the ability to assign different weights to clients in their respective stack in tiled layout
|
||||||
|
|
||||||
|
- [combo](https://dwm.suckless.org/patches/combo/)
|
||||||
|
- allows you to select multiple tags by pressing all the right keys as a combo, e.g. hold MOD and press and hold 1 and 3 together to view those two tags
|
||||||
|
|
||||||
- [cyclelayouts](https://dwm.suckless.org/patches/cyclelayouts/)
|
- [cyclelayouts](https://dwm.suckless.org/patches/cyclelayouts/)
|
||||||
- lets you cycle through all your layouts
|
- lets you cycle through all your layouts
|
||||||
|
|
||||||
|
@ -189,11 +189,19 @@ static const Layout layouts[] = {
|
|||||||
|
|
||||||
/* key definitions */
|
/* key definitions */
|
||||||
#define MODKEY Mod1Mask
|
#define MODKEY Mod1Mask
|
||||||
|
#if COMBO_PATCH
|
||||||
|
#define TAGKEYS(KEY,TAG) \
|
||||||
|
{ MODKEY, KEY, comboview, {.ui = 1 << TAG} }, \
|
||||||
|
{ MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
|
||||||
|
{ MODKEY|ShiftMask, KEY, combotag, {.ui = 1 << TAG} }, \
|
||||||
|
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
|
||||||
|
#else
|
||||||
#define TAGKEYS(KEY,TAG) \
|
#define TAGKEYS(KEY,TAG) \
|
||||||
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
||||||
{ MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
|
{ MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
|
||||||
{ MODKEY|ShiftMask, KEY, tag, {.ui = 1 << TAG} }, \
|
{ MODKEY|ShiftMask, KEY, tag, {.ui = 1 << TAG} }, \
|
||||||
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
|
{ MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
|
||||||
|
#endif // COMBO_PATCH
|
||||||
|
|
||||||
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
|
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
|
||||||
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
||||||
|
6
dwm.c
6
dwm.c
@ -326,6 +326,9 @@ static int (*xerrorxlib)(Display *, XErrorEvent *);
|
|||||||
static unsigned int numlockmask = 0;
|
static unsigned int numlockmask = 0;
|
||||||
static void (*handler[LASTEvent]) (XEvent *) = {
|
static void (*handler[LASTEvent]) (XEvent *) = {
|
||||||
[ButtonPress] = buttonpress,
|
[ButtonPress] = buttonpress,
|
||||||
|
#if COMBO_PATCH
|
||||||
|
[ButtonRelease] = keyrelease,
|
||||||
|
#endif // COMBO_PATCH
|
||||||
[ClientMessage] = clientmessage,
|
[ClientMessage] = clientmessage,
|
||||||
[ConfigureRequest] = configurerequest,
|
[ConfigureRequest] = configurerequest,
|
||||||
[ConfigureNotify] = configurenotify,
|
[ConfigureNotify] = configurenotify,
|
||||||
@ -334,6 +337,9 @@ static void (*handler[LASTEvent]) (XEvent *) = {
|
|||||||
[Expose] = expose,
|
[Expose] = expose,
|
||||||
[FocusIn] = focusin,
|
[FocusIn] = focusin,
|
||||||
[KeyPress] = keypress,
|
[KeyPress] = keypress,
|
||||||
|
#if COMBO_PATCH
|
||||||
|
[KeyRelease] = keyrelease,
|
||||||
|
#endif // COMBO_PATCH
|
||||||
[MappingNotify] = mappingnotify,
|
[MappingNotify] = mappingnotify,
|
||||||
[MapRequest] = maprequest,
|
[MapRequest] = maprequest,
|
||||||
[MotionNotify] = motionnotify,
|
[MotionNotify] = motionnotify,
|
||||||
|
35
patch/combo.c
Normal file
35
patch/combo.c
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
static int combo = 0;
|
||||||
|
|
||||||
|
void
|
||||||
|
keyrelease(XEvent *e) {
|
||||||
|
combo = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
combotag(const Arg *arg) {
|
||||||
|
if(selmon->sel && arg->ui & TAGMASK) {
|
||||||
|
if (combo) {
|
||||||
|
selmon->sel->tags |= arg->ui & TAGMASK;
|
||||||
|
} else {
|
||||||
|
combo = 1;
|
||||||
|
selmon->sel->tags = arg->ui & TAGMASK;
|
||||||
|
}
|
||||||
|
focus(NULL);
|
||||||
|
arrange(selmon);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
comboview(const Arg *arg) {
|
||||||
|
unsigned newtags = arg->ui & TAGMASK;
|
||||||
|
if (combo) {
|
||||||
|
selmon->tagset[selmon->seltags] |= newtags;
|
||||||
|
} else {
|
||||||
|
selmon->seltags ^= 1; /*toggle tagset*/
|
||||||
|
combo = 1;
|
||||||
|
if (newtags)
|
||||||
|
selmon->tagset[selmon->seltags] = newtags;
|
||||||
|
}
|
||||||
|
focus(NULL);
|
||||||
|
arrange(selmon);
|
||||||
|
}
|
3
patch/combo.h
Normal file
3
patch/combo.h
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
static void keyrelease(XEvent *e);
|
||||||
|
static void combotag(const Arg *arg);
|
||||||
|
static void comboview(const Arg *arg);
|
@ -24,6 +24,10 @@
|
|||||||
#include "cfacts.c"
|
#include "cfacts.c"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if COMBO_PATCH
|
||||||
|
#include "combo.c"
|
||||||
|
#endif
|
||||||
|
|
||||||
#if CYCLELAYOUTS_PATCH
|
#if CYCLELAYOUTS_PATCH
|
||||||
#include "cyclelayouts.c"
|
#include "cyclelayouts.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -24,6 +24,10 @@
|
|||||||
#include "cfacts.h"
|
#include "cfacts.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if COMBO_PATCH
|
||||||
|
#include "combo.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#if CYCLELAYOUTS_PATCH
|
#if CYCLELAYOUTS_PATCH
|
||||||
#include "cyclelayouts.h"
|
#include "cyclelayouts.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -73,6 +73,13 @@
|
|||||||
*/
|
*/
|
||||||
#define CFACTS_PATCH 0
|
#define CFACTS_PATCH 0
|
||||||
|
|
||||||
|
/* This patch tweaks the tagging interface so that you can select multiple tags for tag
|
||||||
|
* or view by pressing all the right keys as a combo. For example to view tags 1 and 3,
|
||||||
|
* hold MOD and then press and hold 1 and 3 together.
|
||||||
|
* https://dwm.suckless.org/patches/combo/
|
||||||
|
*/
|
||||||
|
#define COMBO_PATCH 0
|
||||||
|
|
||||||
/* The cyclelayouts patch lets you cycle through all your layouts.
|
/* The cyclelayouts patch lets you cycle through all your layouts.
|
||||||
* https://dwm.suckless.org/patches/cyclelayouts/
|
* https://dwm.suckless.org/patches/cyclelayouts/
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user