--- rxvt-unicode/src/rxvttoolkit.h 2006/02/01 18:36:48 1.21 +++ rxvt-unicode/src/rxvttoolkit.h 2007/06/08 20:04:12 1.30 @@ -1,6 +1,25 @@ -/* - * rxvttoolkit.h - provide toolkit-functionality for rxvt. - */ +/*----------------------------------------------------------------------* + * File: rxvttoolkit.h - provide toolkit-functionality for rxvt. + *----------------------------------------------------------------------* + * + * All portions of code are copyright by their respective author/s. + * Copyright (c) 2003-2006 Marc Lehmann + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + *----------------------------------------------------------------------*/ + #ifndef RXVT_TOOLKIT_H #define RXVT_TOOLKIT_H @@ -107,6 +126,33 @@ ///////////////////////////////////////////////////////////////////////////// +struct rxvt_screen; + +struct rxvt_drawable { + rxvt_screen *screen; + Drawable drawable; + operator Drawable() { return drawable; } + +#if XFT + XftDraw *xftdrawable; + operator XftDraw *(); +#endif + + rxvt_drawable (rxvt_screen *screen, Drawable drawable) + : screen(screen), +#if XFT + xftdrawable(0), +#endif + drawable(drawable) + { } + +#if XFT + ~rxvt_drawable (); +#endif +}; + +///////////////////////////////////////////////////////////////////////////// + #ifdef USE_XIM struct rxvt_xim : refcounted { void destroy (); @@ -123,16 +169,30 @@ struct rxvt_screen { rxvt_display *display; - Display *xdisp; + Display *dpy; int depth; Visual *visual; Colormap cmap; +#if XFT + // scratch pixmap + rxvt_drawable *scratch_area; + int scratch_w, scratch_h; + + rxvt_drawable &scratch_drawable (int w, int h); + + rxvt_screen (); +#endif + void set (rxvt_display *disp); - void set (rxvt_display *disp, int bitdepth); + void select_visual (int bitdepth); void clear (); }; +#ifdef HAVE_AFTERIMAGE +struct ASVisual; +#endif + struct rxvt_display : refcounted { io_manager_vec xw; @@ -147,20 +207,21 @@ #endif //public - Display *display; + Display *dpy; int screen; Window root; +#ifdef HAVE_AFTERIMAGE + struct ASVisual *asv; +#endif rxvt_term *selection_owner; Atom xa[NUM_XA]; -#ifndef NO_SLOW_LINK_SUPPORT bool is_local; -#endif #ifdef POINTER_BLANK Cursor blank_cursor; #endif rxvt_display (const char *id); - XrmDatabase get_resources (); + XrmDatabase get_resources (bool refresh); bool ref_init (); void ref_next (); ~rxvt_display (); @@ -182,10 +243,10 @@ }; #ifdef USE_XIM -struct im_watcher : watcher, callback0 { - template - im_watcher (O1 *object, void (O2::*method) ()) - : callback0 (object,method) +struct im_watcher : watcher, callback { + template + im_watcher (O object, M method) + : callback (object, method) { } void start (rxvt_display *display) @@ -199,12 +260,12 @@ }; #endif -struct xevent_watcher : watcher, callback1 { +struct xevent_watcher : watcher, callback { Window window; - template - xevent_watcher (O1 *object, void (O2::*method) (XEvent &)) - : callback1 (object,method) + template + xevent_watcher (O object, M method) + : callback (object, method) { } void start (rxvt_display *display, Window window)