--- rxvt-unicode/src/rxvttoolkit.C 2007/06/26 00:40:19 1.68 +++ rxvt-unicode/src/rxvttoolkit.C 2007/08/17 22:01:33 1.71 @@ -445,12 +445,6 @@ screen = DefaultScreen (dpy); root = DefaultRootWindow (dpy); -#ifdef HAVE_AFTERIMAGE - ::dpy = dpy; /* init global var from libAfter... */ - asv = create_asvisual_for_id (dpy, screen, DefaultDepth (dpy,screen), - XVisualIDFromVisual (DefaultVisual (dpy, screen)), None, NULL); -#endif - assert (sizeof (xa_names) / sizeof (char *) == NUM_XA); XInternAtoms (dpy, (char **)xa_names, NUM_XA, False, xa); @@ -561,6 +555,9 @@ && xev.xproperty.atom == xa[XA_XIM_SERVERS]) im_change_check (); #endif + if (xev.type == MappingNotify) + XRefreshKeyboardMapping (&xev.xmapping); + for (int i = xw.size (); i--; ) { if (!xw[i]) @@ -748,8 +745,20 @@ else c.a = rgba::MAX_CC; + // parse the non-standard "#aarrggbb" format + if (name[0] == '#' && strlen (name) == 1+2+2+2+2 && 4 == sscanf (name+1, "%2hx%2hx%2hx%2hx%c", &c.a, &c.r, &c.g, &c.b, &eos)) + { + if (c.r) + c.r = (c.r << 8) | 0x0ff; + if (c.g) + c.g = (c.g << 8) | 0x0ff; + if (c.b) + c.b = (c.b << 8) | 0x0ff; + if (c.a) + c.a = (c.a << 8) | 0x0ff; + } // parse the non-standard "rgba:rrrr/gggg/bbbb/aaaa" format - if (strlen (name) != 4+5*4 || 4 != sscanf (name, "rgba:%4hx/%4hx/%4hx/%4hx%c", &c.r, &c.g, &c.b, &c.a, &eos)) + else if (strlen (name) != 4+5*4 || 4 != sscanf (name, "rgba:%4hx/%4hx/%4hx/%4hx%c", &c.r, &c.g, &c.b, &c.a, &eos)) { XColor xc, xc_exact;