aboutsummaryrefslogtreecommitdiff
path: root/tag.c
diff options
context:
space:
mode:
authorAnselm R. Garbe <garbeam@gmail.com>2007-08-16 17:55:55 +0200
committerAnselm R. Garbe <garbeam@gmail.com>2007-08-16 17:55:55 +0200
commit10bc0ce912eb99fec49d954c80d92e04429ed0ee (patch)
tree524951e34fcd67e59b672c4ae203b71f94a214b3 /tag.c
parente8792d95a12c85f9e660e192cd2c6260a01a3c5e (diff)
downloaddwm-10bc0ce912eb99fec49d954c80d92e04429ed0ee.tar.gz
dwm-10bc0ce912eb99fec49d954c80d92e04429ed0ee.tar.bz2
dwm-10bc0ce912eb99fec49d954c80d92e04429ed0ee.zip
made tag/view/toggle{tag,view} work on pointer to tags-array, there was the need to define Key key[] not static to do this. split focusclient into focusnext/prev, fixed config.*.h's
Diffstat (limited to 'tag.c')
-rw-r--r--tag.c26
1 files changed, 18 insertions, 8 deletions
diff --git a/tag.c b/tag.c
index 4aeadc2..cf983b8 100644
--- a/tag.c
+++ b/tag.c
@@ -40,6 +40,16 @@ persistconfig(Client *c) {
PropModeReplace, (unsigned char *)prop, i);
}
+static unsigned int
+idxoftag(const char *tag) {
+ unsigned int i;
+
+ for(i = 0; i < ntags; i++)
+ if(tags[i] == tag)
+ return i;
+ return 0;
+}
+
/* extern */
void
@@ -135,13 +145,13 @@ settags(Client *c, Client *trans) {
void
tag(const char *arg) {
- int i;
+ unsigned int i;
if(!sel)
return;
for(i = 0; i < ntags; i++)
sel->tags[i] = arg == NULL;
- i = arg ? atoi(arg) : 0;
+ i = idxoftag(arg);
if(i >= 0 && i < ntags)
sel->tags[i] = True;
persistconfig(sel);
@@ -162,11 +172,11 @@ togglefloating(const char *arg) {
void
toggletag(const char *arg) {
- int i, j;
+ unsigned int i, j;
if(!sel)
return;
- i = arg ? atoi(arg) : 0;
+ i = idxoftag(arg);
sel->tags[i] = !sel->tags[i];
for(j = 0; j < ntags && !sel->tags[j]; j++);
if(j == ntags)
@@ -177,9 +187,9 @@ toggletag(const char *arg) {
void
toggleview(const char *arg) {
- int i, j;
+ unsigned int i, j;
- i = arg ? atoi(arg) : 0;
+ i = idxoftag(arg);
seltag[i] = !seltag[i];
for(j = 0; j < ntags && !seltag[j]; j++);
if(j == ntags)
@@ -189,11 +199,11 @@ toggleview(const char *arg) {
void
view(const char *arg) {
- int i;
+ unsigned int i;
for(i = 0; i < ntags; i++)
seltag[i] = arg == NULL;
- i = arg ? atoi(arg) : 0;
+ i = idxoftag(arg);
if(i >= 0 && i < ntags)
seltag[i] = True;
arrange();