X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Frendercolor.cc;h=5da218ea92f84f101620240714e270ab89be83e8;hb=9b1943f1feff3f1ed50f9a4039925a9956ada63c;hp=31823341c7e61bfae81851544ceca1eef2a59c43;hpb=a0738a0197b23d1bb2b2a58ae8d82a998fbf2d99;p=chaz%2Fopenbox diff --git a/otk/rendercolor.cc b/otk/rendercolor.cc index 31823341..5da218ea 100644 --- a/otk/rendercolor.cc +++ b/otk/rendercolor.cc @@ -5,6 +5,7 @@ #include "rendercolor.hh" #include "display.hh" #include "screeninfo.hh" +#include "rendercontrol.hh" #include @@ -27,8 +28,7 @@ RenderColor::RenderColor(int screen, unsigned char red, : _screen(screen), _red(red), _green(green), - _blue(blue), - _gc(0) + _blue(blue) { create(); } @@ -37,8 +37,7 @@ RenderColor::RenderColor(int screen, RGB rgb) : _screen(screen), _red(rgb.r), _green(rgb.g), - _blue(rgb.b), - _gc(0) + _blue(rgb.b) { create(); } @@ -61,16 +60,11 @@ void RenderColor::create() const ScreenInfo *info = display->screenInfo(_screen); XColor xcol; // convert from 0-0xff to 0-0xffff - xcol.red = _red << 8 | _red; - xcol.green = _green << 8 | _green; - xcol.blue = _blue << 8 | _blue; - xcol.pixel = 0; + xcol.red = (_red << 8) | _red; + xcol.green = (_green << 8) | _green; + xcol.blue = (_blue << 8) | _blue; - if (! XAllocColor(**display, info->colormap(), &xcol)) { - fprintf(stderr, "RenderColor: color alloc error: rgb:%x/%x/%x\n", - _red, _green, _blue); - xcol.pixel = 0; - } + display->renderControl(_screen)->allocateColor(&xcol); _pixel = xcol.pixel; gcv.foreground = _pixel; @@ -91,13 +85,16 @@ RenderColor::~RenderColor() unsigned long color = _blue | _green << 8 | _red << 16; CacheItem *item = _cache[_screen][color]; - assert(item); // it better be in the cache ... - + assert(item); // better be... + if (--item->count <= 0) { // remove from the cache XFreeGC(**display, _gc); _cache[_screen][color] = 0; delete item; + + const ScreenInfo *info = display->screenInfo(_screen); + XFreeColors(**display, info->colormap(), &_pixel, 1, 0); } }