--- rxvt-unicode/src/rxvttoolkit.h 2007/12/14 04:26:23 1.37 +++ rxvt-unicode/src/rxvttoolkit.h 2010/01/24 21:53:13 1.48 @@ -31,7 +31,6 @@ #include "ev_cpp.h" -#include "rxvtlib.h" #include "rxvtutil.h" #include "callback.h" @@ -62,6 +61,7 @@ XA_NET_WM_NAME, XA_NET_WM_ICON_NAME, XA_NET_WM_PING, + XA_NET_WM_ICON, #endif #if USE_XIM XA_WM_LOCALE_NAME, @@ -76,7 +76,7 @@ XA_XEMBED_INFO, #endif #if !ENABLE_MINIMAL - // these are usually allocated by other subsystens, but we do it + // these are usually allocated by other subsystems, but we do it // here to avoid a server roundtrip. XA_SCREEN_RESOURCES, XA_XDCCC_LINEAR_RGB_CORRECTION, @@ -221,7 +221,8 @@ { event_vec xw; - ev::io x_ev; void x_cb (ev::io &w, int revents); + ev::prepare flush_ev; void flush_cb (ev::prepare &w, int revents); + ev::io x_ev ; void x_cb (ev::io &w, int revents); #ifdef USE_XIM refcache xims; @@ -236,6 +237,7 @@ int screen; Window root; rxvt_term *selection_owner; + rxvt_term *clipboard_owner; Atom xa[NUM_XA]; bool is_local; #ifdef POINTER_BLANK @@ -248,9 +250,13 @@ void ref_next (); ~rxvt_display (); - void flush (); + void flush () + { + flush_ev.start (); + } + Atom atom (const char *name); - void set_selection_owner (rxvt_term *owner); + void set_selection_owner (rxvt_term *owner, bool clipboard); void reg (xevent_watcher *w); void unreg (xevent_watcher *w); @@ -265,7 +271,8 @@ }; #ifdef USE_XIM -struct im_watcher : rxvt_watcher, callback { +struct im_watcher : rxvt_watcher, callback +{ void start (rxvt_display *display) { display->reg (this); @@ -327,6 +334,15 @@ bool operator == (const rxvt_color &b) const { return Pixel (*this) == Pixel (b); } bool operator != (const rxvt_color &b) const { return Pixel (*this) != Pixel (b); } + bool is_opaque () const + { +#if XFT + return c.color.alpha == rgba::MAX_CC; +#else + return 1; +#endif + } + bool alloc (rxvt_screen *screen, const rgba &color); void free (rxvt_screen *screen);