ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvttoolkit.h
(Generate patch)

Comparing rxvt-unicode/src/rxvttoolkit.h (file contents):
Revision 1.24 by root, Sat Feb 18 14:14:43 2006 UTC vs.
Revision 1.44 by root, Sat Jan 26 10:15:20 2008 UTC

1/* 1/*----------------------------------------------------------------------*
2 * rxvttoolkit.h - provide toolkit-functionality for rxvt. 2 * File: rxvttoolkit.h - provide toolkit-functionality for rxvt.
3 *----------------------------------------------------------------------*
3 */ 4 *
5 * All portions of code are copyright by their respective author/s.
6 * Copyright (c) 2003-2006 Marc Lehmann <pcg@goof.com>
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 *----------------------------------------------------------------------*/
22
4#ifndef RXVT_TOOLKIT_H 23#ifndef RXVT_TOOLKIT_H
5#define RXVT_TOOLKIT_H 24#define RXVT_TOOLKIT_H
6 25
7#include <X11/Xlib.h> 26#include <X11/Xlib.h>
8 27
9#if XFT 28#if XFT
10# include <X11/Xft/Xft.h> 29# include <X11/Xft/Xft.h>
11#endif 30#endif
12 31
13#include "iom.h" 32#include "ev_cpp.h"
14 33
15#include "rxvtlib.h"
16#include "rxvtutil.h" 34#include "rxvtutil.h"
17 35
18#include "callback.h" 36#include "callback.h"
19 37
20// see rxvttoolkit.C:xa_names, which must be kept in sync 38// see rxvttoolkit.C:xa_names, which must be kept in sync
46#endif 64#endif
47#if USE_XIM 65#if USE_XIM
48 XA_WM_LOCALE_NAME, 66 XA_WM_LOCALE_NAME,
49 XA_XIM_SERVERS, 67 XA_XIM_SERVERS,
50#endif 68#endif
51#if TRANSPARENT 69#if ENABLE_TRANSPARENCY
52 XA_XROOTPMAP_ID, 70 XA_XROOTPMAP_ID,
53 XA_ESETROOT_PMAP_ID, 71 XA_ESETROOT_PMAP_ID,
54#endif 72#endif
55#if ENABLE_XEMBED 73#if ENABLE_XEMBED
56 XA_XEMBED, 74 XA_XEMBED,
57 XA_XEMBED_INFO, 75 XA_XEMBED_INFO,
58#endif 76#endif
59#if !ENABLE_MINIMAL 77#if !ENABLE_MINIMAL
60 // these are usually allocated by other subsystens, but we do it 78 // these are usually allocated by other subsystems, but we do it
61 // here to avoid a server roundtrip. 79 // here to avoid a server roundtrip.
62 XA_SCREEN_RESOURCES, 80 XA_SCREEN_RESOURCES,
63 XA_XDCCC_LINEAR_RGB_CORRECTION, 81 XA_XDCCC_LINEAR_RGB_CORRECTION,
64 XA_XDCCC_LINEAR_RGB_MATRICES, 82 XA_XDCCC_LINEAR_RGB_MATRICES,
65 XA_WM_COLORMAP_WINDOWS, 83 XA_WM_COLORMAP_WINDOWS,
81struct rxvt_display; 99struct rxvt_display;
82 100
83struct im_watcher; 101struct im_watcher;
84struct xevent_watcher; 102struct xevent_watcher;
85 103
104template<class watcher>
105struct event_vec : vector<watcher *>
106{
107 void erase_unordered (unsigned int pos)
108 {
109 watcher *w = (*this)[this->size () - 1];
110 this->pop_back ();
111
112 if (!this->empty ())
113 if (((*this)[pos] = w)) // '=' is correct!
114 w->active = pos + 1;
115 }
116};
117
118struct rxvt_watcher
119{
120 int active; /* 0 == inactive, else index into respective vector */
121
122 bool is_active () { return active; }
123
124 rxvt_watcher () : active (0) { }
125};
126
86struct refcounted { 127struct refcounted
128{
87 int referenced; 129 int referenced;
88 char *id; 130 char *id;
89 131
90 refcounted (const char *id); 132 refcounted (const char *id);
91 bool ref_init () { return false; } 133 bool ref_init () { return false; }
92 void ref_next () { } 134 void ref_next () { }
93 ~refcounted (); 135 ~refcounted ();
94}; 136};
95 137
96template<class T> 138template<class T>
97struct refcache : vector<T *> { 139struct refcache : vector<T *>
140{
98 T *get (const char *id); 141 T *get (const char *id);
99 void put (T *obj); 142 void put (T *obj);
100 void clear (); 143 void clear ();
101 144
102 ~refcache () 145 ~refcache ()
107 150
108///////////////////////////////////////////////////////////////////////////// 151/////////////////////////////////////////////////////////////////////////////
109 152
110struct rxvt_screen; 153struct rxvt_screen;
111 154
112struct rxvt_drawable { 155struct rxvt_drawable
156{
113 rxvt_screen *screen; 157 rxvt_screen *screen;
114 Drawable drawable; 158 Drawable drawable;
115 operator Drawable() { return drawable; } 159 operator Drawable() { return drawable; }
116 160
117#if XFT 161#if XFT
133}; 177};
134 178
135///////////////////////////////////////////////////////////////////////////// 179/////////////////////////////////////////////////////////////////////////////
136 180
137#ifdef USE_XIM 181#ifdef USE_XIM
138struct rxvt_xim : refcounted { 182struct rxvt_xim : refcounted
183{
139 void destroy (); 184 void destroy ();
140 rxvt_display *display; 185 rxvt_display *display;
141 186
142//public 187//public
143 XIM xim; 188 XIM xim;
146 bool ref_init (); 191 bool ref_init ();
147 ~rxvt_xim (); 192 ~rxvt_xim ();
148}; 193};
149#endif 194#endif
150 195
151struct rxvt_screen { 196struct rxvt_screen
197{
152 rxvt_display *display; 198 rxvt_display *display;
153 Display *dpy; 199 Display *dpy;
154 int depth; 200 int depth;
155 Visual *visual; 201 Visual *visual;
156 Colormap cmap; 202 Colormap cmap;
164 210
165 rxvt_screen (); 211 rxvt_screen ();
166#endif 212#endif
167 213
168 void set (rxvt_display *disp); 214 void set (rxvt_display *disp);
169 void set (rxvt_display *disp, int bitdepth); 215 void select_visual (int bitdepth);
170 void clear (); 216 void clear ();
171}; 217};
172 218
173struct rxvt_display : refcounted { 219struct rxvt_display : refcounted
220{
174 io_manager_vec<xevent_watcher> xw; 221 event_vec<xevent_watcher> xw;
175 222
176 io_watcher x_ev; void x_cb (io_watcher &w, short revents); 223 ev::idle flush_ev; void flush_cb (ev::idle &w, int revents);
224 ev::io x_ev ; void x_cb (ev::io &w, int revents);
177 225
178#ifdef USE_XIM 226#ifdef USE_XIM
179 refcache<rxvt_xim> xims; 227 refcache<rxvt_xim> xims;
180 vector<im_watcher *> imw; 228 vector<im_watcher *> imw;
181 229
187 Display *dpy; 235 Display *dpy;
188 int screen; 236 int screen;
189 Window root; 237 Window root;
190 rxvt_term *selection_owner; 238 rxvt_term *selection_owner;
191 Atom xa[NUM_XA]; 239 Atom xa[NUM_XA];
192#ifndef NO_SLOW_LINK_SUPPORT
193 bool is_local; 240 bool is_local;
194#endif
195#ifdef POINTER_BLANK 241#ifdef POINTER_BLANK
196 Cursor blank_cursor; 242 Cursor blank_cursor;
197#endif 243#endif
198 244
199 rxvt_display (const char *id); 245 rxvt_display (const char *id);
200 XrmDatabase get_resources (bool refresh); 246 XrmDatabase get_resources (bool refresh);
201 bool ref_init (); 247 bool ref_init ();
202 void ref_next (); 248 void ref_next ();
203 ~rxvt_display (); 249 ~rxvt_display ();
204 250
205 void flush (); 251 void flush ()
252 {
253 flush_ev.start ();
254 }
255
206 Atom atom (const char *name); 256 Atom atom (const char *name);
207 void set_selection_owner (rxvt_term *owner); 257 void set_selection_owner (rxvt_term *owner);
208 258
209 void reg (xevent_watcher *w); 259 void reg (xevent_watcher *w);
210 void unreg (xevent_watcher *w); 260 void unreg (xevent_watcher *w);
217 void put_xim (rxvt_xim *xim); 267 void put_xim (rxvt_xim *xim);
218#endif 268#endif
219}; 269};
220 270
221#ifdef USE_XIM 271#ifdef USE_XIM
222struct im_watcher : watcher, callback0<void> { 272struct im_watcher : rxvt_watcher, callback<void (void)> {
223 template<class O1, class O2>
224 im_watcher (O1 *object, void (O2::*method) ())
225 : callback0<void> (object,method)
226 { }
227
228 void start (rxvt_display *display) 273 void start (rxvt_display *display)
229 { 274 {
230 display->reg (this); 275 display->reg (this);
231 } 276 }
277
232 void stop (rxvt_display *display) 278 void stop (rxvt_display *display)
233 { 279 {
234 display->unreg (this); 280 display->unreg (this);
235 } 281 }
236}; 282};
237#endif 283#endif
238 284
239struct xevent_watcher : watcher, callback1<void, XEvent &> { 285struct xevent_watcher : rxvt_watcher, callback<void (XEvent &)>
286{
240 Window window; 287 Window window;
241
242 template<class O1, class O2>
243 xevent_watcher (O1 *object, void (O2::*method) (XEvent &))
244 : callback1<void, XEvent &> (object,method)
245 { }
246 288
247 void start (rxvt_display *display, Window window) 289 void start (rxvt_display *display, Window window)
248 { 290 {
249 this->window = window; 291 this->window = window;
250 display->reg (this); 292 display->reg (this);
251 } 293 }
294
252 void stop (rxvt_display *display) 295 void stop (rxvt_display *display)
253 { 296 {
254 display->unreg (this); 297 display->unreg (this);
255 } 298 }
256}; 299};
259 302
260///////////////////////////////////////////////////////////////////////////// 303/////////////////////////////////////////////////////////////////////////////
261 304
262typedef unsigned long Pixel; 305typedef unsigned long Pixel;
263 306
264struct rgba { 307struct rgba
308{
265 unsigned short r, g, b, a; 309 unsigned short r, g, b, a;
266 310
267 enum { MIN_CC = 0x0000, MAX_CC = 0xffff }; 311 enum { MIN_CC = 0x0000, MAX_CC = 0xffff };
268 312
269 rgba () 313 rgba ()
272 rgba (unsigned short r, unsigned short g, unsigned short b, unsigned short a = MAX_CC) 316 rgba (unsigned short r, unsigned short g, unsigned short b, unsigned short a = MAX_CC)
273 : r(r), g(g), b(b), a(a) 317 : r(r), g(g), b(b), a(a)
274 { } 318 { }
275}; 319};
276 320
277struct rxvt_color { 321struct rxvt_color
322{
278#if XFT 323#if XFT
279 XftColor c; 324 XftColor c;
280#else 325#else
281 XColor c; 326 XColor c;
282#endif 327#endif
284 operator Pixel () const { return c.pixel; } 329 operator Pixel () const { return c.pixel; }
285 330
286 bool operator == (const rxvt_color &b) const { return Pixel (*this) == Pixel (b); } 331 bool operator == (const rxvt_color &b) const { return Pixel (*this) == Pixel (b); }
287 bool operator != (const rxvt_color &b) const { return Pixel (*this) != Pixel (b); } 332 bool operator != (const rxvt_color &b) const { return Pixel (*this) != Pixel (b); }
288 333
334 bool is_opaque () const
335 {
336#if XFT
337 return c.color.alpha == rgba::MAX_CC;
338#else
339 return 1;
340#endif
341 }
342
289 bool alloc (rxvt_screen *screen, const rgba &color); 343 bool alloc (rxvt_screen *screen, const rgba &color);
290 void free (rxvt_screen *screen); 344 void free (rxvt_screen *screen);
291 345
292 void get (rgba &color); 346 void get (rgba &color);
293 void get (XColor &color); 347 void get (XColor &color);
294 348
295 bool set (rxvt_screen *screen, const char *name); 349 bool set (rxvt_screen *screen, const char *name);
296 bool set (rxvt_screen *screen, const rgba &color); 350 bool set (rxvt_screen *screen, const rgba &color);
297 351
298 void fade (rxvt_screen *screen, int percent, rxvt_color &result, const rgba &to = rgba (0, 0, 0)); 352 void fade (rxvt_screen *screen, int percent, rxvt_color &result, const rgba &to = rgba (0, 0, 0));
299}; 353};
300 354
301#endif 355#if TRACE_PIXMAPS
356Pixmap trace_XCreatePixmap (const char *file, int line, Display *dpy, Window r, unsigned int w, unsigned int h, unsigned int d);
357void trace_XFreePixmap (const char *file, int line, Display *dpy, Pixmap p);
302 358
359# define XCreatePixmap(dpy,r,w,h,d) trace_XCreatePixmap (__FILE__,__LINE__,dpy,r,w,h,d)
360# define XFreePixmap(dpy,p) trace_XFreePixmap (__FILE__,__LINE__,dpy,p)
361#endif
362
363#endif
364

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines