aewl

changeset 43:989178822938

changed default colors
author Anselm R. Garbe <garbeam@wmii.de>
date Thu, 13 Jul 2006 11:43:05 +0200 (2006-07-13)
parents 040a7074d23c
children a36f95a4841a
files Makefile client.c dev.c draw.c dwm.h event.c main.c util.c
diffstat 10 files changed, 465 insertions(+), 476 deletions(-) [+]
line diff
     1.1 --- a/Makefile	Thu Jul 13 10:34:55 2006 +0200
     1.2 +++ b/Makefile	Thu Jul 13 11:43:05 2006 +0200
     1.3 @@ -3,7 +3,7 @@
     1.4  
     1.5  include config.mk
     1.6  
     1.7 -SRC = client.c dev.c draw.c event.c util.c wm.c
     1.8 +SRC = client.c dev.c draw.c event.c main.c util.c
     1.9  OBJ = ${SRC:.c=.o}
    1.10  MAN1 = dwm.1 
    1.11  BIN = dwm
    1.12 @@ -22,7 +22,7 @@
    1.13  	@echo CC $<
    1.14  	@${CC} -c ${CFLAGS} $<
    1.15  
    1.16 -${OBJ}: wm.h
    1.17 +${OBJ}: dwm.h
    1.18  
    1.19  dwm: ${OBJ}
    1.20  	@echo LD $@
     2.1 --- a/client.c	Thu Jul 13 10:34:55 2006 +0200
     2.2 +++ b/client.c	Thu Jul 13 11:43:05 2006 +0200
     2.3 @@ -9,7 +9,7 @@
     2.4  #include <X11/Xatom.h>
     2.5  #include <X11/Xutil.h>
     2.6  
     2.7 -#include "wm.h"
     2.8 +#include "dwm.h"
     2.9  
    2.10  static void floating(void);
    2.11  static void tiling(void);
    2.12 @@ -125,8 +125,8 @@
    2.13  	c->tw = 0;
    2.14  	for(i = 0; i < TLast; i++)
    2.15  		if(c->tags[i])
    2.16 -			c->tw += textw(&dc.font, c->tags[i]) + dc.font.height;
    2.17 -	c->tw += textw(&dc.font, c->name) + dc.font.height;
    2.18 +			c->tw += textw(c->tags[i]) + dc.font.height;
    2.19 +	c->tw += textw(c->name) + dc.font.height;
    2.20  	if(c->tw > c->w)
    2.21  		c->tw = c->w + 2;
    2.22  	c->tx = c->x + c->w - c->tw + 2;
    2.23 @@ -226,10 +226,12 @@
    2.24  	c->snext = stack;
    2.25  	stack = c;
    2.26  	if(old && old != c) {
    2.27 +		XSetWindowBorder(dpy, old->win, dc.bg);
    2.28  		XMapWindow(dpy, old->title);
    2.29  		draw_client(old);
    2.30  	}
    2.31  	XUnmapWindow(dpy, c->title);
    2.32 +	XSetWindowBorder(dpy, c->win, dc.fg);
    2.33  	draw_client(c);
    2.34  	XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime);
    2.35  	XFlush(dpy);
    2.36 @@ -250,8 +252,6 @@
    2.37  	c->th = th;
    2.38  	c->border = 1;
    2.39  	update_size(c);
    2.40 -	XSetWindowBorderWidth(dpy, c->win, 1);
    2.41 -	XSetWindowBorder(dpy, c->win, dc.border);
    2.42  	XSelectInput(dpy, c->win,
    2.43  			StructureNotifyMask | PropertyChangeMask | EnterWindowMask);
    2.44  	XGetTransientForHint(dpy, c->win, &c->trans);
    2.45 @@ -269,6 +269,7 @@
    2.46  	for(l=&clients; *l; l=&(*l)->next);
    2.47  	c->next = *l; /* *l == nil */
    2.48  	*l = c;
    2.49 +	XSetWindowBorderWidth(dpy, c->win, 1);
    2.50  	XMapRaised(dpy, c->win);
    2.51  	XMapRaised(dpy, c->title);
    2.52  	XGrabButton(dpy, Button1, Mod1Mask, c->win, False, ButtonPressMask,
    2.53 @@ -435,12 +436,12 @@
    2.54  	for(i = 0; i < TLast; i++) {
    2.55  		if(c->tags[i]) {
    2.56  			dc.x += dc.w;
    2.57 -			dc.w = textw(&dc.font, c->tags[i]) + dc.font.height;
    2.58 +			dc.w = textw(c->tags[i]) + dc.font.height;
    2.59  			draw(True, c->tags[i]);
    2.60  		}
    2.61  	}
    2.62  	dc.x += dc.w;
    2.63 -	dc.w = textw(&dc.font, c->name) + dc.font.height;
    2.64 +	dc.w = textw(c->name) + dc.font.height;
    2.65  	draw(True, c->name);
    2.66  	XCopyArea(dpy, dc.drawable, c->title, dc.gc,
    2.67  			0, 0, c->tw, c->th, 0, 0);
     3.1 --- a/dev.c	Thu Jul 13 10:34:55 2006 +0200
     3.2 +++ b/dev.c	Thu Jul 13 11:43:05 2006 +0200
     3.3 @@ -3,7 +3,7 @@
     3.4   * See LICENSE file for license details.
     3.5   */
     3.6  
     3.7 -#include "wm.h"
     3.8 +#include "dwm.h"
     3.9  
    3.10  #include <stdlib.h>
    3.11  #include <string.h>
     4.1 --- a/draw.c	Thu Jul 13 10:34:55 2006 +0200
     4.2 +++ b/draw.c	Thu Jul 13 11:43:05 2006 +0200
     4.3 @@ -8,7 +8,7 @@
     4.4  
     4.5  #include <X11/Xlocale.h>
     4.6  
     4.7 -#include "wm.h"
     4.8 +#include "dwm.h"
     4.9  
    4.10  static void
    4.11  drawborder(void)
    4.12 @@ -59,7 +59,7 @@
    4.13  	x = dc.x + (h / 2);
    4.14  
    4.15  	/* shorten text if necessary */
    4.16 -	while(len && (w = textnw(&dc.font, buf, len)) > dc.w - h)
    4.17 +	while(len && (w = textnw(buf, len)) > dc.w - h)
    4.18  		buf[--len] = 0;
    4.19  
    4.20  	if(w > dc.w)
    4.21 @@ -79,93 +79,80 @@
    4.22  	}
    4.23  }
    4.24  
    4.25 -static unsigned long
    4.26 -xinitcolors(Colormap cmap, const char *colstr)
    4.27 +unsigned long
    4.28 +initcolor(const char *colstr)
    4.29  {
    4.30  	XColor color;
    4.31 +	Colormap cmap = DefaultColormap(dpy, screen);
    4.32 +
    4.33  	XAllocNamedColor(dpy, cmap, colstr, &color, &color);
    4.34  	return color.pixel;
    4.35  }
    4.36  
    4.37 -void
    4.38 -initcolors(const char *bg, const char *fg, const char *border)
    4.39 +unsigned int
    4.40 +textnw(char *text, unsigned int len)
    4.41  {
    4.42 -	Colormap cmap = DefaultColormap(dpy, screen);
    4.43 -	dc.bg = xinitcolors(cmap, bg);
    4.44 -	dc.fg = xinitcolors(cmap, fg);
    4.45 -	dc.border = xinitcolors(cmap, border);
    4.46 +	XRectangle r;
    4.47 +	if(dc.font.set) {
    4.48 +		XmbTextExtents(dc.font.set, text, len, NULL, &r);
    4.49 +		return r.width;
    4.50 +	}
    4.51 +	return XTextWidth(dc.font.xfont, text, len);
    4.52  }
    4.53  
    4.54  unsigned int
    4.55 -textnw(Fnt *font, char *text, unsigned int len)
    4.56 +textw(char *text)
    4.57  {
    4.58 -	XRectangle r;
    4.59 -	if(font->set) {
    4.60 -		XmbTextExtents(font->set, text, len, NULL, &r);
    4.61 -		return r.width;
    4.62 -	}
    4.63 -	return XTextWidth(font->xfont, text, len);
    4.64 -}
    4.65 -
    4.66 -unsigned int
    4.67 -textw(Fnt *font, char *text)
    4.68 -{
    4.69 -	return textnw(font, text, strlen(text));
    4.70 -}
    4.71 -
    4.72 -unsigned int
    4.73 -texth(Fnt *font)
    4.74 -{
    4.75 -	return font->height + 4;
    4.76 +	return textnw(text, strlen(text));
    4.77  }
    4.78  
    4.79  void
    4.80 -initfont(Fnt *font, const char *fontstr)
    4.81 +initfont(const char *fontstr)
    4.82  {
    4.83  	char **missing, *def;
    4.84  	int i, n;
    4.85  
    4.86  	missing = NULL;
    4.87  	setlocale(LC_ALL, "");
    4.88 -	if(font->set)
    4.89 -		XFreeFontSet(dpy, font->set);
    4.90 -	font->set = XCreateFontSet(dpy, fontstr, &missing, &n, &def);
    4.91 +	if(dc.font.set)
    4.92 +		XFreeFontSet(dpy, dc.font.set);
    4.93 +	dc.font.set = XCreateFontSet(dpy, fontstr, &missing, &n, &def);
    4.94  	if(missing) {
    4.95  		while(n--)
    4.96  			fprintf(stderr, "missing fontset: %s\n", missing[n]);
    4.97  		XFreeStringList(missing);
    4.98 -		if(font->set) {
    4.99 -			XFreeFontSet(dpy, font->set);
   4.100 -			font->set = NULL;
   4.101 +		if(dc.font.set) {
   4.102 +			XFreeFontSet(dpy, dc.font.set);
   4.103 +			dc.font.set = NULL;
   4.104  		}
   4.105  	}
   4.106 -	if(font->set) {
   4.107 +	if(dc.font.set) {
   4.108  		XFontSetExtents *font_extents;
   4.109  		XFontStruct **xfonts;
   4.110  		char **font_names;
   4.111  
   4.112 -		font->ascent = font->descent = 0;
   4.113 -		font_extents = XExtentsOfFontSet(font->set);
   4.114 -		n = XFontsOfFontSet(font->set, &xfonts, &font_names);
   4.115 -		for(i = 0, font->ascent = 0, font->descent = 0; i < n; i++) {
   4.116 -			if(font->ascent < (*xfonts)->ascent)
   4.117 -				font->ascent = (*xfonts)->ascent;
   4.118 -			if(font->descent < (*xfonts)->descent)
   4.119 -				font->descent = (*xfonts)->descent;
   4.120 +		dc.font.ascent = dc.font.descent = 0;
   4.121 +		font_extents = XExtentsOfFontSet(dc.font.set);
   4.122 +		n = XFontsOfFontSet(dc.font.set, &xfonts, &font_names);
   4.123 +		for(i = 0, dc.font.ascent = 0, dc.font.descent = 0; i < n; i++) {
   4.124 +			if(dc.font.ascent < (*xfonts)->ascent)
   4.125 +				dc.font.ascent = (*xfonts)->ascent;
   4.126 +			if(dc.font.descent < (*xfonts)->descent)
   4.127 +				dc.font.descent = (*xfonts)->descent;
   4.128  			xfonts++;
   4.129  		}
   4.130  	}
   4.131  	else {
   4.132 -		if(font->xfont)
   4.133 -			XFreeFont(dpy, font->xfont);
   4.134 -		font->xfont = NULL;
   4.135 -		font->xfont = XLoadQueryFont(dpy, fontstr);
   4.136 -		if (!font->xfont)
   4.137 -			font->xfont = XLoadQueryFont(dpy, "fixed");
   4.138 -		if (!font->xfont)
   4.139 +		if(dc.font.xfont)
   4.140 +			XFreeFont(dpy, dc.font.xfont);
   4.141 +		dc.font.xfont = NULL;
   4.142 +		dc.font.xfont = XLoadQueryFont(dpy, fontstr);
   4.143 +		if (!dc.font.xfont)
   4.144 +			dc.font.xfont = XLoadQueryFont(dpy, "fixed");
   4.145 +		if (!dc.font.xfont)
   4.146  			error("error, cannot init 'fixed' font\n");
   4.147 -		font->ascent = font->xfont->ascent;
   4.148 -		font->descent = font->xfont->descent;
   4.149 +		dc.font.ascent = dc.font.xfont->ascent;
   4.150 +		dc.font.descent = dc.font.xfont->descent;
   4.151  	}
   4.152 -	font->height = font->ascent + font->descent;
   4.153 +	dc.font.height = dc.font.ascent + dc.font.descent;
   4.154  }
     5.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     5.2 +++ b/dwm.h	Thu Jul 13 11:43:05 2006 +0200
     5.3 @@ -0,0 +1,136 @@
     5.4 +/*
     5.5 + * (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
     5.6 + * See LICENSE file for license details.
     5.7 + */
     5.8 +
     5.9 +#include <X11/Xlib.h>
    5.10 +
    5.11 +/********** CUSTOMIZE **********/
    5.12 +
    5.13 +#define FONT		"-*-terminus-medium-*-*-*-13-*-*-*-*-*-iso10646-*"
    5.14 +#define BGCOLOR		"DarkSlateGrey"
    5.15 +#define FGCOLOR		"LightSteelBlue"
    5.16 +#define BORDERCOLOR	"SlateGray"
    5.17 +#define WM_PROTOCOL_DELWIN 1
    5.18 +
    5.19 +/* tags */
    5.20 +enum { Tscratch, Tdev, Tirc, Twww, Twork, TLast };
    5.21 +
    5.22 +/********** CUSTOMIZE **********/
    5.23 +
    5.24 +typedef struct DC DC;
    5.25 +typedef struct Client Client;
    5.26 +typedef struct Fnt Fnt;
    5.27 +typedef struct Key Key;
    5.28 +
    5.29 +/* atoms */
    5.30 +enum { WMProtocols, WMDelete, WMLast };
    5.31 +enum { NetSupported, NetWMName, NetLast };
    5.32 +
    5.33 +/* cursor */
    5.34 +enum { CurNormal, CurResize, CurMove, CurInput, CurLast };
    5.35 +
    5.36 +struct Fnt {
    5.37 +	XFontStruct *xfont;
    5.38 +	XFontSet set;
    5.39 +	int ascent;
    5.40 +	int descent;
    5.41 +	int height;
    5.42 +};
    5.43 +
    5.44 +struct DC { /* draw context */
    5.45 +	GC gc;
    5.46 +	Drawable drawable;
    5.47 +	int x, y, w, h;
    5.48 +	Fnt font;
    5.49 +	unsigned long bg;
    5.50 +	unsigned long fg;
    5.51 +	unsigned long border;
    5.52 +};
    5.53 +
    5.54 +struct Client {
    5.55 +	char name[256];
    5.56 +	char *tags[TLast];
    5.57 +	int proto;
    5.58 +	int x, y, w, h;
    5.59 +	int tx, ty, tw, th;
    5.60 +	int basew, baseh, incw, inch, maxw, maxh, minw, minh;
    5.61 +	int grav;
    5.62 +	unsigned int border;
    5.63 +	long flags; 
    5.64 +	Window win;
    5.65 +	Window trans;
    5.66 +	Window title;
    5.67 +	Client *next;
    5.68 +	Client *snext;
    5.69 +};
    5.70 +
    5.71 +struct Key {
    5.72 +	unsigned long mod;
    5.73 +	KeySym keysym;
    5.74 +	void (*func)(void *aux);
    5.75 +	void *aux;
    5.76 +};
    5.77 +
    5.78 +extern Display *dpy;
    5.79 +extern Window root;
    5.80 +extern Atom wm_atom[WMLast], net_atom[NetLast];
    5.81 +extern Cursor cursor[CurLast];
    5.82 +extern Bool running, issel;
    5.83 +extern void (*handler[LASTEvent]) (XEvent *);
    5.84 +
    5.85 +extern int tsel, screen, sx, sy, sw, sh, th;
    5.86 +extern char stext[1024], *tags[TLast];
    5.87 +
    5.88 +extern DC dc;
    5.89 +extern Client *clients, *stack;
    5.90 +
    5.91 +/* client.c */
    5.92 +extern void manage(Window w, XWindowAttributes *wa);
    5.93 +extern void unmanage(Client *c);
    5.94 +extern Client *getclient(Window w);
    5.95 +extern void focus(Client *c);
    5.96 +extern void update_name(Client *c);
    5.97 +extern void draw_client(Client *c);
    5.98 +extern void resize(Client *c);
    5.99 +extern void update_size(Client *c);
   5.100 +extern Client *gettitle(Window w);
   5.101 +extern void craise(Client *c);
   5.102 +extern void lower(Client *c);
   5.103 +extern void ckill(void *aux);
   5.104 +extern void sel(void *aux);
   5.105 +extern void max(void *aux);
   5.106 +extern void toggle(void *aux);
   5.107 +extern void gravitate(Client *c, Bool invert);
   5.108 +
   5.109 +/* draw.c */
   5.110 +extern void draw(Bool border, const char *text);
   5.111 +extern unsigned long initcolor(const char *colstr);
   5.112 +extern void initfont(const char *fontstr);
   5.113 +extern unsigned int textnw(char *text, unsigned int len);
   5.114 +extern unsigned int textw(char *text);
   5.115 +extern unsigned int texth(void);
   5.116 +
   5.117 +/* event.c */
   5.118 +extern void discard_events(long even_mask);
   5.119 +
   5.120 +/* dev.c */
   5.121 +extern void update_keys(void);
   5.122 +extern void keypress(XEvent *e);
   5.123 +extern void mresize(Client *c);
   5.124 +extern void mmove(Client *c);
   5.125 +
   5.126 +/* main.c */
   5.127 +extern int error_handler(Display *dsply, XErrorEvent *e);
   5.128 +extern void send_message(Window w, Atom a, long value);
   5.129 +extern int win_proto(Window w);
   5.130 +extern void quit(void *aux);
   5.131 +
   5.132 +/* util.c */
   5.133 +extern void error(const char *errstr, ...);
   5.134 +extern void *emallocz(unsigned int size);
   5.135 +extern void *emalloc(unsigned int size);
   5.136 +extern void *erealloc(void *ptr, unsigned int size);
   5.137 +extern char *estrdup(const char *str);
   5.138 +extern void spawn(char *argv[]);
   5.139 +extern void swap(void **p1, void **p2);
     6.1 --- a/event.c	Thu Jul 13 10:34:55 2006 +0200
     6.2 +++ b/event.c	Thu Jul 13 11:43:05 2006 +0200
     6.3 @@ -9,7 +9,7 @@
     6.4  #include <X11/keysym.h>
     6.5  #include <X11/Xatom.h>
     6.6  
     6.7 -#include "wm.h"
     6.8 +#include "dwm.h"
     6.9  
    6.10  /* local functions */
    6.11  static void buttonpress(XEvent *e);
     7.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     7.2 +++ b/main.c	Thu Jul 13 11:43:05 2006 +0200
     7.3 @@ -0,0 +1,274 @@
     7.4 +/*
     7.5 + * (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
     7.6 + * See LICENSE file for license details.
     7.7 + */
     7.8 +
     7.9 +#include <stdarg.h>
    7.10 +#include <stdio.h>
    7.11 +#include <stdlib.h>
    7.12 +
    7.13 +#include <X11/cursorfont.h>
    7.14 +#include <X11/Xatom.h>
    7.15 +#include <X11/Xproto.h>
    7.16 +
    7.17 +#include "dwm.h"
    7.18 +
    7.19 +/********** CUSTOMIZE **********/
    7.20 +
    7.21 +char *tags[TLast] = {
    7.22 +	[Tscratch] = "scratch",
    7.23 +	[Tdev] = "dev",
    7.24 +	[Tirc] = "irc",
    7.25 +	[Twww] = "www",
    7.26 +	[Twork] = "work",
    7.27 +};
    7.28 +
    7.29 +/********** CUSTOMIZE **********/
    7.30 +
    7.31 +/* X structs */
    7.32 +Display *dpy;
    7.33 +Window root, barwin;
    7.34 +Atom wm_atom[WMLast], net_atom[NetLast];
    7.35 +Cursor cursor[CurLast];
    7.36 +Bool running = True;
    7.37 +Bool issel;
    7.38 +
    7.39 +char stext[1024];
    7.40 +int tsel = Tdev; /* default tag */
    7.41 +int screen, sx, sy, sw, sh, th;
    7.42 +
    7.43 +DC dc = {0};
    7.44 +Client *clients = NULL;
    7.45 +Client *stack = NULL;
    7.46 +
    7.47 +static Bool other_wm_running;
    7.48 +static const char version[] =
    7.49 +	"dwm - " VERSION ", (C)opyright MMVI Anselm R. Garbe\n";
    7.50 +static int (*x_error_handler) (Display *, XErrorEvent *);
    7.51 +
    7.52 +static void
    7.53 +usage() {	error("usage: dwm [-v]\n"); }
    7.54 +
    7.55 +static void
    7.56 +scan_wins()
    7.57 +{
    7.58 +	unsigned int i, num;
    7.59 +	Window *wins;
    7.60 +	XWindowAttributes wa;
    7.61 +	Window d1, d2;
    7.62 +
    7.63 +	if(XQueryTree(dpy, root, &d1, &d2, &wins, &num)) {
    7.64 +		for(i = 0; i < num; i++) {
    7.65 +			if(!XGetWindowAttributes(dpy, wins[i], &wa))
    7.66 +				continue;
    7.67 +			if(wa.override_redirect || XGetTransientForHint(dpy, wins[i], &d1))
    7.68 +				continue;
    7.69 +			if(wa.map_state == IsViewable)
    7.70 +				manage(wins[i], &wa);
    7.71 +		}
    7.72 +	}
    7.73 +	if(wins)
    7.74 +		XFree(wins);
    7.75 +}
    7.76 +
    7.77 +static int
    7.78 +win_property(Window w, Atom a, Atom t, long l, unsigned char **prop)
    7.79 +{
    7.80 +	Atom real;
    7.81 +	int format;
    7.82 +	unsigned long res, extra;
    7.83 +	int status;
    7.84 +
    7.85 +	status = XGetWindowProperty(dpy, w, a, 0L, l, False, t, &real, &format,
    7.86 +			&res, &extra, prop);
    7.87 +
    7.88 +	if(status != Success || *prop == 0) {
    7.89 +		return 0;
    7.90 +	}
    7.91 +	if(res == 0) {
    7.92 +		free((void *) *prop);
    7.93 +	}
    7.94 +	return res;
    7.95 +}
    7.96 +
    7.97 +int
    7.98 +win_proto(Window w)
    7.99 +{
   7.100 +	unsigned char *protocols;
   7.101 +	long res;
   7.102 +	int protos = 0;
   7.103 +	int i;
   7.104 +
   7.105 +	res = win_property(w, wm_atom[WMProtocols], XA_ATOM, 20L, &protocols);
   7.106 +	if(res <= 0) {
   7.107 +		return protos;
   7.108 +	}
   7.109 +	for(i = 0; i < res; i++) {
   7.110 +		if(protocols[i] == wm_atom[WMDelete])
   7.111 +			protos |= WM_PROTOCOL_DELWIN;
   7.112 +	}
   7.113 +	free((char *) protocols);
   7.114 +	return protos;
   7.115 +}
   7.116 +
   7.117 +void
   7.118 +send_message(Window w, Atom a, long value)
   7.119 +{
   7.120 +	XEvent e;
   7.121 +
   7.122 +	e.type = ClientMessage;
   7.123 +	e.xclient.window = w;
   7.124 +	e.xclient.message_type = a;
   7.125 +	e.xclient.format = 32;
   7.126 +	e.xclient.data.l[0] = value;
   7.127 +	e.xclient.data.l[1] = CurrentTime;
   7.128 +	XSendEvent(dpy, w, False, NoEventMask, &e);
   7.129 +	XFlush(dpy);
   7.130 +}
   7.131 +
   7.132 +/*
   7.133 + * There's no way to check accesses to destroyed windows, thus
   7.134 + * those cases are ignored (especially on UnmapNotify's).
   7.135 + * Other types of errors call Xlib's default error handler, which
   7.136 + * calls exit().
   7.137 + */
   7.138 +int
   7.139 +error_handler(Display *dpy, XErrorEvent *error)
   7.140 +{
   7.141 +	if(error->error_code == BadWindow
   7.142 +			|| (error->request_code == X_SetInputFocus
   7.143 +				&& error->error_code == BadMatch)
   7.144 +			|| (error->request_code == X_PolyText8
   7.145 +				&& error->error_code == BadDrawable)
   7.146 +			|| (error->request_code == X_PolyFillRectangle
   7.147 +				&& error->error_code == BadDrawable)
   7.148 +			|| (error->request_code == X_PolySegment
   7.149 +				&& error->error_code == BadDrawable)
   7.150 +			|| (error->request_code == X_ConfigureWindow
   7.151 +				&& error->error_code == BadMatch)
   7.152 +			|| (error->request_code == X_GrabKey
   7.153 +				&& error->error_code == BadAccess))
   7.154 +		return 0;
   7.155 +	fprintf(stderr, "dwm: fatal error: request code=%d, error code=%d\n",
   7.156 +			error->request_code, error->error_code);
   7.157 +	return x_error_handler(dpy, error); /* may call exit() */
   7.158 +}
   7.159 +
   7.160 +/*
   7.161 + * Startup Error handler to check if another window manager
   7.162 + * is already running.
   7.163 + */
   7.164 +static int
   7.165 +startup_error_handler(Display *dpy, XErrorEvent *error)
   7.166 +{
   7.167 +	other_wm_running = True;
   7.168 +	return -1;
   7.169 +}
   7.170 +
   7.171 +static void
   7.172 +cleanup()
   7.173 +{
   7.174 +	while(clients)
   7.175 +		unmanage(clients);
   7.176 +	XSetInputFocus(dpy, PointerRoot, RevertToPointerRoot, CurrentTime);
   7.177 +}
   7.178 +
   7.179 +void
   7.180 +quit(void *aux)
   7.181 +{
   7.182 +	running = False;
   7.183 +}
   7.184 +
   7.185 +int
   7.186 +main(int argc, char *argv[])
   7.187 +{
   7.188 +	int i;
   7.189 +	XSetWindowAttributes wa;
   7.190 +	unsigned int mask;
   7.191 +	Window w;
   7.192 +	XEvent ev;
   7.193 +
   7.194 +	/* command line args */
   7.195 +	for(i = 1; (i < argc) && (argv[i][0] == '-'); i++) {
   7.196 +		switch (argv[i][1]) {
   7.197 +		case 'v':
   7.198 +			fprintf(stdout, "%s", version);
   7.199 +			exit(0);
   7.200 +			break;
   7.201 +		default:
   7.202 +			usage();
   7.203 +			break;
   7.204 +		}
   7.205 +	}
   7.206 +
   7.207 +	dpy = XOpenDisplay(0);
   7.208 +	if(!dpy)
   7.209 +		error("dwm: cannot connect X server\n");
   7.210 +
   7.211 +	screen = DefaultScreen(dpy);
   7.212 +	root = RootWindow(dpy, screen);
   7.213 +
   7.214 +	/* check if another WM is already running */
   7.215 +	other_wm_running = False;
   7.216 +	XSetErrorHandler(startup_error_handler);
   7.217 +	/* this causes an error if some other WM is running */
   7.218 +	XSelectInput(dpy, root, SubstructureRedirectMask);
   7.219 +	XFlush(dpy);
   7.220 +
   7.221 +	if(other_wm_running)
   7.222 +		error("dwm: another window manager is already running\n");
   7.223 +
   7.224 +	sx = sy = 0;
   7.225 +	sw = DisplayWidth(dpy, screen);
   7.226 +	sh = DisplayHeight(dpy, screen);
   7.227 +	issel = XQueryPointer(dpy, root, &w, &w, &i, &i, &i, &i, &mask);
   7.228 +
   7.229 +	XSetErrorHandler(0);
   7.230 +	x_error_handler = XSetErrorHandler(error_handler);
   7.231 +
   7.232 +	/* init atoms */
   7.233 +	wm_atom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False);
   7.234 +	wm_atom[WMDelete] = XInternAtom(dpy, "WM_DELETE_WINDOW", False);
   7.235 +	net_atom[NetSupported] = XInternAtom(dpy, "_NET_SUPPORTED", False);
   7.236 +	net_atom[NetWMName] = XInternAtom(dpy, "_NET_WM_NAME", False);
   7.237 +
   7.238 +	XChangeProperty(dpy, root, net_atom[NetSupported], XA_ATOM, 32,
   7.239 +			PropModeReplace, (unsigned char *) net_atom, NetLast);
   7.240 +
   7.241 +
   7.242 +	/* init cursors */
   7.243 +	cursor[CurNormal] = XCreateFontCursor(dpy, XC_left_ptr);
   7.244 +	cursor[CurResize] = XCreateFontCursor(dpy, XC_sizing);
   7.245 +	cursor[CurMove] = XCreateFontCursor(dpy, XC_fleur);
   7.246 +
   7.247 +	update_keys();
   7.248 +
   7.249 +	/* style */
   7.250 +	dc.bg = initcolor(BGCOLOR);
   7.251 +	dc.fg = initcolor(FGCOLOR);
   7.252 +	dc.border = initcolor(BORDERCOLOR);
   7.253 +	initfont(FONT);
   7.254 +
   7.255 +	th = dc.font.height + 4;
   7.256 +
   7.257 +	dc.drawable = XCreatePixmap(dpy, root, sw, th, DefaultDepth(dpy, screen));
   7.258 +	dc.gc = XCreateGC(dpy, root, 0, 0);
   7.259 +
   7.260 +	wa.event_mask = SubstructureRedirectMask | EnterWindowMask \
   7.261 +					| LeaveWindowMask;
   7.262 +	wa.cursor = cursor[CurNormal];
   7.263 +	XChangeWindowAttributes(dpy, root, CWEventMask | CWCursor, &wa);
   7.264 +
   7.265 +	scan_wins();
   7.266 +
   7.267 +	while(running) {
   7.268 +		XNextEvent(dpy, &ev);
   7.269 +		if(handler[ev.type])
   7.270 +			(handler[ev.type])(&ev); /* call handler */
   7.271 +	}
   7.272 +
   7.273 +	cleanup();
   7.274 +	XCloseDisplay(dpy);
   7.275 +
   7.276 +	return 0;
   7.277 +}
     8.1 --- a/util.c	Thu Jul 13 10:34:55 2006 +0200
     8.2 +++ b/util.c	Thu Jul 13 11:43:05 2006 +0200
     8.3 @@ -11,7 +11,7 @@
     8.4  #include <sys/wait.h>
     8.5  #include <unistd.h>
     8.6  
     8.7 -#include "wm.h"
     8.8 +#include "dwm.h"
     8.9  
    8.10  void
    8.11  error(const char *errstr, ...) {
     9.1 --- a/wm.c	Thu Jul 13 10:34:55 2006 +0200
     9.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     9.3 @@ -1,272 +0,0 @@
     9.4 -/*
     9.5 - * (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
     9.6 - * See LICENSE file for license details.
     9.7 - */
     9.8 -
     9.9 -#include <stdarg.h>
    9.10 -#include <stdio.h>
    9.11 -#include <stdlib.h>
    9.12 -
    9.13 -#include <X11/cursorfont.h>
    9.14 -#include <X11/Xatom.h>
    9.15 -#include <X11/Xproto.h>
    9.16 -
    9.17 -#include "wm.h"
    9.18 -
    9.19 -/********** CUSTOMIZE **********/
    9.20 -
    9.21 -char *tags[TLast] = {
    9.22 -	[Tscratch] = "scratch",
    9.23 -	[Tdev] = "dev",
    9.24 -	[Tirc] = "irc",
    9.25 -	[Twww] = "www",
    9.26 -	[Twork] = "work",
    9.27 -};
    9.28 -
    9.29 -/********** CUSTOMIZE **********/
    9.30 -
    9.31 -/* X structs */
    9.32 -Display *dpy;
    9.33 -Window root, barwin;
    9.34 -Atom wm_atom[WMLast], net_atom[NetLast];
    9.35 -Cursor cursor[CurLast];
    9.36 -Bool running = True;
    9.37 -Bool issel;
    9.38 -
    9.39 -char stext[1024];
    9.40 -int tsel = Tdev; /* default tag */
    9.41 -int screen, sx, sy, sw, sh, th;
    9.42 -
    9.43 -DC dc = {0};
    9.44 -Client *clients = NULL;
    9.45 -Client *stack = NULL;
    9.46 -
    9.47 -static Bool other_wm_running;
    9.48 -static const char version[] =
    9.49 -	"dwm - " VERSION ", (C)opyright MMVI Anselm R. Garbe\n";
    9.50 -static int (*x_error_handler) (Display *, XErrorEvent *);
    9.51 -
    9.52 -static void
    9.53 -usage() {	error("usage: dwm [-v]\n"); }
    9.54 -
    9.55 -static void
    9.56 -scan_wins()
    9.57 -{
    9.58 -	unsigned int i, num;
    9.59 -	Window *wins;
    9.60 -	XWindowAttributes wa;
    9.61 -	Window d1, d2;
    9.62 -
    9.63 -	if(XQueryTree(dpy, root, &d1, &d2, &wins, &num)) {
    9.64 -		for(i = 0; i < num; i++) {
    9.65 -			if(!XGetWindowAttributes(dpy, wins[i], &wa))
    9.66 -				continue;
    9.67 -			if(wa.override_redirect || XGetTransientForHint(dpy, wins[i], &d1))
    9.68 -				continue;
    9.69 -			if(wa.map_state == IsViewable)
    9.70 -				manage(wins[i], &wa);
    9.71 -		}
    9.72 -	}
    9.73 -	if(wins)
    9.74 -		XFree(wins);
    9.75 -}
    9.76 -
    9.77 -static int
    9.78 -win_property(Window w, Atom a, Atom t, long l, unsigned char **prop)
    9.79 -{
    9.80 -	Atom real;
    9.81 -	int format;
    9.82 -	unsigned long res, extra;
    9.83 -	int status;
    9.84 -
    9.85 -	status = XGetWindowProperty(dpy, w, a, 0L, l, False, t, &real, &format,
    9.86 -			&res, &extra, prop);
    9.87 -
    9.88 -	if(status != Success || *prop == 0) {
    9.89 -		return 0;
    9.90 -	}
    9.91 -	if(res == 0) {
    9.92 -		free((void *) *prop);
    9.93 -	}
    9.94 -	return res;
    9.95 -}
    9.96 -
    9.97 -int
    9.98 -win_proto(Window w)
    9.99 -{
   9.100 -	unsigned char *protocols;
   9.101 -	long res;
   9.102 -	int protos = 0;
   9.103 -	int i;
   9.104 -
   9.105 -	res = win_property(w, wm_atom[WMProtocols], XA_ATOM, 20L, &protocols);
   9.106 -	if(res <= 0) {
   9.107 -		return protos;
   9.108 -	}
   9.109 -	for(i = 0; i < res; i++) {
   9.110 -		if(protocols[i] == wm_atom[WMDelete])
   9.111 -			protos |= WM_PROTOCOL_DELWIN;
   9.112 -	}
   9.113 -	free((char *) protocols);
   9.114 -	return protos;
   9.115 -}
   9.116 -
   9.117 -void
   9.118 -send_message(Window w, Atom a, long value)
   9.119 -{
   9.120 -	XEvent e;
   9.121 -
   9.122 -	e.type = ClientMessage;
   9.123 -	e.xclient.window = w;
   9.124 -	e.xclient.message_type = a;
   9.125 -	e.xclient.format = 32;
   9.126 -	e.xclient.data.l[0] = value;
   9.127 -	e.xclient.data.l[1] = CurrentTime;
   9.128 -	XSendEvent(dpy, w, False, NoEventMask, &e);
   9.129 -	XFlush(dpy);
   9.130 -}
   9.131 -
   9.132 -/*
   9.133 - * There's no way to check accesses to destroyed windows, thus
   9.134 - * those cases are ignored (especially on UnmapNotify's).
   9.135 - * Other types of errors call Xlib's default error handler, which
   9.136 - * calls exit().
   9.137 - */
   9.138 -int
   9.139 -error_handler(Display *dpy, XErrorEvent *error)
   9.140 -{
   9.141 -	if(error->error_code == BadWindow
   9.142 -			|| (error->request_code == X_SetInputFocus
   9.143 -				&& error->error_code == BadMatch)
   9.144 -			|| (error->request_code == X_PolyText8
   9.145 -				&& error->error_code == BadDrawable)
   9.146 -			|| (error->request_code == X_PolyFillRectangle
   9.147 -				&& error->error_code == BadDrawable)
   9.148 -			|| (error->request_code == X_PolySegment
   9.149 -				&& error->error_code == BadDrawable)
   9.150 -			|| (error->request_code == X_ConfigureWindow
   9.151 -				&& error->error_code == BadMatch)
   9.152 -			|| (error->request_code == X_GrabKey
   9.153 -				&& error->error_code == BadAccess))
   9.154 -		return 0;
   9.155 -	fprintf(stderr, "dwm: fatal error: request code=%d, error code=%d\n",
   9.156 -			error->request_code, error->error_code);
   9.157 -	return x_error_handler(dpy, error); /* may call exit() */
   9.158 -}
   9.159 -
   9.160 -/*
   9.161 - * Startup Error handler to check if another window manager
   9.162 - * is already running.
   9.163 - */
   9.164 -static int
   9.165 -startup_error_handler(Display *dpy, XErrorEvent *error)
   9.166 -{
   9.167 -	other_wm_running = True;
   9.168 -	return -1;
   9.169 -}
   9.170 -
   9.171 -static void
   9.172 -cleanup()
   9.173 -{
   9.174 -	while(clients)
   9.175 -		unmanage(clients);
   9.176 -	XSetInputFocus(dpy, PointerRoot, RevertToPointerRoot, CurrentTime);
   9.177 -}
   9.178 -
   9.179 -void
   9.180 -quit(void *aux)
   9.181 -{
   9.182 -	running = False;
   9.183 -}
   9.184 -
   9.185 -int
   9.186 -main(int argc, char *argv[])
   9.187 -{
   9.188 -	int i;
   9.189 -	XSetWindowAttributes wa;
   9.190 -	unsigned int mask;
   9.191 -	Window w;
   9.192 -	XEvent ev;
   9.193 -
   9.194 -	/* command line args */
   9.195 -	for(i = 1; (i < argc) && (argv[i][0] == '-'); i++) {
   9.196 -		switch (argv[i][1]) {
   9.197 -		case 'v':
   9.198 -			fprintf(stdout, "%s", version);
   9.199 -			exit(0);
   9.200 -			break;
   9.201 -		default:
   9.202 -			usage();
   9.203 -			break;
   9.204 -		}
   9.205 -	}
   9.206 -
   9.207 -	dpy = XOpenDisplay(0);
   9.208 -	if(!dpy)
   9.209 -		error("dwm: cannot connect X server\n");
   9.210 -
   9.211 -	screen = DefaultScreen(dpy);
   9.212 -	root = RootWindow(dpy, screen);
   9.213 -
   9.214 -	/* check if another WM is already running */
   9.215 -	other_wm_running = False;
   9.216 -	XSetErrorHandler(startup_error_handler);
   9.217 -	/* this causes an error if some other WM is running */
   9.218 -	XSelectInput(dpy, root, SubstructureRedirectMask);
   9.219 -	XFlush(dpy);
   9.220 -
   9.221 -	if(other_wm_running)
   9.222 -		error("dwm: another window manager is already running\n");
   9.223 -
   9.224 -	sx = sy = 0;
   9.225 -	sw = DisplayWidth(dpy, screen);
   9.226 -	sh = DisplayHeight(dpy, screen);
   9.227 -	issel = XQueryPointer(dpy, root, &w, &w, &i, &i, &i, &i, &mask);
   9.228 -
   9.229 -	XSetErrorHandler(0);
   9.230 -	x_error_handler = XSetErrorHandler(error_handler);
   9.231 -
   9.232 -	/* init atoms */
   9.233 -	wm_atom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False);
   9.234 -	wm_atom[WMDelete] = XInternAtom(dpy, "WM_DELETE_WINDOW", False);
   9.235 -	net_atom[NetSupported] = XInternAtom(dpy, "_NET_SUPPORTED", False);
   9.236 -	net_atom[NetWMName] = XInternAtom(dpy, "_NET_WM_NAME", False);
   9.237 -
   9.238 -	XChangeProperty(dpy, root, net_atom[NetSupported], XA_ATOM, 32,
   9.239 -			PropModeReplace, (unsigned char *) net_atom, NetLast);
   9.240 -
   9.241 -
   9.242 -	/* init cursors */
   9.243 -	cursor[CurNormal] = XCreateFontCursor(dpy, XC_left_ptr);
   9.244 -	cursor[CurResize] = XCreateFontCursor(dpy, XC_sizing);
   9.245 -	cursor[CurMove] = XCreateFontCursor(dpy, XC_fleur);
   9.246 -
   9.247 -	update_keys();
   9.248 -
   9.249 -	/* style */
   9.250 -	initcolors(BGCOLOR, FGCOLOR, BORDERCOLOR);
   9.251 -	initfont(&dc.font, FONT);
   9.252 -
   9.253 -	th = texth(&dc.font);
   9.254 -
   9.255 -	dc.drawable = XCreatePixmap(dpy, root, sw, th, DefaultDepth(dpy, screen));
   9.256 -	dc.gc = XCreateGC(dpy, root, 0, 0);
   9.257 -
   9.258 -	wa.event_mask = SubstructureRedirectMask | EnterWindowMask \
   9.259 -					| LeaveWindowMask;
   9.260 -	wa.cursor = cursor[CurNormal];
   9.261 -	XChangeWindowAttributes(dpy, root, CWEventMask | CWCursor, &wa);
   9.262 -
   9.263 -	scan_wins();
   9.264 -
   9.265 -	while(running) {
   9.266 -		XNextEvent(dpy, &ev);
   9.267 -		if(handler[ev.type])
   9.268 -			(handler[ev.type])(&ev); /* call handler */
   9.269 -	}
   9.270 -
   9.271 -	cleanup();
   9.272 -	XCloseDisplay(dpy);
   9.273 -
   9.274 -	return 0;
   9.275 -}
    10.1 --- a/wm.h	Thu Jul 13 10:34:55 2006 +0200
    10.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
    10.3 @@ -1,137 +0,0 @@
    10.4 -/*
    10.5 - * (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
    10.6 - * See LICENSE file for license details.
    10.7 - */
    10.8 -
    10.9 -#include <X11/Xlib.h>
   10.10 -
   10.11 -/********** CUSTOMIZE **********/
   10.12 -
   10.13 -#define FONT		"-*-terminus-medium-*-*-*-13-*-*-*-*-*-iso10646-*"
   10.14 -#define BGCOLOR		"#666699"
   10.15 -#define FGCOLOR		"#ffffff"
   10.16 -#define BORDERCOLOR	"#9999CC"
   10.17 -#define STATUSDELAY	10 /* seconds */
   10.18 -#define WM_PROTOCOL_DELWIN 1
   10.19 -
   10.20 -/* tags */
   10.21 -enum { Tscratch, Tdev, Tirc, Twww, Twork, TLast };
   10.22 -
   10.23 -/********** CUSTOMIZE **********/
   10.24 -
   10.25 -typedef struct DC DC;
   10.26 -typedef struct Client Client;
   10.27 -typedef struct Fnt Fnt;
   10.28 -typedef struct Key Key;
   10.29 -
   10.30 -/* atoms */
   10.31 -enum { WMProtocols, WMDelete, WMLast };
   10.32 -enum { NetSupported, NetWMName, NetLast };
   10.33 -
   10.34 -/* cursor */
   10.35 -enum { CurNormal, CurResize, CurMove, CurInput, CurLast };
   10.36 -
   10.37 -struct Fnt {
   10.38 -	XFontStruct *xfont;
   10.39 -	XFontSet set;
   10.40 -	int ascent;
   10.41 -	int descent;
   10.42 -	int height;
   10.43 -};
   10.44 -
   10.45 -struct DC { /* draw context */
   10.46 -	GC gc;
   10.47 -	Drawable drawable;
   10.48 -	int x, y, w, h;
   10.49 -	Fnt font;
   10.50 -	unsigned long bg;
   10.51 -	unsigned long fg;
   10.52 -	unsigned long border;
   10.53 -};
   10.54 -
   10.55 -struct Client {
   10.56 -	char name[256];
   10.57 -	char *tags[TLast];
   10.58 -	int proto;
   10.59 -	int x, y, w, h;
   10.60 -	int tx, ty, tw, th;
   10.61 -	int basew, baseh, incw, inch, maxw, maxh, minw, minh;
   10.62 -	int grav;
   10.63 -	unsigned int border;
   10.64 -	long flags; 
   10.65 -	Window win;
   10.66 -	Window trans;
   10.67 -	Window title;
   10.68 -	Client *next;
   10.69 -	Client *snext;
   10.70 -};
   10.71 -
   10.72 -struct Key {
   10.73 -	unsigned long mod;
   10.74 -	KeySym keysym;
   10.75 -	void (*func)(void *aux);
   10.76 -	void *aux;
   10.77 -};
   10.78 -
   10.79 -extern Display *dpy;
   10.80 -extern Window root;
   10.81 -extern Atom wm_atom[WMLast], net_atom[NetLast];
   10.82 -extern Cursor cursor[CurLast];
   10.83 -extern Bool running, issel;
   10.84 -extern void (*handler[LASTEvent]) (XEvent *);
   10.85 -
   10.86 -extern int tsel, screen, sx, sy, sw, sh, th;
   10.87 -extern char stext[1024], *tags[TLast];
   10.88 -
   10.89 -extern DC dc;
   10.90 -extern Client *clients, *stack;
   10.91 -
   10.92 -/* client.c */
   10.93 -extern void manage(Window w, XWindowAttributes *wa);
   10.94 -extern void unmanage(Client *c);
   10.95 -extern Client *getclient(Window w);
   10.96 -extern void focus(Client *c);
   10.97 -extern void update_name(Client *c);
   10.98 -extern void draw_client(Client *c);
   10.99 -extern void resize(Client *c);
  10.100 -extern void update_size(Client *c);
  10.101 -extern Client *gettitle(Window w);
  10.102 -extern void craise(Client *c);
  10.103 -extern void lower(Client *c);
  10.104 -extern void ckill(void *aux);
  10.105 -extern void sel(void *aux);
  10.106 -extern void max(void *aux);
  10.107 -extern void toggle(void *aux);
  10.108 -extern void gravitate(Client *c, Bool invert);
  10.109 -
  10.110 -/* draw.c */
  10.111 -extern void draw(Bool border, const char *text);
  10.112 -extern void initcolors(const char *bg, const char *fg, const char *bo);
  10.113 -extern void initfont(Fnt *font, const char *fontstr);
  10.114 -extern unsigned int textnw(Fnt *font, char *text, unsigned int len);
  10.115 -extern unsigned int textw(Fnt *font, char *text);
  10.116 -extern unsigned int texth(Fnt *font);
  10.117 -
  10.118 -/* event.c */
  10.119 -extern void discard_events(long even_mask);
  10.120 -
  10.121 -/* dev.c */
  10.122 -extern void update_keys(void);
  10.123 -extern void keypress(XEvent *e);
  10.124 -extern void mresize(Client *c);
  10.125 -extern void mmove(Client *c);
  10.126 -
  10.127 -/* util.c */
  10.128 -extern void error(const char *errstr, ...);
  10.129 -extern void *emallocz(unsigned int size);
  10.130 -extern void *emalloc(unsigned int size);
  10.131 -extern void *erealloc(void *ptr, unsigned int size);
  10.132 -extern char *estrdup(const char *str);
  10.133 -extern void spawn(char *argv[]);
  10.134 -extern void swap(void **p1, void **p2);
  10.135 -
  10.136 -/* wm.c */
  10.137 -extern int error_handler(Display *dsply, XErrorEvent *e);
  10.138 -extern void send_message(Window w, Atom a, long value);
  10.139 -extern int win_proto(Window w);
  10.140 -extern void quit(void *aux);