ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvttoolkit.h
Revision: 1.47
Committed: Wed Nov 5 14:43:54 2008 UTC (15 years, 6 months ago) by root
Content type: text/plain
Branch: MAIN
CVS Tags: rel-9_06, rel-9_07
Changes since 1.46: +2 -1 lines
Log Message:
minor overlay refactoring, syntax changes

File Contents

# User Rev Content
1 root 1.27 /*----------------------------------------------------------------------*
2 root 1.26 * File: rxvttoolkit.h - provide toolkit-functionality for rxvt.
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    
23 root 1.1 #ifndef RXVT_TOOLKIT_H
24     #define RXVT_TOOLKIT_H
25    
26     #include <X11/Xlib.h>
27    
28     #if XFT
29     # include <X11/Xft/Xft.h>
30     #endif
31    
32 root 1.34 #include "ev_cpp.h"
33 root 1.1
34     #include "rxvtutil.h"
35    
36     #include "callback.h"
37    
38 root 1.11 // see rxvttoolkit.C:xa_names, which must be kept in sync
39     enum {
40     XA_TEXT,
41     XA_COMPOUND_TEXT,
42     XA_UTF8_STRING,
43     XA_MULTIPLE,
44     XA_TARGETS,
45     XA_TIMESTAMP,
46     XA_VT_SELECTION,
47     XA_INCR,
48     XA_WM_PROTOCOLS,
49     XA_WM_DELETE_WINDOW,
50     XA_CLIPBOARD,
51 root 1.14 XA_AVERAGE_WIDTH,
52     XA_WEIGHT_NAME,
53     XA_SLANT,
54     XA_CHARSET_REGISTRY,
55     XA_CHARSET_ENCODING,
56 root 1.11 #if ENABLE_FRILLS
57     XA_MOTIF_WM_HINTS,
58     #endif
59     #if ENABLE_EWMH
60     XA_NET_WM_PID,
61     XA_NET_WM_NAME,
62     XA_NET_WM_ICON_NAME,
63     XA_NET_WM_PING,
64 root 1.46 XA_NET_WM_ICON,
65 root 1.11 #endif
66     #if USE_XIM
67     XA_WM_LOCALE_NAME,
68     XA_XIM_SERVERS,
69     #endif
70 root 1.31 #if ENABLE_TRANSPARENCY
71 root 1.11 XA_XROOTPMAP_ID,
72     XA_ESETROOT_PMAP_ID,
73     #endif
74     #if ENABLE_XEMBED
75     XA_XEMBED,
76     XA_XEMBED_INFO,
77     #endif
78 root 1.14 #if !ENABLE_MINIMAL
79 ayin 1.41 // these are usually allocated by other subsystems, but we do it
80 root 1.14 // here to avoid a server roundtrip.
81     XA_SCREEN_RESOURCES,
82     XA_XDCCC_LINEAR_RGB_CORRECTION,
83     XA_XDCCC_LINEAR_RGB_MATRICES,
84     XA_WM_COLORMAP_WINDOWS,
85     XA_WM_STATE,
86 root 1.15 XA_cursor,
87     # if USE_XIM
88     // various selection targets used by XIM
89     XA_TRANSPORT,
90     XA_LOCALES,
91     XA__XIM_PROTOCOL,
92     XA__XIM_XCONNECT,
93     XA__XIM_MOREDATA,
94     # endif
95 root 1.14 #endif
96 root 1.11 NUM_XA
97     };
98    
99 root 1.1 struct rxvt_term;
100 root 1.2 struct rxvt_display;
101 root 1.1
102     struct im_watcher;
103     struct xevent_watcher;
104    
105 root 1.34 template<class watcher>
106 root 1.37 struct event_vec : vector<watcher *>
107     {
108 root 1.34 void erase_unordered (unsigned int pos)
109     {
110     watcher *w = (*this)[this->size () - 1];
111     this->pop_back ();
112    
113     if (!this->empty ())
114     if (((*this)[pos] = w)) // '=' is correct!
115     w->active = pos + 1;
116     }
117     };
118    
119 root 1.37 struct rxvt_watcher
120     {
121 root 1.34 int active; /* 0 == inactive, else index into respective vector */
122    
123     bool is_active () { return active; }
124    
125     rxvt_watcher () : active (0) { }
126     };
127    
128 root 1.37 struct refcounted
129     {
130 root 1.1 int referenced;
131     char *id;
132    
133     refcounted (const char *id);
134 root 1.9 bool ref_init () { return false; }
135     void ref_next () { }
136 root 1.1 ~refcounted ();
137     };
138    
139     template<class T>
140 root 1.37 struct refcache : vector<T *>
141     {
142 root 1.1 T *get (const char *id);
143     void put (T *obj);
144 root 1.7 void clear ();
145    
146     ~refcache ()
147     {
148     clear ();
149     }
150 root 1.1 };
151    
152     /////////////////////////////////////////////////////////////////////////////
153    
154 root 1.24 struct rxvt_screen;
155    
156 root 1.37 struct rxvt_drawable
157     {
158 root 1.24 rxvt_screen *screen;
159     Drawable drawable;
160     operator Drawable() { return drawable; }
161    
162     #if XFT
163     XftDraw *xftdrawable;
164     operator XftDraw *();
165     #endif
166    
167     rxvt_drawable (rxvt_screen *screen, Drawable drawable)
168     : screen(screen),
169     #if XFT
170     xftdrawable(0),
171     #endif
172     drawable(drawable)
173     { }
174    
175     #if XFT
176     ~rxvt_drawable ();
177     #endif
178     };
179    
180     /////////////////////////////////////////////////////////////////////////////
181    
182 root 1.1 #ifdef USE_XIM
183 root 1.37 struct rxvt_xim : refcounted
184     {
185 root 1.1 void destroy ();
186     rxvt_display *display;
187    
188     //public
189     XIM xim;
190    
191     rxvt_xim (const char *id) : refcounted (id) { }
192 root 1.9 bool ref_init ();
193 root 1.1 ~rxvt_xim ();
194     };
195     #endif
196    
197 root 1.37 struct rxvt_screen
198     {
199 root 1.12 rxvt_display *display;
200 root 1.23 Display *dpy;
201 root 1.12 int depth;
202     Visual *visual;
203     Colormap cmap;
204    
205 root 1.24 #if XFT
206     // scratch pixmap
207     rxvt_drawable *scratch_area;
208     int scratch_w, scratch_h;
209    
210     rxvt_drawable &scratch_drawable (int w, int h);
211    
212     rxvt_screen ();
213     #endif
214    
215 root 1.12 void set (rxvt_display *disp);
216 root 1.29 void select_visual (int bitdepth);
217 root 1.12 void clear ();
218     };
219    
220 root 1.37 struct rxvt_display : refcounted
221     {
222 root 1.34 event_vec<xevent_watcher> xw;
223 root 1.1
224 root 1.45 ev::prepare flush_ev; void flush_cb (ev::prepare &w, int revents);
225 root 1.38 ev::io x_ev ; void x_cb (ev::io &w, int revents);
226 root 1.1
227     #ifdef USE_XIM
228     refcache<rxvt_xim> xims;
229     vector<im_watcher *> imw;
230    
231     void im_change_cb ();
232 root 1.3 void im_change_check ();
233 root 1.1 #endif
234    
235     //public
236 root 1.23 Display *dpy;
237 root 1.7 int screen;
238     Window root;
239 root 1.1 rxvt_term *selection_owner;
240 root 1.11 Atom xa[NUM_XA];
241 root 1.7 bool is_local;
242     #ifdef POINTER_BLANK
243     Cursor blank_cursor;
244 root 1.1 #endif
245    
246     rxvt_display (const char *id);
247 root 1.22 XrmDatabase get_resources (bool refresh);
248 root 1.9 bool ref_init ();
249     void ref_next ();
250 root 1.1 ~rxvt_display ();
251    
252 root 1.39 void flush ()
253     {
254     flush_ev.start ();
255     }
256    
257 root 1.5 Atom atom (const char *name);
258 root 1.1 void set_selection_owner (rxvt_term *owner);
259    
260     void reg (xevent_watcher *w);
261     void unreg (xevent_watcher *w);
262    
263     #ifdef USE_XIM
264     void reg (im_watcher *w);
265     void unreg (im_watcher *w);
266    
267     rxvt_xim *get_xim (const char *locale, const char *modifiers);
268     void put_xim (rxvt_xim *xim);
269     #endif
270     };
271    
272     #ifdef USE_XIM
273 root 1.47 struct im_watcher : rxvt_watcher, callback<void (void)>
274     {
275 root 1.1 void start (rxvt_display *display)
276     {
277     display->reg (this);
278     }
279 root 1.34
280 root 1.1 void stop (rxvt_display *display)
281     {
282     display->unreg (this);
283     }
284     };
285     #endif
286    
287 root 1.37 struct xevent_watcher : rxvt_watcher, callback<void (XEvent &)>
288     {
289 root 1.1 Window window;
290    
291     void start (rxvt_display *display, Window window)
292     {
293     this->window = window;
294     display->reg (this);
295     }
296 root 1.34
297 root 1.1 void stop (rxvt_display *display)
298     {
299     display->unreg (this);
300     }
301     };
302    
303     extern refcache<rxvt_display> displays;
304    
305     /////////////////////////////////////////////////////////////////////////////
306    
307     typedef unsigned long Pixel;
308    
309 root 1.37 struct rgba
310     {
311 root 1.13 unsigned short r, g, b, a;
312    
313     enum { MIN_CC = 0x0000, MAX_CC = 0xffff };
314    
315 root 1.19 rgba ()
316 root 1.13 { }
317    
318 root 1.19 rgba (unsigned short r, unsigned short g, unsigned short b, unsigned short a = MAX_CC)
319 root 1.13 : r(r), g(g), b(b), a(a)
320     { }
321     };
322    
323 root 1.37 struct rxvt_color
324     {
325 root 1.1 #if XFT
326     XftColor c;
327     #else
328 root 1.19 XColor c;
329 root 1.1 #endif
330    
331 root 1.19 operator Pixel () const { return c.pixel; }
332    
333 root 1.1 bool operator == (const rxvt_color &b) const { return Pixel (*this) == Pixel (b); }
334     bool operator != (const rxvt_color &b) const { return Pixel (*this) != Pixel (b); }
335    
336 root 1.42 bool is_opaque () const
337     {
338     #if XFT
339 root 1.43 return c.color.alpha == rgba::MAX_CC;
340 root 1.42 #else
341     return 1;
342     #endif
343     }
344    
345 root 1.19 bool alloc (rxvt_screen *screen, const rgba &color);
346 root 1.16 void free (rxvt_screen *screen);
347    
348 root 1.20 void get (rgba &color);
349 root 1.21 void get (XColor &color);
350 ayin 1.33
351 root 1.12 bool set (rxvt_screen *screen, const char *name);
352 root 1.19 bool set (rxvt_screen *screen, const rgba &color);
353 root 1.1
354 root 1.19 void fade (rxvt_screen *screen, int percent, rxvt_color &result, const rgba &to = rgba (0, 0, 0));
355 root 1.1 };
356    
357 sasha 1.35 #if TRACE_PIXMAPS
358     Pixmap trace_XCreatePixmap (const char *file, int line, Display *dpy, Window r, unsigned int w, unsigned int h, unsigned int d);
359     void trace_XFreePixmap (const char *file, int line, Display *dpy, Pixmap p);
360    
361     # define XCreatePixmap(dpy,r,w,h,d) trace_XCreatePixmap (__FILE__,__LINE__,dpy,r,w,h,d)
362     # define XFreePixmap(dpy,p) trace_XFreePixmap (__FILE__,__LINE__,dpy,p)
363     #endif
364    
365 root 1.1 #endif
366