ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvttoolkit.h
Revision: 1.54
Committed: Mon Feb 21 07:12:03 2011 UTC (13 years, 3 months ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.53: +6 -7 lines
Log Message:
refactor

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 sf-exg 1.51 * Copyright (c) 2011 Emanuele Giaquinta <e.giaquinta@glauco.it>
8 root 1.26 *
9     * This program is free software; you can redistribute it and/or modify
10     * it under the terms of the GNU General Public License as published by
11     * the Free Software Foundation; either version 2 of the License, or
12     * (at your option) any later version.
13     *
14     * This program is distributed in the hope that it will be useful,
15     * but WITHOUT ANY WARRANTY; without even the implied warranty of
16     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17     * GNU General Public License for more details.
18     *
19     * You should have received a copy of the GNU General Public License
20     * along with this program; if not, write to the Free Software
21     * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22     *----------------------------------------------------------------------*/
23    
24 root 1.1 #ifndef RXVT_TOOLKIT_H
25     #define RXVT_TOOLKIT_H
26    
27     #include <X11/Xlib.h>
28    
29     #if XFT
30     # include <X11/Xft/Xft.h>
31     #endif
32    
33 root 1.34 #include "ev_cpp.h"
34 root 1.1
35     #include "rxvtutil.h"
36    
37     #include "callback.h"
38    
39 root 1.11 // see rxvttoolkit.C:xa_names, which must be kept in sync
40     enum {
41     XA_TEXT,
42     XA_COMPOUND_TEXT,
43     XA_UTF8_STRING,
44     XA_MULTIPLE,
45     XA_TARGETS,
46     XA_TIMESTAMP,
47     XA_VT_SELECTION,
48     XA_INCR,
49     XA_WM_PROTOCOLS,
50     XA_WM_DELETE_WINDOW,
51     XA_CLIPBOARD,
52 root 1.14 XA_AVERAGE_WIDTH,
53     XA_WEIGHT_NAME,
54     XA_SLANT,
55     XA_CHARSET_REGISTRY,
56     XA_CHARSET_ENCODING,
57 root 1.11 #if ENABLE_FRILLS
58     XA_MOTIF_WM_HINTS,
59     #endif
60     #if ENABLE_EWMH
61     XA_NET_WM_PID,
62     XA_NET_WM_NAME,
63     XA_NET_WM_ICON_NAME,
64     XA_NET_WM_PING,
65 root 1.46 XA_NET_WM_ICON,
66 root 1.11 #endif
67     #if USE_XIM
68     XA_WM_LOCALE_NAME,
69     XA_XIM_SERVERS,
70     #endif
71 root 1.31 #if ENABLE_TRANSPARENCY
72 root 1.11 XA_XROOTPMAP_ID,
73     XA_ESETROOT_PMAP_ID,
74     #endif
75     #if ENABLE_XEMBED
76     XA_XEMBED,
77     XA_XEMBED_INFO,
78     #endif
79 root 1.14 #if !ENABLE_MINIMAL
80 ayin 1.41 // these are usually allocated by other subsystems, but we do it
81 root 1.14 // here to avoid a server roundtrip.
82     XA_SCREEN_RESOURCES,
83     XA_XDCCC_LINEAR_RGB_CORRECTION,
84     XA_XDCCC_LINEAR_RGB_MATRICES,
85     XA_WM_COLORMAP_WINDOWS,
86     XA_WM_STATE,
87 root 1.15 XA_cursor,
88     # if USE_XIM
89     // various selection targets used by XIM
90     XA_TRANSPORT,
91     XA_LOCALES,
92     XA__XIM_PROTOCOL,
93     XA__XIM_XCONNECT,
94     XA__XIM_MOREDATA,
95     # endif
96 root 1.14 #endif
97 root 1.11 NUM_XA
98     };
99    
100 root 1.1 struct rxvt_term;
101 root 1.2 struct rxvt_display;
102 root 1.1
103     struct im_watcher;
104     struct xevent_watcher;
105    
106 root 1.34 template<class watcher>
107 root 1.37 struct event_vec : vector<watcher *>
108     {
109 root 1.34 void erase_unordered (unsigned int pos)
110     {
111     watcher *w = (*this)[this->size () - 1];
112     this->pop_back ();
113    
114     if (!this->empty ())
115     if (((*this)[pos] = w)) // '=' is correct!
116     w->active = pos + 1;
117     }
118     };
119    
120 root 1.37 struct rxvt_watcher
121     {
122 root 1.34 int active; /* 0 == inactive, else index into respective vector */
123    
124     bool is_active () { return active; }
125    
126     rxvt_watcher () : active (0) { }
127     };
128    
129 root 1.37 struct refcounted
130     {
131 root 1.1 int referenced;
132     char *id;
133    
134     refcounted (const char *id);
135 root 1.9 bool ref_init () { return false; }
136     void ref_next () { }
137 root 1.1 ~refcounted ();
138     };
139    
140     template<class T>
141 root 1.37 struct refcache : vector<T *>
142     {
143 root 1.1 T *get (const char *id);
144     void put (T *obj);
145 root 1.7 void clear ();
146    
147     ~refcache ()
148     {
149     clear ();
150     }
151 root 1.1 };
152    
153     /////////////////////////////////////////////////////////////////////////////
154    
155 root 1.24 struct rxvt_screen;
156    
157 root 1.37 struct rxvt_drawable
158     {
159 root 1.24 rxvt_screen *screen;
160     Drawable drawable;
161     operator Drawable() { return drawable; }
162    
163     #if XFT
164     XftDraw *xftdrawable;
165     operator XftDraw *();
166     #endif
167    
168     rxvt_drawable (rxvt_screen *screen, Drawable drawable)
169     : screen(screen),
170     #if XFT
171     xftdrawable(0),
172     #endif
173     drawable(drawable)
174     { }
175    
176     #if XFT
177     ~rxvt_drawable ();
178     #endif
179     };
180    
181     /////////////////////////////////////////////////////////////////////////////
182    
183 root 1.1 #ifdef USE_XIM
184 root 1.37 struct rxvt_xim : refcounted
185     {
186 root 1.1 void destroy ();
187     rxvt_display *display;
188    
189     //public
190     XIM xim;
191    
192     rxvt_xim (const char *id) : refcounted (id) { }
193 root 1.9 bool ref_init ();
194 root 1.1 ~rxvt_xim ();
195     };
196     #endif
197    
198 root 1.37 struct rxvt_screen
199     {
200 root 1.12 rxvt_display *display;
201 root 1.23 Display *dpy;
202 root 1.12 int depth;
203     Visual *visual;
204     Colormap cmap;
205    
206 root 1.24 #if XFT
207     // scratch pixmap
208     rxvt_drawable *scratch_area;
209     int scratch_w, scratch_h;
210    
211     rxvt_drawable &scratch_drawable (int w, int h);
212    
213     rxvt_screen ();
214     #endif
215    
216 root 1.12 void set (rxvt_display *disp);
217 root 1.29 void select_visual (int bitdepth);
218 root 1.12 void clear ();
219     };
220    
221 root 1.37 struct rxvt_display : refcounted
222     {
223 root 1.34 event_vec<xevent_watcher> xw;
224 root 1.1
225 root 1.45 ev::prepare flush_ev; void flush_cb (ev::prepare &w, int revents);
226 root 1.38 ev::io x_ev ; void x_cb (ev::io &w, int revents);
227 root 1.1
228     #ifdef USE_XIM
229     refcache<rxvt_xim> xims;
230     vector<im_watcher *> imw;
231    
232     void im_change_cb ();
233 root 1.3 void im_change_check ();
234 root 1.1 #endif
235    
236     //public
237 root 1.23 Display *dpy;
238 root 1.7 int screen;
239     Window root;
240 root 1.1 rxvt_term *selection_owner;
241 sf-exg 1.48 rxvt_term *clipboard_owner;
242 root 1.11 Atom xa[NUM_XA];
243 root 1.7 bool is_local;
244     #ifdef POINTER_BLANK
245     Cursor blank_cursor;
246 root 1.1 #endif
247    
248     rxvt_display (const char *id);
249 root 1.22 XrmDatabase get_resources (bool refresh);
250 root 1.9 bool ref_init ();
251     void ref_next ();
252 root 1.1 ~rxvt_display ();
253    
254 root 1.39 void flush ()
255     {
256     flush_ev.start ();
257     }
258    
259 root 1.5 Atom atom (const char *name);
260 sf-exg 1.48 void set_selection_owner (rxvt_term *owner, bool clipboard);
261 root 1.1
262     void reg (xevent_watcher *w);
263     void unreg (xevent_watcher *w);
264    
265     #ifdef USE_XIM
266     void reg (im_watcher *w);
267     void unreg (im_watcher *w);
268    
269     rxvt_xim *get_xim (const char *locale, const char *modifiers);
270     void put_xim (rxvt_xim *xim);
271     #endif
272     };
273    
274     #ifdef USE_XIM
275 root 1.47 struct im_watcher : rxvt_watcher, callback<void (void)>
276     {
277 root 1.1 void start (rxvt_display *display)
278     {
279     display->reg (this);
280     }
281 root 1.34
282 root 1.1 void stop (rxvt_display *display)
283     {
284     display->unreg (this);
285     }
286     };
287     #endif
288    
289 root 1.37 struct xevent_watcher : rxvt_watcher, callback<void (XEvent &)>
290     {
291 root 1.1 Window window;
292    
293     void start (rxvt_display *display, Window window)
294     {
295     this->window = window;
296     display->reg (this);
297     }
298 root 1.34
299 root 1.1 void stop (rxvt_display *display)
300     {
301     display->unreg (this);
302     }
303     };
304    
305     extern refcache<rxvt_display> displays;
306    
307     /////////////////////////////////////////////////////////////////////////////
308    
309     typedef unsigned long Pixel;
310    
311 root 1.37 struct rgba
312     {
313 root 1.13 unsigned short r, g, b, a;
314    
315     enum { MIN_CC = 0x0000, MAX_CC = 0xffff };
316    
317 root 1.19 rgba ()
318 root 1.13 { }
319    
320 root 1.19 rgba (unsigned short r, unsigned short g, unsigned short b, unsigned short a = MAX_CC)
321 root 1.13 : r(r), g(g), b(b), a(a)
322     { }
323     };
324    
325 root 1.37 struct rxvt_color
326     {
327 root 1.1 #if XFT
328     XftColor c;
329     #else
330 root 1.19 XColor c;
331 root 1.1 #endif
332    
333 root 1.19 operator Pixel () const { return c.pixel; }
334    
335 root 1.1 bool operator == (const rxvt_color &b) const { return Pixel (*this) == Pixel (b); }
336     bool operator != (const rxvt_color &b) const { return Pixel (*this) != Pixel (b); }
337    
338 root 1.42 bool is_opaque () const
339     {
340     #if XFT
341 root 1.43 return c.color.alpha == rgba::MAX_CC;
342 root 1.42 #else
343     return 1;
344     #endif
345     }
346    
347 root 1.19 bool alloc (rxvt_screen *screen, const rgba &color);
348 root 1.16 void free (rxvt_screen *screen);
349    
350 root 1.20 void get (rgba &color);
351 root 1.21 void get (XColor &color);
352 ayin 1.33
353 root 1.12 bool set (rxvt_screen *screen, const char *name);
354 root 1.19 bool set (rxvt_screen *screen, const rgba &color);
355 root 1.1
356 root 1.19 void fade (rxvt_screen *screen, int percent, rxvt_color &result, const rgba &to = rgba (0, 0, 0));
357 root 1.1 };
358    
359 sf-exg 1.50 #define Sel_normal 0x01 /* normal selection */
360     #define Sel_incr 0x02 /* incremental selection */
361     #define Sel_Primary 0x01
362     #define Sel_Secondary 0x02
363     #define Sel_Clipboard 0x03
364     #define Sel_whereMask 0x0f
365     #define Sel_CompoundText 0x10 /* last request was COMPOUND_TEXT */
366     #define Sel_UTF8String 0x20 /* last request was UTF8_STRING */
367    
368     struct rxvt_selection
369     {
370 root 1.54 rxvt_selection (rxvt_display *disp, int selnum, Time tm, Window win, Atom prop, rxvt_term *term, void *cb_sv = 0);
371 sf-exg 1.52 void run ();
372 sf-exg 1.50 ~rxvt_selection ();
373    
374 root 1.54 rxvt_term *term; // terminal to paste to, may be 0
375     void *cb_sv; // perl callback, may be 0
376    
377 sf-exg 1.50 rxvt_display *display;
378     Time request_time;
379     Window request_win;
380     Atom request_prop;
381    
382     unsigned char selection_wait;
383     unsigned char selection_type;
384    
385 root 1.54 private:
386 sf-exg 1.50 char *incr_buf;
387     size_t incr_buf_size, incr_buf_fill;
388    
389     void timer_cb (ev::timer &w, int revents); ev::timer timer_ev;
390     void x_cb (XEvent &xev); xevent_watcher x_ev;
391    
392 root 1.54 void finish (char *data = 0, unsigned int len = 0);
393 sf-exg 1.50 void stop ();
394     bool request (Atom target, int selnum);
395     void handle_selection (Window win, Atom prop, bool delete_prop);
396     };
397    
398 root 1.1 #endif
399