X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=util%2Fbsetroot.cc;h=6f8e122d8995c7a89fcf302e7334068ee1ecd023;hb=616fa39a1609809cecc628627139b8a96eef2989;hp=470ca7b3ead64d6d89cb67fb7dcf25212603ce46;hpb=3531afa1cca6fe135013b925999d3b62291c0acb;p=chaz%2Fopenbox diff --git a/util/bsetroot.cc b/util/bsetroot.cc index 470ca7b3..6f8e122d 100644 --- a/util/bsetroot.cc +++ b/util/bsetroot.cc @@ -1,5 +1,5 @@ // -*- mode++; indent-tabs-mode: nil; c-basic-offset: 2; -*- -// Window.cc for Blackbox - an X11 Window manager +// bsetroot.cc for Blackbox - an X11 Window manager // Copyright (c) 2001 - 2002 Sean 'Shaleh' Perry // Copyright (c) 1997 - 2000, 2002 Brad Hughes // @@ -49,8 +49,8 @@ extern "C" { I18n i18n; bsetroot::bsetroot(int argc, char **argv, char *dpy_name) - : BaseDisplay(argv[0], dpy_name) -{ + : BaseDisplay(argv[0], dpy_name) { + grad = fore = back = (char *) 0; bool mod = False, sol = False, grd = False; @@ -97,8 +97,9 @@ bsetroot::bsetroot(int argc, char **argv, char *dpy_name) } else if (! strcmp("-display", argv[i])) { // -display passed through tests ealier... we just skip it now i++; - } else + } else { usage(); + } } if ((mod + sol + grd) != True) { @@ -150,11 +151,19 @@ void bsetroot::setPixmapProperty(int screen, Pixmap pixmap) { /* Clear out the old pixmap */ XGetWindowProperty(getXDisplay(), screen_info->getRootWindow(), - rootpmap_id, 0L, 1L, False, XA_PIXMAP, - &type, &format, &length, &after, &data); - if (type == XA_PIXMAP && format == 32) { - XKillClient(getXDisplay(), *((Pixmap *) data)); - XSync(getXDisplay(), False); + rootpmap_id, 0L, 1L, False, AnyPropertyType, + &type, &format, &length, &after, &data); + + if ((type == XA_PIXMAP) && (format == 32) && (length == 1)) { + unsigned char* data_esetroot = 0; + XGetWindowProperty(getXDisplay(), screen_info->getRootWindow(), + esetroot_id, 0L, 1L, False, AnyPropertyType, + &type, &format, &length, &after, &data_esetroot); + if (data && data_esetroot && *((Pixmap *) data)) { + XKillClient(getXDisplay(), *((Pixmap *) data)); + XSync(getXDisplay(), False); + XFree(data_esetroot); + } XFree(data); } @@ -332,7 +341,7 @@ void bsetroot::usage(int exit_code) { int main(int argc, char **argv) { char *display_name = (char *) 0; - i18n.openCatalog("blackbox.cat"); + i18n.openCatalog("openbox.cat"); for (int i = 1; i < argc; i++) { if (! strcmp(argv[i], "-display")) {