]> Dogcows Code - chaz/openbox/blobdiff - render/mask.c
yet more focus fixings. RevertToPointerRoot could mess things up focusing a client...
[chaz/openbox] / render / mask.c
index e1a18933143993a33a10676a93597830e58755f2..26059ca6e581bb1c6696a9be976b546d5850eaa9 100644 (file)
@@ -6,6 +6,8 @@ pixmap_mask *pixmap_mask_new(int w, int h, char *data)
     pixmap_mask *m = g_new(pixmap_mask, 1);
     m->w = w;
     m->h = h;
+    /* round up to nearest byte */
+    m->data = g_memdup(data, (w * h + 7) / 8);
     m->mask = XCreateBitmapFromData(ob_display, ob_root, data, w, h);
     return m;
 }
@@ -13,6 +15,7 @@ pixmap_mask *pixmap_mask_new(int w, int h, char *data)
 void pixmap_mask_free(pixmap_mask *m)
 {
     XFreePixmap(ob_display, m->mask);
+    g_free(m->data);
     g_free(m);
 }
 
@@ -39,3 +42,14 @@ void mask_draw(Pixmap p, TextureMask *m, Rect *position)
     XSetClipMask(ob_display, m->color->gc, None);
     XSetClipOrigin(ob_display, m->color->gc, 0, 0);
 }
+
+pixmap_mask *pixmap_mask_copy(pixmap_mask *src)
+{
+    pixmap_mask *m = g_new(pixmap_mask, 1);
+    m->w = src->w;
+    m->h = src->h;
+    /* round up to nearest byte */
+    m->data = g_memdup(src->data, (src->w * src->h + 7) / 8);
+    m->mask = XCreateBitmapFromData(ob_display, ob_root, m->data, m->w, m->h);
+    return m;
+}
This page took 0.02229 seconds and 4 git commands to generate.