X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Frendercolor.cc;h=eb3ffdbc3e3cf3957621ec3fa1501a9df360d5aa;hb=3fe7bded58fb82fd2c1c2a5f9ad2e8f453fa0609;hp=b5e037d382272e1a9cd026b09c31a8b0b8625f66;hpb=033e9843bcec8340c9e657fe0f0519f86075424b;p=chaz%2Fopenbox diff --git a/otk/rendercolor.cc b/otk/rendercolor.cc index b5e037d3..eb3ffdbc 100644 --- a/otk/rendercolor.cc +++ b/otk/rendercolor.cc @@ -47,6 +47,8 @@ void RenderColor::create() { unsigned long color = _blue | _green << 8 | _red << 16; + printf("CREATE COLOR: %lx\n", color); + // try get a gc from the cache CacheItem *item = _cache[_screen][color]; @@ -79,17 +81,21 @@ void RenderColor::create() assert(_gc); // insert into the cache - _cache[_screen][color] = new CacheItem(_gc); + item = new CacheItem(_gc); + _cache[_screen][color] = item; + ++item->count; } } RenderColor::~RenderColor() { unsigned long color = _blue | _green << 8 | _red << 16; - + CacheItem *item = _cache[_screen][color]; assert(item); // it better be in the cache ... + printf("DESTROY COLOR: %lx %d\n", color, item->count); + if (--item->count <= 0) { // remove from the cache XFreeGC(**display, _gc);