JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
added heretag command which allows to tag a client of a foreign tag with current tag
[dwm.git] / tag.c
diff --git a/tag.c b/tag.c
index 48f1f2a..3837fbd 100644 (file)
--- a/tag.c
+++ b/tag.c
@@ -7,24 +7,23 @@
 #include <string.h>
 #include <X11/Xutil.h>
 
-/********** CUSTOMIZE **********/
-
-char *tags[TLast] = {
-       [Tscratch] = "scratch",
-       [Tdev] = "dev",
-       [Twww] = "www",
-       [Twork] = "work",
-};
+/* static */
 
+/* CUSTOMIZE */ 
 static Rule rule[] = {
        /* class                        instance        tags                                            isfloat */
        { "Firefox-bin",        "Gecko",        { [Twww] = "www" },                     False },
 };
 
-/********** CUSTOMIZE **********/
-
-/* extern functions */
+/* extern */
 
+/* CUSTOMIZE */
+char *tags[TLast] = {
+       [Tscratch] = "scratch",
+       [Tdev] = "dev",
+       [Twww] = "www",
+       [Twork] = "work",
+};
 void (*arrange)(Arg *) = dotile;
 
 void
@@ -50,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);
                }
@@ -107,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);
                }
@@ -116,13 +115,32 @@ 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)
 {
        int i;