--- rxvt-unicode/src/rxvttoolkit.h 2006/01/25 21:03:04 1.12 +++ rxvt-unicode/src/rxvttoolkit.h 2006/01/31 00:25:16 1.16 @@ -30,6 +30,11 @@ XA_WM_PROTOCOLS, XA_WM_DELETE_WINDOW, XA_CLIPBOARD, + XA_AVERAGE_WIDTH, + XA_WEIGHT_NAME, + XA_SLANT, + XA_CHARSET_REGISTRY, + XA_CHARSET_ENCODING, #if ENABLE_FRILLS XA_MOTIF_WM_HINTS, #endif @@ -51,6 +56,24 @@ XA_XEMBED, XA_XEMBED_INFO, #endif +#if !ENABLE_MINIMAL + // these are usually allocated by other subsystens, but we do it + // here to avoid a server roundtrip. + XA_SCREEN_RESOURCES, + XA_XDCCC_LINEAR_RGB_CORRECTION, + XA_XDCCC_LINEAR_RGB_MATRICES, + XA_WM_COLORMAP_WINDOWS, + XA_WM_STATE, + XA_cursor, +# if USE_XIM + // various selection targets used by XIM + XA_TRANSPORT, + XA_LOCALES, + XA__XIM_PROTOCOL, + XA__XIM_XCONNECT, + XA__XIM_MOREDATA, +# endif +#endif NUM_XA }; @@ -106,7 +129,7 @@ Colormap cmap; void set (rxvt_display *disp); - void set (rxvt_display *disp, int depth); + void set (rxvt_display *disp, int bitdepth); void clear (); }; @@ -201,6 +224,19 @@ typedef unsigned long Pixel; +struct rxvt_rgba { + unsigned short r, g, b, a; + + enum { MIN_CC = 0x0000, MAX_CC = 0xffff }; + + rxvt_rgba () + { } + + rxvt_rgba (unsigned short r, unsigned short g, unsigned short b, unsigned short a = MAX_CC) + : r(r), g(g), b(b), a(a) + { } +}; + struct rxvt_color { #if XFT XftColor c; @@ -213,16 +249,16 @@ bool operator == (const rxvt_color &b) const { return Pixel (*this) == Pixel (b); } bool operator != (const rxvt_color &b) const { return Pixel (*this) != Pixel (b); } - void get (rxvt_screen *screen, unsigned short &cr, unsigned short &cg, unsigned short &cb); + bool alloc (rxvt_screen *screen, rxvt_rgba rgba); + void free (rxvt_screen *screen); + + void get (rxvt_screen *screen, rxvt_rgba &rgba); - bool set (rxvt_screen *screen, Pixel p); bool set (rxvt_screen *screen, const char *name); - bool set (rxvt_screen *screen, unsigned short cr, unsigned short cg, unsigned short cb); + bool set (rxvt_screen *screen, rxvt_rgba rgba); rxvt_color fade (rxvt_screen *screen, int percent); // fades to black rxvt_color fade (rxvt_screen *screen, int percent, rxvt_color &fadeto); - - void free (rxvt_screen *screen); }; #endif