m Added combo patch
This commit is contained in:
parent
9cbc6bfeb9
commit
ab4b736cda
43
dwm.c
43
dwm.c
@ -270,6 +270,11 @@ static int xerrordummy(Display *dpy, XErrorEvent *ee);
|
|||||||
static int xerrorstart(Display *dpy, XErrorEvent *ee);
|
static int xerrorstart(Display *dpy, XErrorEvent *ee);
|
||||||
static void zoom(const Arg *arg);
|
static void zoom(const Arg *arg);
|
||||||
|
|
||||||
|
static void keyrelease(XEvent *e);
|
||||||
|
static void combotag(const Arg *arg);
|
||||||
|
static void comboview(const Arg *arg);
|
||||||
|
|
||||||
|
|
||||||
/* variables */
|
/* variables */
|
||||||
static const char *exec_name;
|
static const char *exec_name;
|
||||||
static Systray *systray = NULL;
|
static Systray *systray = NULL;
|
||||||
@ -283,6 +288,7 @@ 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,
|
||||||
|
[ButtonRelease] = keyrelease,
|
||||||
[ClientMessage] = clientmessage,
|
[ClientMessage] = clientmessage,
|
||||||
[ConfigureRequest] = configurerequest,
|
[ConfigureRequest] = configurerequest,
|
||||||
[ConfigureNotify] = configurenotify,
|
[ConfigureNotify] = configurenotify,
|
||||||
@ -290,6 +296,7 @@ static void (*handler[LASTEvent]) (XEvent *) = {
|
|||||||
[EnterNotify] = enternotify,
|
[EnterNotify] = enternotify,
|
||||||
[Expose] = expose,
|
[Expose] = expose,
|
||||||
[FocusIn] = focusin,
|
[FocusIn] = focusin,
|
||||||
|
[KeyRelease] = keyrelease,
|
||||||
[KeyPress] = keypress,
|
[KeyPress] = keypress,
|
||||||
[MappingNotify] = mappingnotify,
|
[MappingNotify] = mappingnotify,
|
||||||
[MapRequest] = maprequest,
|
[MapRequest] = maprequest,
|
||||||
@ -314,6 +321,42 @@ static Window root, wmcheckwin;
|
|||||||
struct NumTags { char limitexceeded[LENGTH(tags) > 31 ? -1 : 1]; };
|
struct NumTags { char limitexceeded[LENGTH(tags) > 31 ? -1 : 1]; };
|
||||||
|
|
||||||
/* function implementations */
|
/* function implementations */
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
applyrules(Client *c)
|
applyrules(Client *c)
|
||||||
{
|
{
|
||||||
|
75
patches/dwm-combo-6.1.diff
Normal file
75
patches/dwm-combo-6.1.diff
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
diff --git a/dwm.c b/dwm.c
|
||||||
|
index 0362114..40b7a99 100644
|
||||||
|
--- a/dwm.c
|
||||||
|
+++ b/dwm.c
|
||||||
|
@@ -234,6 +234,11 @@ static int xerrordummy(Display *dpy, XErrorEvent *ee);
|
||||||
|
static int xerrorstart(Display *dpy, XErrorEvent *ee);
|
||||||
|
static void zoom(const Arg *arg);
|
||||||
|
|
||||||
|
+static void keyrelease(XEvent *e);
|
||||||
|
+static void combotag(const Arg *arg);
|
||||||
|
+static void comboview(const Arg *arg);
|
||||||
|
+
|
||||||
|
+
|
||||||
|
/* variables */
|
||||||
|
static const char broken[] = "broken";
|
||||||
|
static char stext[256];
|
||||||
|
@@ -244,6 +249,7 @@ static int (*xerrorxlib)(Display *, XErrorEvent *);
|
||||||
|
static unsigned int numlockmask = 0;
|
||||||
|
static void (*handler[LASTEvent]) (XEvent *) = {
|
||||||
|
[ButtonPress] = buttonpress,
|
||||||
|
+ [ButtonRelease] = keyrelease,
|
||||||
|
[ClientMessage] = clientmessage,
|
||||||
|
[ConfigureRequest] = configurerequest,
|
||||||
|
[ConfigureNotify] = configurenotify,
|
||||||
|
@@ -251,6 +257,7 @@ static void (*handler[LASTEvent]) (XEvent *) = {
|
||||||
|
[EnterNotify] = enternotify,
|
||||||
|
[Expose] = expose,
|
||||||
|
[FocusIn] = focusin,
|
||||||
|
+ [KeyRelease] = keyrelease,
|
||||||
|
[KeyPress] = keypress,
|
||||||
|
[MappingNotify] = mappingnotify,
|
||||||
|
[MapRequest] = maprequest,
|
||||||
|
@@ -274,6 +281,42 @@ static Window root;
|
||||||
|
struct NumTags { char limitexceeded[LENGTH(tags) > 31 ? -1 : 1]; };
|
||||||
|
|
||||||
|
/* function implementations */
|
||||||
|
+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);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
void
|
||||||
|
applyrules(Client *c)
|
||||||
|
{
|
Loading…
Reference in New Issue
Block a user