X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2FGCCache.cc;h=75c7252a80d74ef39f3f972ae5678bb9b768e755;hb=45863e605c2dc7d605293331c26f688305c45fac;hp=57310a44168b46d9e570de7c7b573baede81b521;hpb=1775e867c408bbea2b7f197c0c40b26e586e9ef1;p=chaz%2Fopenbox diff --git a/src/GCCache.cc b/src/GCCache.cc index 57310a44..75c7252a 100644 --- a/src/GCCache.cc +++ b/src/GCCache.cc @@ -35,14 +35,25 @@ extern "C" { #include "Util.hh" +BGCCacheContext::~BGCCacheContext(void) { + if (gc) + XFreeGC(display->getXDisplay(), gc); +} + + void BGCCacheContext::set(const BColor &_color, const XFontStruct * const _font, - const int _function, const int _subwindow) { + const int _function, const int _subwindow, + int _linewidth) { XGCValues gcv; pixel = gcv.foreground = _color.pixel(); function = gcv.function = _function; subwindow = gcv.subwindow_mode = _subwindow; - unsigned long mask = GCForeground | GCFunction | GCSubwindowMode; + linewidth = gcv.line_width = _linewidth; + gcv.cap_style = CapProjecting; + + unsigned long mask = GCForeground | GCFunction | GCSubwindowMode | + GCLineWidth | GCCapStyle; if (_font) { fontid = gcv.font = _font->fid; @@ -125,7 +136,7 @@ void BGCCache::release(BGCCacheContext *ctx) { BGCCacheItem *BGCCache::find(const BColor &_color, const XFontStruct * const _font, - int _function, int _subwindow) { + int _function, int _subwindow, int _linewidth) { const unsigned long pixel = _color.pixel(); const unsigned int screen = _color.screen(); const int key = _color.red() ^ _color.green() ^ _color.blue(); @@ -136,7 +147,8 @@ BGCCacheItem *BGCCache::find(const BColor &_color, // this will either loop 8 times then return/abort or it will stop matching while (c->ctx && (c->ctx->pixel != pixel || c->ctx->function != _function || - c->ctx->subwindow != _subwindow || c->ctx->screen != screen)) { + c->ctx->subwindow != _subwindow || c->ctx->screen != screen || + c->ctx->linewidth != _linewidth)) { if (i < 7) { prev = c; c = cache[ ++k ]; @@ -145,7 +157,7 @@ BGCCacheItem *BGCCache::find(const BColor &_color, } if (c->count == 0 && c->ctx->screen == screen) { // use this cache item - c->ctx->set(_color, _font, _function, _subwindow); + c->ctx->set(_color, _font, _function, _subwindow, _linewidth); c->ctx->used = true; c->count = 1; c->hits = 1; @@ -169,7 +181,7 @@ BGCCacheItem *BGCCache::find(const BColor &_color, } } else { c->ctx = nextContext(screen); - c->ctx->set(_color, _font, _function, _subwindow); + c->ctx->set(_color, _font, _function, _subwindow, _linewidth); c->ctx->used = true; c->count = 1; c->hits = 1;