aewl
changeset 9:d567f430a81d
fixed several stuff (gridwm gets better and better)
author | Anselm R. Garbe <garbeam@wmii.de> |
---|---|
date | Tue, 11 Jul 2006 12:52:57 +0200 (2006-07-11) |
parents | 7066ff2fe8bc |
children | 703255003abb |
files | README client.c config.h event.c font.c key.c menu.c util.c wm.c wm.h |
diffstat | 10 files changed, 59 insertions(+), 141 deletions(-) [+] |
line diff
1.1 --- a/README Tue Jul 11 11:50:18 2006 +0200 1.2 +++ b/README Tue Jul 11 12:52:57 2006 +0200 1.3 @@ -2,6 +2,7 @@ 1.4 ------ 1.5 1.6 gridwm is an automatic X11 window manager which arranges all windows in a grid. 1.7 +One goal is not to exceed 3kSLOC. 1.8 1.9 1.10 Requirements
2.1 --- a/client.c Tue Jul 11 11:50:18 2006 +0200 2.2 +++ b/client.c Tue Jul 11 12:52:57 2006 +0200 2.3 @@ -51,7 +51,6 @@ 2.4 c->r[RFloat].height = wa->height; 2.5 c->border = wa->border_width; 2.6 XSetWindowBorderWidth(dpy, c->win, 0); 2.7 - c->proto = win_proto(c->win); 2.8 XGetTransientForHint(dpy, c->win, &c->trans); 2.9 if(!XGetWMNormalHints(dpy, c->win, &c->size, &msize) || !c->size.flags) 2.10 c->size.flags = PSize; 2.11 @@ -59,7 +58,6 @@ 2.12 (c->size.flags & PMinSize && c->size.flags & PMaxSize 2.13 && c->size.min_width == c->size.max_width 2.14 && c->size.min_height == c->size.max_height); 2.15 - XAddToSaveSet(dpy, c->win); 2.16 update_client_name(c); 2.17 twa.override_redirect = 1; 2.18 twa.background_pixmap = ParentRelative; 2.19 @@ -87,3 +85,13 @@ 2.20 XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); 2.21 XFlush(dpy); 2.22 } 2.23 + 2.24 +Client * 2.25 +getclient(Window w) 2.26 +{ 2.27 + Client *c; 2.28 + for(c = clients; c; c = c->next) 2.29 + if(c->win == w) 2.30 + return c; 2.31 + return NULL; 2.32 +}
3.1 --- a/config.h Tue Jul 11 11:50:18 2006 +0200 3.2 +++ b/config.h Tue Jul 11 12:52:57 2006 +0200 3.3 @@ -10,4 +10,6 @@ 3.4 #define STATUSCMD "echo -n `date` `uptime | sed 's/.*://; s/,//g'`" \ 3.5 " `acpi | awk '{print $4}' | sed 's/,//'`" 3.6 #define KEYS \ 3.7 - { Mod1Mask, XK_Return, run, "xterm -u8 -bg black -fg white -fn -*-terminus-medium-*-*-*-14-*-*-*-*-*-iso10646-*" }, 3.8 + { Mod1Mask, XK_Return, run, "xterm -u8 -bg black -fg white -fn '-*-terminus-medium-*-*-*-14-*-*-*-*-*-iso10646-*'" }, \ 3.9 + { Mod1Mask | ShiftMask, XK_q, quit, NULL}, 3.10 +
4.1 --- a/event.c Tue Jul 11 11:50:18 2006 +0200 4.2 +++ b/event.c Tue Jul 11 12:52:57 2006 +0200 4.3 @@ -16,7 +16,6 @@ 4.4 static void enternotify(XEvent *e); 4.5 static void leavenotify(XEvent *e); 4.6 static void expose(XEvent *e); 4.7 -static void keypress(XEvent *e); 4.8 static void keymapnotify(XEvent *e); 4.9 static void maprequest(XEvent *e); 4.10 static void propertynotify(XEvent *e); 4.11 @@ -47,80 +46,36 @@ 4.12 static void 4.13 configurerequest(XEvent *e) 4.14 { 4.15 -#if 0 4.16 XConfigureRequestEvent *ev = &e->xconfigurerequest; 4.17 XWindowChanges wc; 4.18 - XRectangle *frect; 4.19 Client *c; 4.20 4.21 - c = client_of_win(ev->window); 4.22 + c = getclient(ev->window); 4.23 ev->value_mask &= ~CWSibling; 4.24 if(c) { 4.25 - gravitate_client(c, True); 4.26 - 4.27 if(ev->value_mask & CWX) 4.28 - c->rect.x = ev->x; 4.29 + c->r[RFloat].x = ev->x; 4.30 if(ev->value_mask & CWY) 4.31 - c->rect.y = ev->y; 4.32 + c->r[RFloat].y = ev->y; 4.33 if(ev->value_mask & CWWidth) 4.34 - c->rect.width = ev->width; 4.35 + c->r[RFloat].width = ev->width; 4.36 if(ev->value_mask & CWHeight) 4.37 - c->rect.height = ev->height; 4.38 + c->r[RFloat].height = ev->height; 4.39 if(ev->value_mask & CWBorderWidth) 4.40 c->border = ev->border_width; 4.41 - 4.42 - gravitate_client(c, False); 4.43 - 4.44 - if(c->frame) { 4.45 - if(c->sel->area->floating) 4.46 - frect=&c->sel->rect; 4.47 - else 4.48 - frect=&c->sel->revert; 4.49 - 4.50 - if(c->rect.width >= screen->rect.width && c->rect.height >= screen->rect.height) { 4.51 - frect->y = wc.y = -height_of_bar(); 4.52 - frect->x = wc.x = -def.border; 4.53 - } 4.54 - else { 4.55 - frect->y = wc.y = c->rect.y - height_of_bar(); 4.56 - frect->x = wc.x = c->rect.x - def.border; 4.57 - } 4.58 - frect->width = wc.width = c->rect.width + 2 * def.border; 4.59 - frect->height = wc.height = c->rect.height + def.border 4.60 - + height_of_bar(); 4.61 - wc.border_width = 1; 4.62 - wc.sibling = None; 4.63 - wc.stack_mode = ev->detail; 4.64 - if(c->sel->area->view != screen->sel) 4.65 - wc.x += 2 * screen->rect.width; 4.66 - if(c->sel->area->floating) { 4.67 - XConfigureWindow(dpy, c->framewin, ev->value_mask, &wc); 4.68 - configure_client(c); 4.69 - } 4.70 - } 4.71 } 4.72 4.73 wc.x = ev->x; 4.74 wc.y = ev->y; 4.75 wc.width = ev->width; 4.76 wc.height = ev->height; 4.77 - 4.78 - if(c && c->frame) { 4.79 - wc.x = def.border; 4.80 - wc.y = height_of_bar(); 4.81 - wc.width = c->sel->rect.width - 2 * def.border; 4.82 - wc.height = c->sel->rect.height - def.border - height_of_bar(); 4.83 - } 4.84 - 4.85 wc.border_width = 0; 4.86 wc.sibling = None; 4.87 wc.stack_mode = Above; 4.88 ev->value_mask &= ~CWStackMode; 4.89 ev->value_mask |= CWBorderWidth; 4.90 XConfigureWindow(dpy, ev->window, ev->value_mask, &wc); 4.91 - 4.92 XFlush(dpy); 4.93 -#endif 4.94 } 4.95 4.96 static void 4.97 @@ -182,32 +137,6 @@ 4.98 } 4.99 4.100 static void 4.101 -keypress(XEvent *e) 4.102 -{ 4.103 -#if 0 4.104 - XKeyEvent *ev = &e->xkey; 4.105 - KeySym k = 0; 4.106 - char buf[32]; 4.107 - int n; 4.108 - static Frame *f; 4.109 - 4.110 - 4.111 - ev->state &= valid_mask; 4.112 - if((f = frame_of_win(ev->window))) { 4.113 - buf[0] = 0; 4.114 - n = XLookupString(ev, buf, sizeof(buf), &k, 0); 4.115 - if(IsFunctionKey(k) || IsKeypadKey(k) || IsMiscFunctionKey(k) 4.116 - || IsPFKey(k) || IsPrivateKeypadKey(k)) 4.117 - return; 4.118 - buf[n] = 0; 4.119 - blitz_kpress_input(&f->tagbar, ev->state, k, buf); 4.120 - } 4.121 - else 4.122 - key(root, ev->state, (KeyCode) ev->keycode); 4.123 -#endif 4.124 -} 4.125 - 4.126 -static void 4.127 keymapnotify(XEvent *e) 4.128 { 4.129 #if 0 4.130 @@ -231,7 +160,11 @@ 4.131 } 4.132 4.133 /*if(!client_of_win(ev->window))*/ 4.134 - manage(create_client(ev->window, &wa)); 4.135 + /*manage(create_client(ev->window, &wa));*/ 4.136 + XMapRaised(dpy, ev->window); 4.137 + XMoveResizeWindow(dpy, ev->window, rect.x, rect.y, rect.width, rect.height - barrect.height); 4.138 + XSetInputFocus(dpy, ev->window, RevertToPointerRoot, CurrentTime); 4.139 + XFlush(dpy); 4.140 } 4.141 4.142 static void
5.1 --- a/font.c Tue Jul 11 11:50:18 2006 +0200 5.2 +++ b/font.c Tue Jul 11 12:52:57 2006 +0200 5.3 @@ -38,7 +38,7 @@ 5.4 font->set = XCreateFontSet(blitz->dpy, fontname, &missing, &n, &def); 5.5 if(missing) { 5.6 while(n--) 5.7 - fprintf(stderr, "liblitz: missing fontset: %s\n", missing[n]); 5.8 + fprintf(stderr, "missing fontset: %s\n", missing[n]); 5.9 XFreeStringList(missing); 5.10 if(font->set) { 5.11 XFreeFontSet(blitz->dpy, font->set); 5.12 @@ -72,7 +72,7 @@ 5.13 font->xfont = XLoadQueryFont(blitz->dpy, fontname); 5.14 } 5.15 if (!font->xfont) { 5.16 - fprintf(stderr, "%s", "liblitz: error, cannot load 'fixed' font\n"); 5.17 + fprintf(stderr, "%s", "error, cannot load 'fixed' font\n"); 5.18 exit(1); 5.19 } 5.20 font->ascent = font->xfont->ascent;
6.1 --- a/key.c Tue Jul 11 11:50:18 2006 +0200 6.2 +++ b/key.c Tue Jul 11 12:52:57 2006 +0200 6.3 @@ -24,3 +24,20 @@ 6.4 XGrabKey(dpy, code, key[i].mod, root, True, GrabModeAsync, GrabModeAsync); 6.5 } 6.6 } 6.7 + 6.8 +void 6.9 +keypress(XEvent *e) 6.10 +{ 6.11 + XKeyEvent *ev = &e->xkey; 6.12 + unsigned int i, len; 6.13 + KeySym keysym; 6.14 + 6.15 + keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0); 6.16 + len = sizeof(key) / sizeof(key[0]); 6.17 + for(i = 0; i < len; i++) 6.18 + if((keysym == key[i].keysym) && (key[i].mod == ev->state)) { 6.19 + if(key[i].func) 6.20 + key[i].func(key[i].arg); 6.21 + return; 6.22 + } 6.23 +}
7.1 --- a/menu.c Tue Jul 11 11:50:18 2006 +0200 7.2 +++ b/menu.c Tue Jul 11 12:52:57 2006 +0200 7.3 @@ -358,8 +358,6 @@ 7.4 7.5 char buf[256]; 7.6 7.7 - fputs(STATUSCMD, stdout); 7.8 - fputs("\n", stdout); 7.9 pipe_spawn(buf, sizeof(buf), NULL, STATUSCMD); 7.10 fputs(buf, stderr); 7.11
8.1 --- a/util.c Tue Jul 11 11:50:18 2006 +0200 8.2 +++ b/util.c Tue Jul 11 12:52:57 2006 +0200 8.3 @@ -93,11 +93,12 @@ 8.4 return; 8.5 if(fork() == 0) { 8.6 if(fork() == 0) { 8.7 - setsid(); 8.8 if(dpy) 8.9 close(ConnectionNumber(dpy)); 8.10 - execlp(shell, "shell", "-c", cmd, NULL); 8.11 - fprintf(stderr, "gridwm: execvp %s", cmd); 8.12 + setsid(); 8.13 + fprintf(stderr, "gridwm: execlp %s %s -c %s", shell, shell, cmd); 8.14 + execlp(shell, shell, "-c", cmd, NULL); 8.15 + fprintf(stderr, "gridwm: execlp %s", cmd); 8.16 perror(" failed"); 8.17 } 8.18 exit (0); 8.19 @@ -123,14 +124,14 @@ 8.20 } 8.21 8.22 if(fork() == 0) { 8.23 - setsid(); 8.24 if(dpy) 8.25 close(ConnectionNumber(dpy)); 8.26 + setsid(); 8.27 dup2(pfd[1], STDOUT_FILENO); 8.28 close(pfd[0]); 8.29 close(pfd[1]); 8.30 - execlp(shell, "shell", "-c", cmd, NULL); 8.31 - fprintf(stderr, "gridwm: execvp %s", cmd); 8.32 + execlp(shell, shell, "-c", cmd, NULL); 8.33 + fprintf(stderr, "gridwm: execlp %s", cmd); 8.34 perror(" failed"); 8.35 } 8.36 else {
9.1 --- a/wm.c Tue Jul 11 11:50:18 2006 +0200 9.2 +++ b/wm.c Tue Jul 11 12:52:57 2006 +0200 9.3 @@ -16,11 +16,11 @@ 9.4 /* X structs */ 9.5 Display *dpy; 9.6 Window root, barwin; 9.7 -Atom wm_atom[WMLast], net_atom[NetLast]; 9.8 +Atom net_atom[NetLast]; 9.9 Cursor cursor[CurLast]; 9.10 XRectangle rect, barrect; 9.11 Bool running = True; 9.12 -Client *client = NULL; 9.13 +Client *clients = NULL; 9.14 9.15 char *bartext, tag[256]; 9.16 int screen, sel_screen; 9.17 @@ -63,46 +63,6 @@ 9.18 XFree(wins); 9.19 } 9.20 9.21 -static int 9.22 -win_property(Window w, Atom a, Atom t, long l, unsigned char **prop) 9.23 -{ 9.24 - Atom real; 9.25 - int format; 9.26 - unsigned long res, extra; 9.27 - int status; 9.28 - 9.29 - status = XGetWindowProperty(dpy, w, a, 0L, l, False, t, &real, &format, 9.30 - &res, &extra, prop); 9.31 - 9.32 - if(status != Success || *prop == NULL) { 9.33 - return 0; 9.34 - } 9.35 - if(res == 0) 9.36 - free((void *) *prop); 9.37 - return res; 9.38 -} 9.39 - 9.40 -int 9.41 -win_proto(Window w) 9.42 -{ 9.43 - Atom *protocols; 9.44 - long res; 9.45 - int protos = 0; 9.46 - int i; 9.47 - 9.48 - res = win_property(w, wm_atom[WMProtocols], XA_ATOM, 20L, 9.49 - ((unsigned char **) &protocols)); 9.50 - if(res <= 0) { 9.51 - return protos; 9.52 - } 9.53 - for(i = 0; i < res; i++) { 9.54 - if(protocols[i] == wm_atom[WMDelete]) 9.55 - protos |= WM_PROTOCOL_DELWIN; 9.56 - } 9.57 - free((char *) protocols); 9.58 - return protos; 9.59 -} 9.60 - 9.61 /* 9.62 * There's no way to check accesses to destroyed windows, thus 9.63 * those cases are ignored (especially on UnmapNotify's). 9.64 @@ -201,9 +161,6 @@ 9.65 x_error_handler = XSetErrorHandler(error_handler); 9.66 9.67 /* init atoms */ 9.68 - wm_atom[WMState] = XInternAtom(dpy, "WM_STATE", False); 9.69 - wm_atom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False); 9.70 - wm_atom[WMDelete] = XInternAtom(dpy, "WM_DELETE_WINDOW", False); 9.71 net_atom[NetSupported] = XInternAtom(dpy, "_NET_SUPPORTED", False); 9.72 net_atom[NetWMName] = XInternAtom(dpy, "_NET_WM_NAME", False); 9.73 9.74 @@ -242,7 +199,8 @@ 9.75 XMapRaised(dpy, barwin); 9.76 draw_bar(); 9.77 9.78 - wa.event_mask = SubstructureRedirectMask | EnterWindowMask | LeaveWindowMask; 9.79 + wa.event_mask = SubstructureRedirectMask | EnterWindowMask \ 9.80 + | LeaveWindowMask; 9.81 wa.cursor = cursor[CurNormal]; 9.82 XChangeWindowAttributes(dpy, root, CWEventMask | CWCursor, &wa); 9.83
10.1 --- a/wm.h Tue Jul 11 11:50:18 2006 +0200 10.2 +++ b/wm.h Tue Jul 11 12:52:57 2006 +0200 10.3 @@ -10,7 +10,6 @@ 10.4 #include <X11/Xutil.h> 10.5 10.6 /* atoms */ 10.7 -enum { WMState, WMProtocols, WMDelete, WMLast }; 10.8 enum { NetSupported, NetWMName, NetLast }; 10.9 10.10 /* cursor */ 10.11 @@ -25,7 +24,6 @@ 10.12 struct Client { 10.13 char name[256]; 10.14 char tag[256]; 10.15 - int proto; 10.16 unsigned int border; 10.17 Bool fixedsize; 10.18 Window win; 10.19 @@ -46,7 +44,7 @@ 10.20 10.21 extern Display *dpy; 10.22 extern Window root, barwin; 10.23 -extern Atom wm_atom[WMLast], net_atom[NetLast]; 10.24 +extern Atom net_atom[NetLast]; 10.25 extern Cursor cursor[CurLast]; 10.26 extern XRectangle rect, barrect; 10.27 extern Bool running; 10.28 @@ -57,20 +55,22 @@ 10.29 extern char *bartext, tag[256]; 10.30 10.31 extern Brush brush; 10.32 -extern Client *client; 10.33 +extern Client *clients; 10.34 10.35 /* bar.c */ 10.36 extern void draw_bar(); 10.37 10.38 /* cmd.c */ 10.39 extern void run(char *arg); 10.40 +extern void quit(char *arg); 10.41 10.42 /* client.c */ 10.43 extern Client *create_client(Window w, XWindowAttributes *wa); 10.44 extern void manage(Client *c); 10.45 +extern Client * getclient(Window w); 10.46 10.47 /* key.c */ 10.48 extern void update_keys(); 10.49 +extern void keypress(XEvent *e); 10.50 10.51 /* wm.c */ 10.52 -extern int win_proto(Window w);