};
Client *
-next(Client *c)
+getnext(Client *c)
{
for(; c && !c->tags[tsel]; c = c->next);
return c;
}
void
-ban_client(Client *c)
+ban(Client *c)
{
XMoveWindow(dpy, c->win, c->x + 2 * sw, c->y);
XMoveWindow(dpy, c->title, c->tx + 2 * sw, c->ty);
}
void
-update_name(Client *c)
+settitle(Client *c)
{
XTextProperty name;
int n;
}
void
-update_size(Client *c)
+setsize(Client *c)
{
XSizeHints size;
long msize;
}
void
-craise(Client *c)
+higher(Client *c)
{
XRaiseWindow(dpy, c->win);
XRaiseWindow(dpy, c->title);
XFlush(dpy);
sel = c;
if(old && old != c)
- draw_client(old);
- draw_client(c);
+ drawtitle(old);
+ drawtitle(c);
XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime);
XFlush(dpy);
while(XCheckMaskEvent(dpy, EnterWindowMask, &ev));
c->h = wa->height;
c->th = bh;
c->border = 1;
- c->proto = win_proto(c->win);
- update_size(c);
+ c->proto = proto(c->win);
+ setsize(c);
XSelectInput(dpy, c->win,
StructureNotifyMask | PropertyChangeMask | EnterWindowMask);
XGetTransientForHint(dpy, c->win, &trans);
DefaultVisual(dpy, screen),
CWOverrideRedirect | CWBackPixmap | CWEventMask, &twa);
- update_name(c);
+ settitle(c);
init_tags(c);
for(l = &clients; *l; l = &(*l)->next);
focus(c);
}
else {
- ban_client(c);
+ ban(c);
XMapRaised(dpy, c->win);
XMapRaised(dpy, c->title);
}
}
static int
-dummy_error_handler(Display *dsply, XErrorEvent *err)
+dummy_xerror(Display *dsply, XErrorEvent *err)
{
return 0;
}
Client **l;
XGrabServer(dpy);
- XSetErrorHandler(dummy_error_handler);
+ XSetErrorHandler(dummy_xerror);
XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
XDestroyWindow(dpy, c->title);
free(c);
XFlush(dpy);
- XSetErrorHandler(error_handler);
+ XSetErrorHandler(xerror);
XUngrabServer(dpy);
arrange(NULL);
if(sel)
#include "dwm.h"
void
-draw_bar()
+drawstatus()
{
int i;
}
void
-draw_client(Client *c)
+drawtitle(Client *c)
{
int i;
if(c == sel) {
- draw_bar();
+ drawstatus();
XUnmapWindow(dpy, c->title);
XSetWindowBorder(dpy, c->win, dc.fg);
return;
}
unsigned long
-initcolor(const char *colstr)
+getcolor(const char *colstr)
{
XColor color;
Colormap cmap = DefaultColormap(dpy, screen);
}
void
-initfont(const char *fontstr)
+setfont(const char *fontstr)
{
char **missing, *def;
int i, n;
extern void unmanage(Client *c);
extern Client *getclient(Window w);
extern void focus(Client *c);
-extern void update_name(Client *c);
+extern void settitle(Client *c);
extern void resize(Client *c, Bool inc);
-extern void update_size(Client *c);
+extern void setsize(Client *c);
extern Client *gettitle(Window w);
-extern void craise(Client *c);
+extern void higher(Client *c);
extern void lower(Client *c);
extern void gravitate(Client *c, Bool invert);
-extern void ban_client(Client *c);
-extern Client *next(Client *c);
+extern void ban(Client *c);
+extern Client *getnext(Client *c);
/* draw.c */
-extern void draw_bar();
-extern void draw_client(Client *c);
+extern void drawstatus();
+extern void drawtitle(Client *c);
extern void drawtext(const char *text, Bool invert, Bool border);
-extern unsigned long initcolor(const char *colstr);
-extern void initfont(const char *fontstr);
+extern unsigned long getcolor(const char *colstr);
+extern void setfont(const char *fontstr);
extern unsigned int textnw(char *text, unsigned int len);
extern unsigned int textw(char *text);
extern unsigned int texth(void);
extern void keypress(XEvent *e);
/* main.c */
-extern int error_handler(Display *dsply, XErrorEvent *e);
-extern void send_message(Window w, Atom a, long value);
-extern int win_proto(Window w);
+extern int xerror(Display *dsply, XErrorEvent *e);
+extern void sendevent(Window w, Atom a, long value);
+extern int proto(Window w);
extern void quit(Arg *arg);
/* screen.c */
else if((c = getclient(ev->window))) {
if(arrange == tiling && !c->floating)
return;
- craise(c);
+ higher(c);
switch(ev->button) {
default:
break;
if(ev->count == 0) {
if(barwin == ev->window)
- draw_bar();
+ drawstatus();
else if((c = gettitle(ev->window)))
- draw_client(c);
+ drawtitle(c);
}
}
if((c = getclient(ev->window))) {
if(ev->atom == wm_atom[WMProtocols]) {
- c->proto = win_proto(c->win);
+ c->proto = proto(c->win);
return;
}
switch (ev->atom) {
arrange(NULL);
break;
case XA_WM_NORMAL_HINTS:
- update_size(c);
+ setsize(c);
break;
}
if(ev->atom == XA_WM_NAME || ev->atom == net_atom[NetWMName]) {
- update_name(c);
- draw_client(c);
+ settitle(c);
+ drawtitle(c);
}
}
}
if(!sel)
return;
- if(sel == next(clients) && sel->next) {
- if((c = next(sel->next)))
+ if(sel == getnext(clients) && sel->next) {
+ if((c = getnext(sel->next)))
sel = c;
}
sel->y = sy + bh;
sel->w = sw - 2 * sel->border;
sel->h = sh - 2 * sel->border - bh;
- craise(sel);
+ higher(sel);
resize(sel, False);
}
return;
if((c = sel->revert && sel->revert->tags[tsel] ? sel->revert : NULL)) {
- craise(c);
+ higher(c);
focus(c);
}
}
if(!sel)
return;
- if(!(c = next(sel->next)))
- c = next(clients);
+ if(!(c = getnext(sel->next)))
+ c = getnext(clients);
if(c) {
- craise(c);
+ higher(c);
c->revert = sel;
focus(c);
}
if(!sel)
return;
if(sel->proto & WM_PROTOCOL_DELWIN)
- send_message(sel->win, wm_atom[WMProtocols], wm_atom[WMDelete]);
+ sendevent(sel->win, wm_atom[WMProtocols], wm_atom[WMDelete]);
else
XKillClient(dpy, sel->win);
}
static Bool other_wm_running;
static const char version[] =
"dwm-" VERSION ", (C)opyright MMVI Anselm R. Garbe\n";
-static int (*x_error_handler) (Display *, XErrorEvent *);
+static int (*x_xerror) (Display *, XErrorEvent *);
static void
usage() { error("usage: dwm [-v]\n"); }
}
int
-win_proto(Window w)
+proto(Window w)
{
unsigned char *protocols;
long res;
}
void
-send_message(Window w, Atom a, long value)
+sendevent(Window w, Atom a, long value)
{
XEvent e;
* calls exit().
*/
int
-error_handler(Display *dpy, XErrorEvent *error)
+xerror(Display *dpy, XErrorEvent *error)
{
if(error->error_code == BadWindow
|| (error->request_code == X_SetInputFocus
return 0;
fprintf(stderr, "dwm: fatal error: request code=%d, error code=%d\n",
error->request_code, error->error_code);
- return x_error_handler(dpy, error); /* may call exit() */
+ return x_xerror(dpy, error); /* may call exit() */
}
/*
* is already running.
*/
static int
-startup_error_handler(Display *dpy, XErrorEvent *error)
+startup_xerror(Display *dpy, XErrorEvent *error)
{
other_wm_running = True;
return -1;
/* check if another WM is already running */
other_wm_running = False;
- XSetErrorHandler(startup_error_handler);
+ XSetErrorHandler(startup_xerror);
/* this causes an error if some other WM is running */
XSelectInput(dpy, root, SubstructureRedirectMask);
XFlush(dpy);
error("dwm: another window manager is already running\n");
XSetErrorHandler(0);
- x_error_handler = XSetErrorHandler(error_handler);
+ x_xerror = XSetErrorHandler(xerror);
/* init atoms */
wm_atom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False);
grabkeys();
/* style */
- dc.bg = initcolor(BGCOLOR);
- dc.fg = initcolor(FGCOLOR);
- dc.border = initcolor(BORDERCOLOR);
- initfont(FONT);
+ dc.bg = getcolor(BGCOLOR);
+ dc.fg = getcolor(FGCOLOR);
+ dc.border = getcolor(BORDERCOLOR);
+ setfont(FONT);
sx = sy = 0;
sw = DisplayWidth(dpy, screen);
dc.drawable = XCreatePixmap(dpy, root, sw, bh, DefaultDepth(dpy, screen));
dc.gc = XCreateGC(dpy, root, 0, 0);
- draw_bar();
+ drawstatus();
issel = XQueryPointer(dpy, root, &w, &w, &i, &i, &i, &i, &mask);
stext[n++] = i;
}
stext[n] = 0;
- draw_bar();
+ drawstatus();
}
}
}
tsel = arg->i;
arrange(NULL);
- for(c = clients; c; c = next(c->next))
- draw_client(c);
- draw_bar();
+ for(c = clients; c; c = getnext(c->next))
+ drawtitle(c);
+ drawstatus();
}
void
if(c->tags[tsel])
resize(c, True);
else
- ban_client(c);
+ ban(c);
}
if(sel && !sel->tags[tsel]) {
- if((sel = next(clients))) {
- craise(sel);
+ if((sel = getnext(clients))) {
+ higher(sel);
focus(sel);
}
}
- draw_bar();
+ drawstatus();
}
void
for(i = 0, c = clients; c; c = c->next) {
if(c->tags[tsel]) {
if(c->floating) {
- craise(c);
+ higher(c);
resize(c, True);
continue;
}
i++;
}
else
- ban_client(c);
+ ban(c);
}
if(!sel || (sel && !sel->tags[tsel])) {
- if((sel = next(clients))) {
- craise(sel);
+ if((sel = getnext(clients))) {
+ higher(sel);
focus(sel);
}
}
- draw_bar();
+ drawstatus();
}