all repos — openbox @ 35e3370651be572c710a09f6bb6190207c5dbd01

openbox fork - make it a bit more like ryudo

add an id to colors for debugging purposes
Dana Jansens danakj@orodu.net
commit

35e3370651be572c710a09f6bb6190207c5dbd01

parent

7833271d1461d9b0e02ffc804cd4e0156fd8faf4

2 files changed, 18 insertions(+), 0 deletions(-)

jump to
M render/color.crender/color.c

@@ -54,6 +54,11 @@ }

return RrColorNew(inst, xcol.red >> 8, xcol.green >> 8, xcol.blue >> 8); } +/*#define NO_COLOR_CACHE*/ +#ifdef DEBUG +gint id; +#endif + RrColor *RrColorNew(const RrInstance *inst, gint r, gint g, gint b) { /* this should be replaced with something far cooler */

@@ -62,9 +67,11 @@ XColor xcol;

gint key; key = (r << 24) + (g << 16) + (b << 8); +#ifndef NO_COLOR_CACHE if ((out = g_hash_table_lookup(RrColorHash(inst), &key))) { out->refcount++; } else { +#endif xcol.red = (r << 8) | r; xcol.green = (g << 8) | g; xcol.blue = (b << 8) | b;

@@ -78,8 +85,13 @@ out->gc = None;

out->pixel = xcol.pixel; out->key = key; out->refcount = 1; +#ifdef DEBUG + out->id = id++; +#endif +#ifndef NO_COLOR_CACHE g_hash_table_insert(RrColorHash(inst), &out->key, out); } +#endif } return out; }

@@ -88,8 +100,10 @@ void RrColorFree(RrColor *c)

{ if (c) { if (--c->refcount < 1) { +#ifndef NO_COLOR_CACHE g_assert(g_hash_table_lookup(RrColorHash(c->inst), &c->key)); g_hash_table_remove(RrColorHash(c->inst), &c->key); +#endif if (c->pixel) XFreeColors(RrDisplay(c->inst), RrColormap(c->inst), &c->pixel, 1, 0); if (c->gc) XFreeGC(RrDisplay(c->inst), c->gc);
M render/color.hrender/color.h

@@ -37,6 +37,10 @@ GC gc;

gint key; gint refcount; + +#ifdef DEBUG + gint id; +#endif }; void RrColorAllocateGC(RrColor *in);