JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
implemented regexp matching for rules
[dwm.git] / dwm.h
diff --git a/dwm.h b/dwm.h
index de88527..9670c68 100644 (file)
--- a/dwm.h
+++ b/dwm.h
@@ -11,6 +11,7 @@
 #define BGCOLOR                                "#0a2c2d"
 #define FGCOLOR                                "#ddeeee"
 #define BORDERCOLOR                    "#176164"
+#define MODKEY                          Mod1Mask /* Mod4Mask */
 /*
 #define BGCOLOR                                "#666699"
 #define FGCOLOR                                "#eeeeee"
@@ -25,11 +26,10 @@ enum { Tscratch, Tdev, Twww, Twork, TLast };
 /********** CUSTOMIZE **********/
 
 typedef union Arg Arg;
-typedef struct DC DC;
 typedef struct Client Client;
+typedef enum Corner Corner;
+typedef struct DC DC;
 typedef struct Fnt Fnt;
-typedef struct Key Key;
-typedef struct Rule Rule;
 
 union Arg {
        const char **argv;
@@ -43,6 +43,8 @@ enum { WMProtocols, WMDelete, WMLast };
 /* cursor */
 enum { CurNormal, CurResize, CurMove, CurLast };
 
+enum Corner { TopLeft, TopRight, BotLeft, BotRight };
+
 struct Fnt {
        int ascent;
        int descent;
@@ -65,8 +67,10 @@ struct Client {
        char name[256];
        char *tags[TLast];
        int proto;
-       int x, y, w, h;
-       int tx, ty, tw, th;
+       int *x, *y, *w, *h; /* current geom */
+       int bx, by, bw, bh; /* title bar */
+       int fx, fy, fw, fh; /* floating geom */
+       int tx, ty, tw, th; /* tiled geom */
        int basew, baseh, incw, inch, maxw, maxh, minw, minh;
        int grav;
        unsigned int border;
@@ -78,20 +82,6 @@ struct Client {
        Window title;
 };
 
-struct Rule {
-       const char *class;
-       const char *instance;
-       char *tags[TLast];
-       Bool isfloat;
-};
-
-struct Key {
-       unsigned long mod;
-       KeySym keysym;
-       void (*func)(Arg *arg);
-       Arg arg;
-};
-
 extern char *tags[TLast], stext[1024];
 extern int tsel, screen, sx, sy, sw, sh, bx, by, bw, bh, mw;
 extern void (*handler[LASTEvent])(XEvent *);
@@ -102,7 +92,6 @@ extern Client *clients, *sel;
 extern Cursor cursor[CurLast];
 extern DC dc;
 extern Display *dpy;
-extern Key key[];
 extern Window root, barwin;
 
 /* client.c */
@@ -118,7 +107,9 @@ extern void killclient(Arg *arg);
 extern void lower(Client *c);
 extern void manage(Window w, XWindowAttributes *wa);
 extern void maximize(Arg *arg);
-extern void resize(Client *c, Bool inc);
+extern void pop(Client *c);
+extern void resize(Client *c, Bool inc, Corner sticky);
+extern void setgeom(Client *c);
 extern void setsize(Client *c);
 extern void settitle(Client *c);
 extern void unmanage(Client *c);
@@ -145,7 +136,8 @@ extern int xerror(Display *dsply, XErrorEvent *ee);
 extern void appendtag(Arg *arg);
 extern void dofloat(Arg *arg);
 extern void dotile(Arg *arg);
-extern Client *getnext(Client *c);
+extern Client *getnext(Client *c, unsigned int t);
+extern void heretag(Arg *arg);
 extern void replacetag(Arg *arg);
 extern void settags(Client *c);
 extern void view(Arg *arg);