aewl
changeset 262:d659a2dce2b5
implemented viewextend and added M-S-C-n shortcuts for extending the current view... updated man page (works great!) nice feature
author | Anselm R.Garbe <arg@10ksloc.org> |
---|---|
date | Fri, 11 Aug 2006 19:26:12 +0200 (2006-08-11) |
parents | d6fd632d861c |
children | 118d3e010e5e |
files | config.arg.h config.default.h draw.c dwm.1 dwm.h event.c main.c tag.c |
diffstat | 8 files changed, 100 insertions(+), 68 deletions(-) [+] |
line diff
1.1 --- a/config.arg.h Fri Aug 11 18:37:41 2006 +0200 1.2 +++ b/config.arg.h Fri Aug 11 19:26:12 2006 +0200 1.3 @@ -18,31 +18,34 @@ 1.4 1.5 #define KEYS \ 1.6 static Key key[] = { \ 1.7 - /* modifier key function arguments */ \ 1.8 - { MODKEY, XK_1, view, { .i = 0 } }, \ 1.9 - { MODKEY, XK_2, view, { .i = 1 } }, \ 1.10 - { MODKEY, XK_3, view, { .i = 2 } }, \ 1.11 - { MODKEY, XK_h, viewprev, { 0 } }, \ 1.12 - { MODKEY, XK_j, focusnext, { 0 } }, \ 1.13 - { MODKEY, XK_k, focusprev, { 0 } }, \ 1.14 - { MODKEY, XK_l, viewnext, { 0 } }, \ 1.15 - { MODKEY, XK_m, togglemax, { 0 } }, \ 1.16 - { MODKEY, XK_p, spawn, \ 1.17 + /* modifier key function arguments */ \ 1.18 + { MODKEY, XK_1, view, { .i = 0 } }, \ 1.19 + { MODKEY, XK_2, view, { .i = 1 } }, \ 1.20 + { MODKEY, XK_3, view, { .i = 2 } }, \ 1.21 + { MODKEY, XK_h, viewprev, { 0 } }, \ 1.22 + { MODKEY, XK_j, focusnext, { 0 } }, \ 1.23 + { MODKEY, XK_k, focusprev, { 0 } }, \ 1.24 + { MODKEY, XK_l, viewnext, { 0 } }, \ 1.25 + { MODKEY, XK_m, togglemax, { 0 } }, \ 1.26 + { MODKEY, XK_p, spawn, \ 1.27 { .cmd = "exec `ls -lL /usr/bin /usr/local/bin 2>/dev/null | " \ 1.28 "awk 'NF>2 && $1 ~ /^[^d].*x/ {print $NF}' | sort | uniq | dmenu`" } }, \ 1.29 - { MODKEY, XK_space, togglemode, { 0 } }, \ 1.30 - { MODKEY, XK_Return, zoom, { 0 } }, \ 1.31 - { MODKEY|ControlMask, XK_1, appendtag, { .i = 0 } }, \ 1.32 - { MODKEY|ControlMask, XK_2, appendtag, { .i = 1 } }, \ 1.33 - { MODKEY|ControlMask, XK_3, appendtag, { .i = 2 } }, \ 1.34 - { MODKEY|ShiftMask, XK_1, replacetag, { .i = 0 } }, \ 1.35 - { MODKEY|ShiftMask, XK_2, replacetag, { .i = 1 } }, \ 1.36 - { MODKEY|ShiftMask, XK_3, replacetag, { .i = 2 } }, \ 1.37 - { MODKEY|ShiftMask, XK_c, killclient, { 0 } }, \ 1.38 - { MODKEY|ShiftMask, XK_q, quit, { 0 } }, \ 1.39 - { MODKEY|ShiftMask, XK_Return, spawn, \ 1.40 + { MODKEY, XK_space, togglemode, { 0 } }, \ 1.41 + { MODKEY, XK_Return, zoom, { 0 } }, \ 1.42 + { MODKEY|ControlMask, XK_1, appendtag, { .i = 0 } }, \ 1.43 + { MODKEY|ControlMask, XK_2, appendtag, { .i = 1 } }, \ 1.44 + { MODKEY|ControlMask, XK_3, appendtag, { .i = 2 } }, \ 1.45 + { MODKEY|ShiftMask, XK_1, replacetag, { .i = 0 } }, \ 1.46 + { MODKEY|ShiftMask, XK_2, replacetag, { .i = 1 } }, \ 1.47 + { MODKEY|ShiftMask, XK_3, replacetag, { .i = 2 } }, \ 1.48 + { MODKEY|ShiftMask, XK_c, killclient, { 0 } }, \ 1.49 + { MODKEY|ShiftMask, XK_q, quit, { 0 } }, \ 1.50 + { MODKEY|ShiftMask, XK_Return, spawn, \ 1.51 { .cmd = "exec urxvt +sb -tr -bg black -fg '#eeeeee' -cr '#eeeeee' +sb " \ 1.52 "-fn '-*-terminus-medium-*-*-*-12-*-*-*-*-*-iso10646-*'" } }, \ 1.53 + { MODKEY|ControlMask|ShiftMask, XK_1, viewextend, { .i = 0 } }, \ 1.54 + { MODKEY|ShiftMask, XK_2, viewextend, { .i = 1 } }, \ 1.55 + { MODKEY|ShiftMask, XK_3, viewextend, { .i = 2 } }, \ 1.56 }; 1.57 1.58 #define RULES \
2.1 --- a/config.default.h Fri Aug 11 18:37:41 2006 +0200 2.2 +++ b/config.default.h Fri Aug 11 19:26:12 2006 +0200 2.3 @@ -18,32 +18,37 @@ 2.4 2.5 #define KEYS \ 2.6 static Key key[] = { \ 2.7 - /* modifier key function arguments */ \ 2.8 - { MODKEY, XK_0, view, { .i = 0 } }, \ 2.9 - { MODKEY, XK_1, view, { .i = 1 } }, \ 2.10 - { MODKEY, XK_2, view, { .i = 2 } }, \ 2.11 - { MODKEY, XK_3, view, { .i = 3 } }, \ 2.12 - { MODKEY, XK_4, view, { .i = 4 } }, \ 2.13 - { MODKEY, XK_h, viewprev, { 0 } }, \ 2.14 - { MODKEY, XK_j, focusnext, { 0 } }, \ 2.15 - { MODKEY, XK_k, focusprev, { 0 } }, \ 2.16 - { MODKEY, XK_l, viewnext, { 0 } }, \ 2.17 - { MODKEY, XK_m, togglemax, { 0 } }, \ 2.18 - { MODKEY, XK_space, togglemode, { 0 } }, \ 2.19 - { MODKEY, XK_Return, zoom, { 0 } }, \ 2.20 - { MODKEY|ControlMask, XK_0, appendtag, { .i = 0 } }, \ 2.21 - { MODKEY|ControlMask, XK_1, appendtag, { .i = 1 } }, \ 2.22 - { MODKEY|ControlMask, XK_2, appendtag, { .i = 2 } }, \ 2.23 - { MODKEY|ControlMask, XK_3, appendtag, { .i = 3 } }, \ 2.24 - { MODKEY|ControlMask, XK_4, appendtag, { .i = 4 } }, \ 2.25 - { MODKEY|ShiftMask, XK_0, replacetag, { .i = 0 } }, \ 2.26 - { MODKEY|ShiftMask, XK_1, replacetag, { .i = 1 } }, \ 2.27 - { MODKEY|ShiftMask, XK_2, replacetag, { .i = 2 } }, \ 2.28 - { MODKEY|ShiftMask, XK_3, replacetag, { .i = 3 } }, \ 2.29 - { MODKEY|ShiftMask, XK_4, replacetag, { .i = 4 } }, \ 2.30 - { MODKEY|ShiftMask, XK_c, killclient, { 0 } }, \ 2.31 - { MODKEY|ShiftMask, XK_q, quit, { 0 } }, \ 2.32 - { MODKEY|ShiftMask, XK_Return, spawn, { .cmd = "exec xterm" } }, \ 2.33 + /* modifier key function arguments */ \ 2.34 + { MODKEY, XK_0, view, { .i = 0 } }, \ 2.35 + { MODKEY, XK_1, view, { .i = 1 } }, \ 2.36 + { MODKEY, XK_2, view, { .i = 2 } }, \ 2.37 + { MODKEY, XK_3, view, { .i = 3 } }, \ 2.38 + { MODKEY, XK_4, view, { .i = 4 } }, \ 2.39 + { MODKEY, XK_h, viewprev, { 0 } }, \ 2.40 + { MODKEY, XK_j, focusnext, { 0 } }, \ 2.41 + { MODKEY, XK_k, focusprev, { 0 } }, \ 2.42 + { MODKEY, XK_l, viewnext, { 0 } }, \ 2.43 + { MODKEY, XK_m, togglemax, { 0 } }, \ 2.44 + { MODKEY, XK_space, togglemode, { 0 } }, \ 2.45 + { MODKEY, XK_Return, zoom, { 0 } }, \ 2.46 + { MODKEY|ControlMask, XK_0, appendtag, { .i = 0 } }, \ 2.47 + { MODKEY|ControlMask, XK_1, appendtag, { .i = 1 } }, \ 2.48 + { MODKEY|ControlMask, XK_2, appendtag, { .i = 2 } }, \ 2.49 + { MODKEY|ControlMask, XK_3, appendtag, { .i = 3 } }, \ 2.50 + { MODKEY|ControlMask, XK_4, appendtag, { .i = 4 } }, \ 2.51 + { MODKEY|ShiftMask, XK_0, replacetag, { .i = 0 } }, \ 2.52 + { MODKEY|ShiftMask, XK_1, replacetag, { .i = 1 } }, \ 2.53 + { MODKEY|ShiftMask, XK_2, replacetag, { .i = 2 } }, \ 2.54 + { MODKEY|ShiftMask, XK_3, replacetag, { .i = 3 } }, \ 2.55 + { MODKEY|ShiftMask, XK_4, replacetag, { .i = 4 } }, \ 2.56 + { MODKEY|ShiftMask, XK_c, killclient, { 0 } }, \ 2.57 + { MODKEY|ShiftMask, XK_q, quit, { 0 } }, \ 2.58 + { MODKEY|ShiftMask, XK_Return, spawn, { .cmd = "exec xterm" } }, \ 2.59 + { MODKEY|ControlMask|ShiftMask, XK_0, viewextend, { .i = 0 } }, \ 2.60 + { MODKEY|ControlMask|ShiftMask, XK_1, viewextend, { .i = 1 } }, \ 2.61 + { MODKEY|ControlMask|ShiftMask, XK_2, viewextend, { .i = 2 } }, \ 2.62 + { MODKEY|ControlMask|ShiftMask, XK_3, viewextend, { .i = 3 } }, \ 2.63 + { MODKEY|ControlMask|ShiftMask, XK_4, viewextend, { .i = 4 } }, \ 2.64 }; 2.65 2.66 #define RULES \
3.1 --- a/draw.c Fri Aug 11 18:37:41 2006 +0200 3.2 +++ b/draw.c Fri Aug 11 19:26:12 2006 +0200 3.3 @@ -109,9 +109,9 @@ 3.4 dc.x += dc.w; 3.5 dc.w = textw(tags[i]); 3.6 if(istile) 3.7 - drawtext(tags[i], tsel[i]); 3.8 + drawtext(tags[i], seltag[i]); 3.9 else 3.10 - drawtext(tags[i], !tsel[i]); 3.11 + drawtext(tags[i], !seltag[i]); 3.12 } 3.13 x = dc.x + dc.w; 3.14 dc.w = textw(stext);
4.1 --- a/dwm.1 Fri Aug 11 18:37:41 2006 +0200 4.2 +++ b/dwm.1 Fri Aug 11 19:26:12 2006 +0200 4.3 @@ -36,14 +36,21 @@ 4.4 .B Standard input 4.5 is read and displayed in the status text area. 4.6 .TP 4.7 -.B Button[1-3] 4.8 -click on a tag label focuses that tag. 4.9 +.B Button[1,3] 4.10 +click on a tag label focuses that 4.11 +.B tag. 4.12 +.TP 4.13 +.B Button2 4.14 +click on a tag label (un)extends the current 4.15 +.B tag. 4.16 .TP 4.17 .B Button[1,4] 4.18 -click on the bar focuses the previous tag. 4.19 +click on the bar focuses the previous 4.20 +.B tag. 4.21 .TP 4.22 .B Button[2,5] 4.23 -click on the bar focuses the next tag. 4.24 +click on the bar focuses the next 4.25 +.B tag. 4.26 .SS Keyboard commands 4.27 .TP 4.28 .B Mod1-Return 4.29 @@ -108,6 +115,12 @@ 4.30 .B nth tag 4.31 to current 4.32 .B window. 4.33 +.TP 4.34 +.B Mod1-Control-Shift-[0..n] 4.35 +(Un)extends 4.36 +.B nth tag 4.37 +with current 4.38 +.B tag. 4.39 .SS Mouse commands 4.40 .TP 4.41 .B Mod1-Button1
5.1 --- a/dwm.h Fri Aug 11 18:37:41 2006 +0200 5.2 +++ b/dwm.h Fri Aug 11 19:26:12 2006 +0200 5.3 @@ -74,7 +74,7 @@ 5.4 extern void (*handler[LASTEvent])(XEvent *); 5.5 extern void (*arrange)(Arg *); 5.6 extern Atom wmatom[WMLast], netatom[NetLast]; 5.7 -extern Bool running, issel, *tsel; 5.8 +extern Bool running, issel, *seltag; 5.9 extern Client *clients, *sel; 5.10 extern Cursor cursor[CurLast]; 5.11 extern DC dc; 5.12 @@ -128,6 +128,7 @@ 5.13 extern void settags(Client *c); 5.14 extern void togglemode(Arg *arg); 5.15 extern void view(Arg *arg); 5.16 +extern void viewextend(Arg *arg); 5.17 extern void viewnext(Arg *arg); 5.18 extern void viewprev(Arg *arg); 5.19
6.1 --- a/event.c Fri Aug 11 18:37:41 2006 +0200 6.2 +++ b/event.c Fri Aug 11 19:26:12 2006 +0200 6.3 @@ -108,11 +108,8 @@ 6.4 for(a.i = 0; a.i < ntags; a.i++) { 6.5 x += textw(tags[a.i]); 6.6 if(ev->x < x) { 6.7 - if(ev->button == Button3) { 6.8 - tsel[a.i] = True; 6.9 - arrange(NULL); 6.10 - drawall(); 6.11 - } 6.12 + if(ev->button == Button3) 6.13 + viewextend(&a); 6.14 else 6.15 view(&a); 6.16 return;
7.1 --- a/main.c Fri Aug 11 18:37:41 2006 +0200 7.2 +++ b/main.c Fri Aug 11 19:26:12 2006 +0200 7.3 @@ -83,7 +83,7 @@ 7.4 /* extern */ 7.5 7.6 char stext[1024]; 7.7 -Bool *tsel; 7.8 +Bool *seltag; 7.9 int screen, sx, sy, sw, sh, bx, by, bw, bh, mw; 7.10 unsigned int ntags; 7.11 Atom wmatom[WMLast], netatom[NetLast]; 7.12 @@ -213,8 +213,8 @@ 7.13 initrregs(); 7.14 7.15 for(ntags = 0; tags[ntags]; ntags++); 7.16 - tsel = emallocz(sizeof(Bool) * ntags); 7.17 - tsel[DEFTAG] = True; 7.18 + seltag = emallocz(sizeof(Bool) * ntags); 7.19 + seltag[DEFTAG] = True; 7.20 7.21 /* style */ 7.22 dc.bg = getcolor(BGCOLOR);
8.1 --- a/tag.c Fri Aug 11 18:37:41 2006 +0200 8.2 +++ b/tag.c Fri Aug 11 19:26:12 2006 +0200 8.3 @@ -181,7 +181,7 @@ 8.4 unsigned int i; 8.5 8.6 for(i = 0; i < ntags; i++) 8.7 - if(c->tags[i] && tsel[i]) 8.8 + if(c->tags[i] && seltag[i]) 8.9 return True; 8.10 return False; 8.11 } 8.12 @@ -229,7 +229,7 @@ 8.13 } 8.14 if(!matched) 8.15 for(i = 0; i < ntags; i++) 8.16 - c->tags[i] = tsel[i]; 8.17 + c->tags[i] = seltag[i]; 8.18 } 8.19 8.20 void 8.21 @@ -245,8 +245,21 @@ 8.22 unsigned int i; 8.23 8.24 for(i = 0; i < ntags; i++) 8.25 - tsel[i] = False; 8.26 - tsel[arg->i] = True; 8.27 + seltag[i] = False; 8.28 + seltag[arg->i] = True; 8.29 + arrange(NULL); 8.30 + drawall(); 8.31 +} 8.32 + 8.33 +void 8.34 +viewextend(Arg *arg) 8.35 +{ 8.36 + unsigned int i; 8.37 + 8.38 + seltag[arg->i] = !seltag[arg->i]; 8.39 + for(i = 0; !seltag[i] && i < ntags; i++); 8.40 + if(i == ntags) 8.41 + seltag[arg->i] = True; /* cannot toggle last view */ 8.42 arrange(NULL); 8.43 drawall(); 8.44 } 8.45 @@ -256,7 +269,7 @@ 8.46 { 8.47 unsigned int i; 8.48 8.49 - for(i = 0; !tsel[i]; i++); 8.50 + for(i = 0; !seltag[i]; i++); 8.51 arg->i = (i < ntags-1) ? i+1 : 0; 8.52 view(arg); 8.53 } 8.54 @@ -266,7 +279,7 @@ 8.55 { 8.56 unsigned int i; 8.57 8.58 - for(i = 0; !tsel[i]; i++); 8.59 + for(i = 0; !seltag[i]; i++); 8.60 arg->i = (i > 0) ? i-1 : ntags-1; 8.61 view(arg); 8.62 }