X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=dwm.h;h=7db0f546c70615b12e2fe94dae33ab30b725311c;hb=2e0c767d74da024c3cd4dbd524e1364039704451;hp=a410f4e71cc03124c3b43c79bd8d2e41268251c1;hpb=11737233a7ce6bc656bc7bc061c68eeda824ee9b;p=dwm.git diff --git a/dwm.h b/dwm.h index a410f4e..7db0f54 100644 --- a/dwm.h +++ b/dwm.h @@ -3,38 +3,18 @@ * See LICENSE file for license details. */ +#include "config.h" #include -/********** CUSTOMIZE **********/ +/* mask shorthands, used in event.c and client.c */ +#define BUTTONMASK (ButtonPressMask | ButtonReleaseMask) +#define MOUSEMASK (BUTTONMASK | PointerMotionMask) +#define PROTODELWIN 1 -#define FONT "-*-terminus-medium-*-*-*-13-*-*-*-*-*-iso10646-*" -#define BGCOLOR "#0a2c2d" -#define FGCOLOR "#ddeeee" -#define BORDERCOLOR "#176164" -#define MODKEY Mod1Mask /* Mod4Mask */ -/* -#define BGCOLOR "#666699" -#define FGCOLOR "#eeeeee" -#define BORDERCOLOR "#9999CC" -*/ -#define MASTERW 52 /* percent */ -#define WM_PROTOCOL_DELWIN 1 - -/* tags */ -enum { Tscratch, Tdev, Twww, Twork, TLast }; - -/********** CUSTOMIZE **********/ - -typedef union Arg Arg; -typedef struct Client Client; -typedef enum Corner Corner; -typedef struct DC DC; -typedef struct Fnt Fnt; - -union Arg { - const char **argv; +typedef union { + const char *cmd; int i; -}; +} Arg; /* atoms */ enum { NetSupported, NetWMName, NetLast }; @@ -43,49 +23,53 @@ enum { WMProtocols, WMDelete, WMLast }; /* cursor */ enum { CurNormal, CurResize, CurMove, CurLast }; -enum Corner { TopLeft, TopRight, BotLeft, BotRight }; +/* window corners */ +typedef enum { TopLeft, TopRight, BotLeft, BotRight } Corner; -struct Fnt { +typedef struct { int ascent; int descent; int height; XFontSet set; XFontStruct *xfont; -}; +} Fnt; -struct DC { /* draw context */ +typedef struct { /* draw context */ int x, y, w, h; - unsigned long bg; - unsigned long fg; - unsigned long border; + unsigned long bg[2]; + unsigned long fg[2]; Drawable drawable; Fnt font; GC gc; -}; +} DC; +typedef struct Client Client; struct Client { char name[256]; - char *tags[TLast]; int proto; int x, y, w, h; int tx, ty, tw, th; /* title */ int basew, baseh, incw, inch, maxw, maxh, minw, minh; int grav; - unsigned int border; long flags; + unsigned int border; Bool isfloat; + Bool ismax; + Bool *tags; Client *next; - Client *revert; + Client *prev; Window win; - Window title; + Window twin; }; -extern char *tags[TLast], stext[1024]; -extern int tsel, screen, sx, sy, sw, sh, bx, by, bw, bh, mw; +extern const char *tags[]; +extern char stext[1024]; +extern int screen, sx, sy, sw, sh, bx, by, bw, bh, mw; +extern unsigned int ntags, numlockmask; extern void (*handler[LASTEvent])(XEvent *); extern void (*arrange)(Arg *); extern Atom wmatom[WMLast], netatom[NetLast]; -extern Bool running, issel; +extern Bool running, issel, *seltag; extern Client *clients, *sel; extern Cursor cursor[CurLast]; extern DC dc; @@ -95,22 +79,16 @@ extern Window root, barwin; /* client.c */ extern void ban(Client *c); extern void focus(Client *c); -extern void focusnext(Arg *arg); -extern void focusprev(Arg *arg); extern Client *getclient(Window w); extern Client *getctitle(Window w); extern void gravitate(Client *c, Bool invert); -extern void higher(Client *c); extern void killclient(Arg *arg); -extern void lower(Client *c); extern void manage(Window w, XWindowAttributes *wa); -extern void maximize(Arg *arg); -extern void pop(Client *c); -extern void resize(Client *c, Bool inc, Corner sticky); +extern void resize(Client *c, Bool sizehints, Corner sticky); extern void setsize(Client *c); extern void settitle(Client *c); +extern void togglemax(Arg *arg); extern void unmanage(Client *c); -extern void zoom(Arg *arg); /* draw.c */ extern void drawall(); @@ -118,10 +96,11 @@ extern void drawstatus(); extern void drawtitle(Client *c); extern unsigned long getcolor(const char *colstr); extern void setfont(const char *fontstr); -extern unsigned int textw(char *text); +extern unsigned int textw(const char *text); /* event.c */ extern void grabkeys(); +extern void procevent(); /* main.c */ extern int getproto(Window w); @@ -130,16 +109,27 @@ extern void sendevent(Window w, Atom a, long value); extern int xerror(Display *dsply, XErrorEvent *ee); /* tag.c */ -extern void appendtag(Arg *arg); -extern void dofloat(Arg *arg); -extern void dotile(Arg *arg); -extern Client *getnext(Client *c, unsigned int t); -extern void heretag(Arg *arg); -extern void replacetag(Arg *arg); +extern void initrregs(); +extern Client *getnext(Client *c); +extern Client *getprev(Client *c); extern void settags(Client *c); -extern void view(Arg *arg); +extern void tag(Arg *arg); +extern void toggletag(Arg *arg); /* util.c */ extern void *emallocz(unsigned int size); extern void eprint(const char *errstr, ...); +extern void *erealloc(void *ptr, unsigned int size); extern void spawn(Arg *arg); + +/* view.c */ +extern void dofloat(Arg *arg); +extern void dotile(Arg *arg); +extern void focusnext(Arg *arg); +extern void focusprev(Arg *arg); +extern Bool isvisible(Client *c); +extern void restack(); +extern void togglemode(Arg *arg); +extern void toggleview(Arg *arg); +extern void view(Arg *arg); +extern void zoom(Arg *arg);