added heretag command which allows to tag a client of a foreign tag with current tag
authorAnselm R. Garbe <garbeam@wmii.de>
Tue, 18 Jul 2006 09:38:31 +0000 (11:38 +0200)
committerAnselm R. Garbe <garbeam@wmii.de>
Tue, 18 Jul 2006 09:38:31 +0000 (11:38 +0200)
client.c
draw.c
dwm.1
dwm.h
event.c
tag.c

index 69189dea1afb1b5c4e8f750c7447ceb52b1bb1b1..166e9796cd25806e805f60980b24d6cd30214a97 100644 (file)
--- a/client.c
+++ b/client.c
@@ -66,8 +66,8 @@ focusnext(Arg *arg)
        if(!sel)
                return;
 
-       if(!(c = getnext(sel->next)))
-               c = getnext(clients);
+       if(!(c = getnext(sel->next, tsel)))
+               c = getnext(clients, tsel);
        if(c) {
                higher(c);
                c->revert = sel;
@@ -410,8 +410,8 @@ zoom(Arg *arg)
        if(!sel)
                return;
 
-       if(sel == getnext(clients) && sel->next)  {
-               if((c = getnext(sel->next)))
+       if(sel == getnext(clients, tsel) && sel->next)  {
+               if((c = getnext(sel->next, tsel)))
                        sel = c;
        }
 
diff --git a/draw.c b/draw.c
index b8cfffd21d0d1129b1278c7428d85d0d21180ea4..de4bdb0e4feb377d2a3803d8c9076d35f7ebd9dd 100644 (file)
--- a/draw.c
+++ b/draw.c
@@ -97,7 +97,7 @@ drawall()
 {
        Client *c;
 
-       for(c = clients; c; c = getnext(c->next))
+       for(c = clients; c; c = getnext(c->next, tsel))
                drawtitle(c);
        drawstatus();
 }
diff --git a/dwm.1 b/dwm.1
index e1379ba0b9f74e59953680e7fe56b579c29baf7a..96fa7600c68671fbe36ddc79681c99c058bf17cf 100644 (file)
--- a/dwm.1
+++ b/dwm.1
@@ -93,6 +93,14 @@ Append
 tag to current
 .B window
 .TP
+.B Control-Shift-[0..n]
+Replace current
+.B window
+of
+.B nth
+tag with current tag.
+.B window
+.TP
 .B Control-Button1
 Zooms the clicked
 .B window
diff --git a/dwm.h b/dwm.h
index de885274d275e88d412ba5557666de0870a23809..0d37e996858dacd083c9b67d276a000fbccada44 100644 (file)
--- a/dwm.h
+++ b/dwm.h
@@ -145,7 +145,8 @@ extern int xerror(Display *dsply, XErrorEvent *ee);
 extern void appendtag(Arg *arg);
 extern void dofloat(Arg *arg);
 extern void dotile(Arg *arg);
-extern Client *getnext(Client *c);
+extern Client *getnext(Client *c, unsigned int t);
+extern void heretag(Arg *arg);
 extern void replacetag(Arg *arg);
 extern void settags(Client *c);
 extern void view(Arg *arg);
diff --git a/event.c b/event.c
index 0fce36b8b65b0661de722c3292d73f51c12fb695..4b8c07ba06fd057f021a683f1f40c7a820f6c8cb 100644 (file)
--- a/event.c
+++ b/event.c
@@ -35,6 +35,10 @@ Key key[] = {
        { Mod1Mask,                             XK_m,           maximize,               { 0 } }, 
        { Mod1Mask,                             XK_space,       dotile,         { 0 } }, 
        { Mod1Mask,                             XK_Return,      zoom,           { 0 } },
+       { ControlMask|ShiftMask,XK_0,           heretag,        { .i = Tscratch } }, 
+       { ControlMask|ShiftMask,XK_1,           heretag,        { .i = Tdev } }, 
+       { ControlMask|ShiftMask,XK_2,           heretag,        { .i = Twww } }, 
+       { ControlMask|ShiftMask,XK_3,           heretag,        { .i = Twork } }, 
        { Mod1Mask|ShiftMask,   XK_0,           replacetag,             { .i = Tscratch } }, 
        { Mod1Mask|ShiftMask,   XK_1,           replacetag,             { .i = Tdev } }, 
        { Mod1Mask|ShiftMask,   XK_2,           replacetag,             { .i = Twww } }, 
diff --git a/tag.c b/tag.c
index 5da5711c2246539a8e8e3dbd8936705fe06d66ab..3837fbdbde6d293e000e93fbfe536317038820c1 100644 (file)
--- a/tag.c
+++ b/tag.c
@@ -49,7 +49,7 @@ dofloat(Arg *arg)
                        ban(c);
        }
        if(sel && !sel->tags[tsel]) {
-               if((sel = getnext(clients))) {
+               if((sel = getnext(clients, tsel))) {
                        higher(sel);
                        focus(sel);
                }
@@ -106,7 +106,7 @@ dotile(Arg *arg)
                        ban(c);
        }
        if(!sel || (sel && !sel->tags[tsel])) {
-               if((sel = getnext(clients))) {
+               if((sel = getnext(clients, tsel))) {
                        higher(sel);
                        focus(sel);
                }
@@ -115,12 +115,31 @@ dotile(Arg *arg)
 }
 
 Client *
-getnext(Client *c)
+getnext(Client *c, unsigned int t)
 {
-       for(; c && !c->tags[tsel]; c = c->next);
+       for(; c && !c->tags[t]; c = c->next);
        return c;
 }
 
+void
+heretag(Arg *arg)
+{
+       int i;
+       Client *c;
+
+       if(arg->i == tsel)
+               return;
+
+       if(!(c = getnext(clients, arg->i)))
+               return;
+
+       for(i = 0; i < TLast; i++)
+               c->tags[i] = NULL;
+       c->tags[tsel] = tags[tsel];
+       arrange(NULL);
+       focus(c);
+}
+
 void
 replacetag(Arg *arg)
 {