X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=dwm.c;h=0071379da2ff58a5ab26a10f9847b4aae7229514;hb=69439715c09ac36fe94f3cb7b1ed87149fc5ecff;hp=f1d59f955d5a62f4d9fe0bd0e9400f3046a48a25;hpb=d05d09b205e1f1b045cf8da7f0b83a2bee100be6;p=dwm.git diff --git a/dwm.c b/dwm.c index f1d59f9..0071379 100644 --- a/dwm.c +++ b/dwm.c @@ -96,7 +96,8 @@ typedef struct { const char *symbol; void (*arrange)(void); Bool isfloating; -} Layout; +} Layout; /* TODO: layout should keep an auxilliary pointer to its Geometry, + instead of having all those layout specific vars globally */ typedef struct { const char *prop; @@ -160,6 +161,7 @@ void restack(void); void run(void); void scan(void); void setclientstate(Client *c, long state); +void setdefaultgeoms(void); void setlayout(const char *arg); void setup(void); void spawn(const char *arg); @@ -177,6 +179,7 @@ void toggleview(const char *arg); void unban(Client *c); void unmanage(Client *c); void unmapnotify(XEvent *e); +void updatebarpos(void); void updatesizehints(Client *c); void updatetitle(Client *c); void updatewmhints(Client *c); @@ -220,6 +223,7 @@ Display *dpy; DC dc = {0}; Layout *lt = NULL; Window root, barwin; +void (*setgeoms)(void) = setdefaultgeoms; /* configuration, allows nested code to access above variables */ #include "config.h" @@ -404,11 +408,8 @@ configurenotify(XEvent *e) { XConfigureEvent *ev = &e->xconfigure; if(ev->window == root && (ev->width != sw || ev->height != sh)) { - sw = ev->width; - sh = ev->height; - XFreePixmap(dpy, dc.drawable); - dc.drawable = XCreatePixmap(dpy, root, bw, bh, DefaultDepth(dpy, screen)); - XMoveResizeWindow(dpy, barwin, bx, by, bw, bh); + setgeoms(); + updatebarpos(); arrange(); } } @@ -1379,6 +1380,46 @@ setclientstate(Client *c, long state) { } void +setdefaultgeoms(void) { + + /* screen dimensions */ + sx = 0; + sy = 0; + sw = DisplayWidth(dpy, screen); + sh = DisplayHeight(dpy, screen); + + /* bar position */ + bx = sx; + by = sy; + bw = sw; + bh = dc.font.height + 2; + + /* window area */ + wx = sx; + wy = sy + bh; + ww = sw; + wh = sh - bh; + + /* master area */ + mx = wx; + my = wy; + mw = ((float)sw) * 0.55; + mh = wh; + + /* tile area */ + tx = mx + mw; + ty = wy; + tw = ww - mw; + th = wh; + + /* monocle area */ + mox = wx; + moy = wy; + mow = ww; + moh = wh; +} + +void setlayout(const char *arg) { static Layout *revert = 0; unsigned int i; @@ -1410,10 +1451,10 @@ setup(void) { /* init screen */ screen = DefaultScreen(dpy); root = RootWindow(dpy, screen); - sx = 0; - sy = 0; - sw = DisplayWidth(dpy, screen); - sh = DisplayHeight(dpy, screen); + initfont(FONT); + + /* apply default geometries */ + setgeoms(); /* init atoms */ wmatom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False); @@ -1436,7 +1477,7 @@ setup(void) { dc.sel[ColBG] = getcolor(SELBGCOLOR); dc.sel[ColFG] = getcolor(SELFGCOLOR); initfont(FONT); - dc.h = bh = dc.font.height + 2; + dc.h = bh; dc.drawable = XCreatePixmap(dpy, root, DisplayWidth(dpy, screen), bh, DefaultDepth(dpy, screen)); dc.gc = XCreateGC(dpy, root, 0, 0); XSetLineAttributes(dpy, dc.gc, 1, LineSolid, CapButt, JoinMiter); @@ -1451,35 +1492,6 @@ setup(void) { /* init layouts */ lt = &layouts[0]; - /* bar position */ - bx = BX; - by = BY; - bw = BW; - - /* window area */ - wx = WX; - wy = WY; - ww = WW; - wh = WH; - - /* master area */ - mx = MX; - my = MY; - mw = MW; - mh = MH; - - /* tile area */ - tx = TX; - ty = TY; - tw = TW; - th = TH; - - /* monocle area */ - mox = MOX; - moy = MOY; - mow = MOW; - moh = MOH; - /* init bar */ for(blw = i = 0; i < LENGTH(layouts); i++) { i = textw(layouts[i].symbol); @@ -1729,6 +1741,15 @@ unmapnotify(XEvent *e) { } void +updatebarpos(void) { + + if(dc.drawable != 0) + XFreePixmap(dpy, dc.drawable); + dc.drawable = XCreatePixmap(dpy, root, bw, bh, DefaultDepth(dpy, screen)); + XMoveResizeWindow(dpy, barwin, bx, by, bw, bh); +} + +void updatesizehints(Client *c) { long msize; XSizeHints size;