- XFreeFont(getBaseDisplay().getXDisplay(), resource.tstyle.font);
- if (resource.root_command != NULL)
- delete [] resource.root_command;
-
- XFreeGC(getBaseDisplay().getXDisplay(), opGC);
-
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.wstyle.l_text_focus_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.wstyle.l_text_unfocus_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.wstyle.b_pic_focus_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.wstyle.b_pic_unfocus_gc);
-
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.mstyle.t_text_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.mstyle.f_text_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.mstyle.h_text_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.mstyle.d_text_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.mstyle.hilite_gc);
-
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.tstyle.l_text_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.tstyle.w_text_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.tstyle.c_text_gc);
- XFreeGC(getBaseDisplay().getXDisplay(),
- resource.tstyle.b_pic_gc);
-}
-
-void BScreen::readDatabaseTexture(const char *rname, const char *rclass,
- BTexture *texture,
- unsigned long default_pixel)
-{
- std::string s;
-
- if (resource.styleconfig.getValue(rname, rclass, s))
- image_control->parseTexture(texture, s.c_str());
- else
- texture->setTexture(BImage_Solid | BImage_Flat);
-
- if (texture->getTexture() & BImage_Solid) {
- int clen = strlen(rclass) + 32, nlen = strlen(rname) + 32;
-
- char *colorclass = new char[clen], *colorname = new char[nlen];
-
- sprintf(colorclass, "%s.Color", rclass);
- sprintf(colorname, "%s.color", rname);
-
- readDatabaseColor(colorname, colorclass, texture->getColor(),
- default_pixel);
-
-#ifdef INTERLACE
- sprintf(colorclass, "%s.ColorTo", rclass);
- sprintf(colorname, "%s.colorTo", rname);
-
- readDatabaseColor(colorname, colorclass, texture->getColorTo(),
- default_pixel);
-#endif // INTERLACE
-
- delete [] colorclass;
- delete [] colorname;
-
- if ((! texture->getColor()->isAllocated()) ||
- (texture->getTexture() & BImage_Flat))
- return;
-
- XColor xcol;
-
- xcol.red = (unsigned int) (texture->getColor()->getRed() +
- (texture->getColor()->getRed() >> 1));
- if (xcol.red >= 0xff) xcol.red = 0xffff;
- else xcol.red *= 0xff;
- xcol.green = (unsigned int) (texture->getColor()->getGreen() +
- (texture->getColor()->getGreen() >> 1));
- if (xcol.green >= 0xff) xcol.green = 0xffff;
- else xcol.green *= 0xff;
- xcol.blue = (unsigned int) (texture->getColor()->getBlue() +
- (texture->getColor()->getBlue() >> 1));
- if (xcol.blue >= 0xff) xcol.blue = 0xffff;
- else xcol.blue *= 0xff;
-
- if (! XAllocColor(getBaseDisplay().getXDisplay(),
- getColormap(), &xcol))
- xcol.pixel = 0;
-
- texture->getHiColor()->setPixel(xcol.pixel);
-
- xcol.red =
- (unsigned int) ((texture->getColor()->getRed() >> 2) +
- (texture->getColor()->getRed() >> 1)) * 0xff;
- xcol.green =
- (unsigned int) ((texture->getColor()->getGreen() >> 2) +
- (texture->getColor()->getGreen() >> 1)) * 0xff;
- xcol.blue =
- (unsigned int) ((texture->getColor()->getBlue() >> 2) +
- (texture->getColor()->getBlue() >> 1)) * 0xff;
-
- if (! XAllocColor(getBaseDisplay().getXDisplay(),
- getColormap(), &xcol))
- xcol.pixel = 0;
-
- texture->getLoColor()->setPixel(xcol.pixel);
- } else if (texture->getTexture() & BImage_Gradient) {
- int clen = strlen(rclass) + 10, nlen = strlen(rname) + 10;
-
- char *colorclass = new char[clen], *colorname = new char[nlen],
- *colortoclass = new char[clen], *colortoname = new char[nlen];
-
- sprintf(colorclass, "%s.Color", rclass);
- sprintf(colorname, "%s.color", rname);
-
- sprintf(colortoclass, "%s.ColorTo", rclass);
- sprintf(colortoname, "%s.colorTo", rname);
-
- readDatabaseColor(colorname, colorclass, texture->getColor(),
- default_pixel);
- readDatabaseColor(colortoname, colortoclass, texture->getColorTo(),
- default_pixel);
-
- delete [] colorclass;
- delete [] colorname;
- delete [] colortoclass;
- delete [] colortoname;
- }