continued, distinction of Draw and DDC is bad, needs to be merged - dwm - dynamic window manager HTML git clone https://git.parazyd.org/dwm DIR Log DIR Files DIR Refs DIR README DIR LICENSE --- DIR commit 0a673ad7a37f3a1bdda7cef316bda300f8f181eb DIR parent 3aabc08ede9c6496720124be8ee34c8b39735239 HTML Author: anselm@garbe.us <unknown> Date: Sun, 18 Nov 2012 17:26:12 +0100 continued, distinction of Draw and DDC is bad, needs to be merged Diffstat: M draw.c | 17 +++++++++++------ M draw.h | 4 +++- 2 files changed, 14 insertions(+), 7 deletions(-) --- DIR diff --git a/draw.c b/draw.c @@ -5,12 +5,16 @@ #include "draw.h" Draw * -draw_create(Display *dpy, Window win, unsigned int w, unsigned int h) { +draw_create(Display *dpy, int screen, Window win, unsigned int w, unsigned int h) { Draw *draw = (Draw *)calloc(1, sizeof(Draw)); + draw->dpy = dpy; + draw->screen = screen; + draw->win = win; draw->w = w; draw->h = h; - /* TODO: drawable creation */ - /* TODO: gc allocation */ + draw->drawable = XCreatePixmap(dpy, win, w, h, DefaultDepth(dpy, screen)); + draw->gc = XCreateGC(dpy, win, 0, NULL); + XSetLineAttributes(dpy, draw->gc, 1, LineSolid, CapButt, JoinMiter); return draw; } @@ -20,13 +24,14 @@ draw_resize(Draw *draw, unsigned int w, unsigned int h) { return; draw->w = w; draw->h = h; - /* TODO: resize drawable */ + XFreePixmap(draw->dpy, draw->drawable); + draw->drawable = XCreatePixmap(draw->dpy, draw->win, w, h, DefaultDepth(draw->dpy, draw->screen)); } void draw_free(Draw *draw) { - /* TODO: deallocate DDCs */ - /* TODO: deallocate drawable */ + XFreePixmap(draw->dpy, draw->drawable); + XFreeGC(draw->dpy, draw->gc); free(draw); } DIR diff --git a/draw.h b/draw.h @@ -7,6 +7,8 @@ typedef struct _XDraw Draw; struct _XDraw { unsigned int w, h; Display *dpy; + int screen; + Window win; Drawable drawable; GC gc; DDC *dc; @@ -46,7 +48,7 @@ typedef struct { } TextExtents; /* Drawable abstraction */ -Draw *draw_create(Display *dpy, Window win, unsigned int w, unsigned int h); +Draw *draw_create(Display *dpy, int screen, Window win, unsigned int w, unsigned int h); void draw_resize(Draw *draw, unsigned int w, unsigned int h); void draw_free(Draw *draw);