Implement 1002/1003 mouse tracking modes.
[dana/urxvt.git] / src / rxvt.h
1 #ifndef RXVT_H_                /* include once only */
2 #define RXVT_H_
3
4 #include "rxvtlib.h"
5
6 #include "feature.h"
7
8 #if defined (ISO_14755) || defined (ENABLE_PERL)
9 # define ENABLE_OVERLAY 1
10 #endif
11
12 #if ENABLE_PERL
13 # define ENABLE_FRILLS    1
14 # define ENABLE_COMBINING 1
15 #endif
16
17 #if ENABLE_FRILLS
18 # define ENABLE_XEMBED        1
19 # define ENABLE_EWMH          1
20 # define ENABLE_XIM_ONTHESPOT 1
21 # define CURSOR_BLINK         1
22 # define OPTION_HC            1
23 #else
24 # define ENABLE_MINIMAL 1
25 #endif
26
27 #include <limits.h>
28
29 #include <X11/cursorfont.h>
30 #include <X11/keysym.h>
31 #include <X11/keysymdef.h>
32 #include <X11/Xatom.h>
33 #if ENABLE_FRILLS
34 # include <X11/Xmd.h>
35 #endif
36
37 #include "encoding.h"
38 #include "rxvtutil.h"
39 #include "rxvtfont.h"
40 #include "rxvttoolkit.h"
41 #include "iom.h"
42 #include "salloc.h"
43 #include "libptytty.h"
44
45 #include "rxvtperl.h"
46
47 // try to avoid some macros to decrease code size, on some systems
48 #if ENABLE_MINIMAL
49 # define strcmp(a,b)   (strcmp)(a,b)
50 # define strlen(a)     (strlen)(a)
51 # define strcpy(a,b)   (strcpy)(a,b)
52 # define memset(a,c,l) (memset)(a,c,l)
53 # define memcpy(a,b,l) (memcpy)(a,b,l)
54 #endif
55
56 /*
57  *****************************************************************************
58  * SYSTEM HACKS
59  *****************************************************************************
60  */
61 /* Consistent defines - please report on the necessity
62  * @ Unixware: defines (__svr4__)
63  */
64 #if defined (SVR4) && !defined (__svr4__)
65 # define __svr4__ 1
66 #endif
67 #if defined (sun) && !defined (__sun__)
68 # define __sun__ 1
69 #endif
70
71 #ifndef HAVE_XPOINTER
72 typedef char *XPointer;
73 #endif
74
75 #include <termios.h>
76 typedef struct termios ttymode_t;
77
78 #ifdef HAVE_AFTERIMAGE
79 #  include <afterimage.h>
80 #undef min
81 #undef max
82 #endif
83
84 #include "background.h"
85
86 #ifndef STDIN_FILENO
87 # define STDIN_FILENO   0
88 # define STDOUT_FILENO  1
89 # define STDERR_FILENO  2
90 #endif
91
92 /****************************************************************************/
93
94 // exception thrown on fatal (per-instance) errors
95 class rxvt_failure_exception { };
96
97 // exception thrown when the command parser runs out of input data
98 class out_of_input { };
99
100 /*
101  *****************************************************************************
102  * PROTOTYPES                    
103  *****************************************************************************
104  */
105 // main.C
106 void           * rxvt_malloc                      (size_t size);
107 void           * rxvt_calloc                      (size_t number, size_t size);
108 void           * rxvt_realloc                     (void *ptr, size_t size);
109
110 // misc.C
111 char *           rxvt_wcstombs                    (const wchar_t *str, int len = -1);
112 wchar_t *        rxvt_mbstowcs                    (const char *str, int len = -1);
113 char *           rxvt_wcstoutf8                   (const wchar_t *str, int len = -1);
114 wchar_t *        rxvt_utf8towcs                   (const char *str, int len = -1);
115
116 #define rxvt_strdup(s) ((s) ? strdup(s) : 0)
117
118 char *           rxvt_basename                    (const char *str) NOTHROW;
119 void             rxvt_vlog                        (const char *fmt, va_list arg_ptr) NOTHROW;
120 void             rxvt_log                         (const char *fmt,...) NOTHROW;
121 void             rxvt_warn                        (const char *fmt,...) NOTHROW;
122 void             rxvt_fatal                       (const char *fmt, ...) THROW ((class rxvt_failure_exception)) NORETURN;
123 void             rxvt_exit_failure                () THROW ((class rxvt_failure_exception)) NORETURN;
124
125 char           * rxvt_strtrim                     (char *str) NOTHROW;
126 char          ** rxvt_splitcommastring            (const char *cs) NOTHROW;
127 void             rxvt_freecommastring             (char **cs) NOTHROW;
128
129 /////////////////////////////////////////////////////////////////////////////
130
131 // temporarily replace the process environment
132 extern char **environ;
133 extern char **rxvt_environ; // the original environ pointer
134
135 static inline void set_environ (stringvec *envv)
136 {
137 #if ENABLE_PERL
138   assert (envv);
139 #else
140   if (envv)
141 #endif
142     environ = (char **)envv->begin ();
143 }
144
145 static inline void set_environ (char **envv)
146 {
147 #if ENABLE_PERL
148   assert (envv);
149 #else
150   if (envv)
151 #endif
152     environ = envv;
153 }
154
155 /*
156  *****************************************************************************
157  * STRUCTURES AND TYPEDEFS
158  *****************************************************************************
159  */
160 struct grwin_t;
161
162 /* If we're using either the rxvt scrollbar, keep the
163  * scrollColor resource.
164  */
165 #if defined(RXVT_SCROLLBAR) || defined(NEXT_SCROLLBAR) || defined(PLAIN_SCROLLBAR)
166 # define KEEP_SCROLLCOLOR 1
167 #else
168 # undef KEEP_SCROLLCOLOR
169 #endif
170
171 /*
172  * the 'essential' information for reporting Mouse Events
173  * pared down from XButtonEvent
174  */
175 struct mouse_event {
176   int clicks;
177   Time time;             /* milliseconds */
178   unsigned int state;    /* key or button mask */
179   unsigned int button;   /* detail */
180 };
181
182 #if ENABLE_FRILLS
183 typedef struct _mwmhints {
184   CARD32 flags;
185   CARD32 functions;
186   CARD32 decorations;
187   INT32  input_mode;
188   CARD32 status;
189 } MWMHints;
190 #endif
191
192 #if ENABLE_XEMBED
193 // XEMBED messages
194 # define XEMBED_EMBEDDED_NOTIFY          0 
195 # define XEMBED_WINDOW_ACTIVATE          1 
196 # define XEMBED_WINDOW_DEACTIVATE        2 
197 # define XEMBED_REQUEST_FOCUS            3 
198 # define XEMBED_FOCUS_IN                 4 
199 # define XEMBED_FOCUS_OUT                5 
200 # define XEMBED_FOCUS_NEXT               6 
201 # define XEMBED_FOCUS_PREV               7
202
203 # define XEMBED_MODALITY_ON              10 
204 # define XEMBED_MODALITY_OFF             11 
205 # define XEMBED_REGISTER_ACCELERATOR     12 
206 # define XEMBED_UNREGISTER_ACCELERATOR   13 
207 # define XEMBED_ACTIVATE_ACCELERATOR     14
208
209 // XEMBED detail code
210 # define XEMBED_FOCUS_CURRENT            0 
211 # define XEMBED_FOCUS_FIRST              1 
212 # define XEMBED_FOCUS_LAST               2
213
214 # define XEMBED_MAPPED                  (1 << 0)
215 #endif
216
217 /*
218  *****************************************************************************
219  * NORMAL DEFINES
220  *****************************************************************************
221  */
222
223 /* COLORTERM, TERM environment variables */
224 #define COLORTERMENV    "rxvt"
225 #ifdef BG_IMAGE_FROM_FILE
226 # define COLORTERMENVFULL COLORTERMENV "-xpm"
227 #else
228 # define COLORTERMENVFULL COLORTERMENV
229 #endif
230 #ifndef TERMENV
231 # define TERMENV        "rxvt-unicode"
232 #endif
233
234 #if defined (NO_MOUSE_REPORT) && !defined (NO_MOUSE_REPORT_SCROLLBAR)
235 # define NO_MOUSE_REPORT_SCROLLBAR 1
236 #endif
237
238 /* now look for other badly set stuff */
239
240 #if !defined (EACCESS) && defined(EAGAIN)
241 # define EACCESS EAGAIN
242 #endif
243
244 #ifndef EXIT_SUCCESS            /* missing from <stdlib.h> */
245 # define EXIT_SUCCESS           0       /* exit function success */
246 # define EXIT_FAILURE           1       /* exit function failure */
247 #endif
248
249 #define scrollBar_esc           30
250
251 #if defined(RXVT_SCROLLBAR) || defined(NEXT_SCROLLBAR) || defined(XTERM_SCROLLBAR) || defined(PLAIN_SCROLLBAR)
252 # define HAVE_SCROLLBARS 1
253 #endif
254
255 #define R_SB_ALIGN_CENTRE       0
256 #define R_SB_ALIGN_TOP          1
257 #define R_SB_ALIGN_BOTTOM       2
258
259 #define R_SB_NEXT               1
260 #define R_SB_XTERM              2
261 #define R_SB_PLAIN              4
262 #define R_SB_RXVT               8
263
264 #define SB_WIDTH_NEXT           19
265 #define SB_WIDTH_XTERM          15
266 #define SB_WIDTH_PLAIN          7
267 #ifndef SB_WIDTH_RXVT
268 # define SB_WIDTH_RXVT          10
269 #endif
270
271 /*
272  * NeXT scrollbar defines
273  */
274 #define SB_PADDING              1
275 #define SB_BORDER_WIDTH         1
276 #define SB_BEVEL_WIDTH_UPPER_LEFT       1
277 #define SB_BEVEL_WIDTH_LOWER_RIGHT      2
278 #define SB_LEFT_PADDING         (SB_PADDING + SB_BORDER_WIDTH)
279 #define SB_MARGIN_SPACE         (SB_PADDING * 2)
280 #define SB_BUTTON_WIDTH         (SB_WIDTH_NEXT - SB_MARGIN_SPACE - SB_BORDER_WIDTH)
281 #define SB_BUTTON_HEIGHT        (SB_BUTTON_WIDTH)
282 #define SB_BUTTON_SINGLE_HEIGHT (SB_BUTTON_HEIGHT + SB_PADDING)
283 #define SB_BUTTON_BOTH_HEIGHT   (SB_BUTTON_SINGLE_HEIGHT * 2)
284 #define SB_BUTTON_TOTAL_HEIGHT  (SB_BUTTON_BOTH_HEIGHT + SB_PADDING)
285 #define SB_BUTTON_BEVEL_X       (SB_LEFT_PADDING)
286 #define SB_BUTTON_FACE_X        (SB_BUTTON_BEVEL_X + SB_BEVEL_WIDTH_UPPER_LEFT)
287 #define SB_THUMB_MIN_HEIGHT     (SB_BUTTON_WIDTH - (SB_PADDING * 2))
288  /*
289   *    +-------------+
290   *    |             | <---< SB_PADDING
291   *    | ::::::::::: |
292   *    | ::::::::::: |
293   *   '''''''''''''''''
294   *   ,,,,,,,,,,,,,,,,,
295   *    | ::::::::::: |
296   *    | ::::::::::: |
297   *    |  +---------------< SB_BEVEL_WIDTH_UPPER_LEFT
298   *    |  | :::::::: |
299   *    |  V :::: vv-------< SB_BEVEL_WIDTH_LOWER_RIGHT
300   *    | +---------+ |
301   *    | | ......%%| |
302   *    | | ......%%| |
303   *    | | .. ()..%%| |
304   *    | | ......%%| |
305   *    | | %%%%%%%%| |
306   *    | +---------+ | <.........................
307   *    |             | <---< SB_PADDING         :
308   *    | +---------+ | <-+..........            :---< SB_BUTTON_TOTAL_HEIGHT
309   *    | | ......%%| |   |         :            :
310   *    | | ../\..%%| |   |---< SB_BUTTON_HEIGHT :
311   *    | | %%%%%%%%| |   |         :            :
312   *    | +---------+ | <-+         :            :
313   *    |             |             :            :
314   *    | +---------+ | <-+         :---< SB_BUTTON_BOTH_HEIGHT
315   *    | | ......%%| |   |         :            :
316   *    | | ..\/..%%| |   |         :            :
317   *    | | %%%%%%%%| |   |---< SB_BUTTON_SINGLE_HEIGHT
318   *    | +---------+ |   |         :            :
319   *    |             |   |         :            :
320   *    +-------------+ <-+.........:............:
321   *    ^^|_________| :
322   *    ||     |      :
323   *    ||     +---< SB_BUTTON_WIDTH
324   *    ||            :
325   *    |+------< SB_PADDING
326   *    |:            :
327   *    +----< SB_BORDER_WIDTH
328   *     :            :
329   *     :............:
330   *           |
331   *           +---< SB_WIDTH_NEXT
332   */
333
334 enum {
335   NO_REFRESH       = 0,  /* Window not visible at all!        */
336   FAST_REFRESH     = 1,  /* Fully exposed window              */
337   SLOW_REFRESH     = 2,  /* Partially exposed window          */
338 };
339
340 #ifdef NO_SECONDARY_SCREEN
341 # define NSCREENS               0
342 #else
343 # define NSCREENS               1
344 #endif
345
346 /* special (internal) prefix for font commands */
347 #define FONT_CMD                '#'
348 #define FONT_DN                 "#-"
349 #define FONT_UP                 "#+"
350
351 /* flags for rxvt_scr_gotorc () */
352 enum {
353   C_RELATIVE = 1,       /* col movement is relative */
354   R_RELATIVE = 2,       /* row movement is relative */
355   RELATIVE   = C_RELATIVE | R_RELATIVE,
356 };
357
358 /* modes for rxvt_scr_insdel_chars (), rxvt_scr_insdel_lines () */
359 enum {
360   INSERT = -1,                          /* don't change these values */
361   DELETE = +1,
362   ERASE  = +2,
363 };
364
365 /* modes for rxvt_scr_page () - scroll page. used by scrollbar window */
366 enum page_dirn {
367   UP,
368   DN,
369   NO_DIR,
370 };
371
372 /* arguments for rxvt_scr_change_screen () */
373 enum {
374   PRIMARY = 0,
375   SECONDARY,
376 };
377
378 #define RS_None                 0
379
380 #define RS_fgMask               0x0000007fUL    // 128 colors
381 #define RS_bgMask               0x00003f80UL    // 128 colors
382
383 // font styles
384 #define RS_Bold                 0x00004000UL    // value 1
385 #define RS_Italic               0x00008000UL    // value 2
386
387 // fake styles
388 #define RS_Blink                0x00010000UL    // blink
389 #define RS_RVid                 0x00020000UL    // reverse video
390 #define RS_Uline                0x00040000UL    // underline
391
392 // toggle this to force redraw, must be != RS_Careful
393 #define RS_redraw               0x01000000UL
394
395 // 5 custom bits for extensions
396 #define RS_customCount          32
397 #define RS_customMask           0x00f80000UL
398 #define RS_customShift          19
399
400 // other flags
401 #define RS_Careful              0x80000000UL    /* be careful when drawing these */
402
403 #define RS_styleCount           4
404 #define RS_styleMask            (RS_Bold | RS_Italic)
405 #define RS_styleShift           14
406
407 #define RS_baseattrMask         (RS_Italic | RS_Bold | RS_Blink | RS_RVid | RS_Uline)
408 #define RS_attrMask             (RS_baseattrMask | RS_fontMask)
409
410 #define RS_fontCount            127             // not 127 or 256, see rxvtfont.h
411 #define RS_fontMask             0xff000000UL    // plenty(?) of fonts, includes RS_Careful
412 #define RS_fontShift            24
413
414 #define DEFAULT_RSTYLE  (RS_None | Color_fg | (Color_bg << Color_Bits))
415 #define OVERLAY_RSTYLE  (RS_None | Color_Black | (Color_Yellow << Color_Bits))
416
417 #define Sel_none                0       /* Not waiting */
418 #define Sel_normal              0x01    /* normal selection */
419 #define Sel_incr                0x02    /* incremental selection */
420 #define Sel_direct              0x00
421 #define Sel_Primary             0x01
422 #define Sel_Secondary           0x02
423 #define Sel_Clipboard           0x03
424 #define Sel_whereMask           0x0f
425 #define Sel_CompoundText        0x10    /* last request was COMPOUND_TEXT */
426 #define Sel_UTF8String          0x20    /* last request was UTF8_STRING */
427
428 enum {
429   C0_NUL = 0x00,
430           C0_SOH, C0_STX, C0_ETX, C0_EOT, C0_ENQ, C0_ACK, C0_BEL,
431   C0_BS , C0_HT , C0_LF , C0_VT , C0_FF , C0_CR , C0_SO , C0_SI ,
432   C0_DLE, C0_DC1, C0_DC2, D0_DC3, C0_DC4, C0_NAK, C0_SYN, C0_ETB,
433   C0_CAN, C0_EM , C0_SUB, C0_ESC, C0_IS4, C0_IS3, C0_IS2, C0_IS1,
434 }; 
435 #define CHAR_ST                 0x9c    /* 0234 */
436
437 /*
438  * XTerm Operating System Commands: ESC ] Ps;Pt (ST|BEL)
439  * colour extensions by Christian W. Zuckschwerdt <zany@triq.net>
440  */
441 enum {
442   XTerm_name             =  0,
443   XTerm_iconName         =  1,
444   XTerm_title            =  2,
445   XTerm_property         =  3,      // change X property
446   XTerm_Color            =  4,      // change colors
447   XTerm_Color00          = 10,      // not implemented, CLASH!
448   XTerm_Color01          = 11,      // not implemented
449   XTerm_Color_cursor     = 12,      // change actual 'Cursor' color
450   XTerm_Color_pointer_fg = 13,      // change actual 'Pointer' fg color
451   XTerm_Color_pointer_bg = 14,      // change actual 'Pointer' bg color
452   XTerm_Color05          = 15,      // not implemented (tektronix fg)
453   XTerm_Color06          = 16,      // not implemented (tektronix bg)
454   XTerm_Color_RV         = 17,      // change actual 'Highlight' color
455   XTerm_logfile          = 46,      // not implemented
456   XTerm_font             = 50,
457
458   XTerm_konsole30        = 30,      // reserved for konsole
459   XTerm_konsole31        = 31,      // reserved for konsole
460   XTerm_emacs51          = 51,      // reserved for emacs shell
461   /*
462    * rxvt extensions of XTerm OSCs: ESC ] Ps;Pt (ST|BEL)
463    * at least Rxvt_Color_BD and Rxvt_Color_UL clash with xterm
464    */
465   Rxvt_Color_BD          = 18,      // change actual 'Bold' color
466   Rxvt_Color_UL          = 19,      // change actual 'Underline' color
467   Rxvt_Pixmap            = 20,      // new bg pixmap
468   Rxvt_restoreFG         = 39,      // change default fg color
469   Rxvt_restoreBG         = 49,      // change default bg color
470   Rxvt_dumpscreen        = 55,      // dump scrollback and all of screen
471
472   URxvt_locale           = 701,     // change locale
473   URxvt_version          = 702,     // request version
474
475   URxvt_Color_IT         = 704,     // change actual 'Italic' colour
476   URxvt_Color_tint       = 705,     // change actual tint colour
477   URxvt_Color_BD         = 706,
478   URxvt_Color_UL         = 707,
479
480   URxvt_font             = 710,
481   URxvt_boldFont         = 711,
482   URxvt_italicFont       = 712,
483   URxvt_boldItalicFont   = 713,
484
485   URxvt_view_up          = 720,
486   URxvt_view_down        = 721,
487
488   URxvt_perl             = 777,
489 };
490
491 /* Words starting with `Color_' are colours.  Others are counts */
492 /*
493  * The PixColor and rendition colour usage should probably be decoupled
494  * on the unnecessary items, e.g. Color_pointer, but won't bother
495  * until we need to.  Also, be aware of usage in pixcolor_set
496  */
497
498 enum colour_list {
499   Color_none = -2,
500   Color_transparent = -1,
501   Color_fg = 0,
502   Color_bg,
503   minCOLOR,                   /* 2 */
504   Color_Black = minCOLOR,
505   Color_Red3,
506   Color_Green3,
507   Color_Yellow3,
508   Color_Blue3,
509   Color_Magenta3,
510   Color_Cyan3,
511   maxCOLOR,                   /* minCOLOR + 7 */
512 #ifndef NO_BRIGHTCOLOR
513   Color_AntiqueWhite = maxCOLOR,
514   minBrightCOLOR,             /* maxCOLOR + 1 */
515   Color_Grey25 = minBrightCOLOR,
516   Color_Red,
517   Color_Green,
518   Color_Yellow,
519   Color_Blue,
520   Color_Magenta,
521   Color_Cyan,
522   maxBrightCOLOR,             /* minBrightCOLOR + 7 */
523   Color_White = maxBrightCOLOR,
524 #else
525   Color_White = maxCOLOR,
526 #endif
527   minTermCOLOR = Color_White + 1,
528   maxTermCOLOR = Color_White + 72,
529 #ifndef NO_CURSORCOLOR
530   Color_cursor,
531   Color_cursor2,
532 #endif
533   Color_pointer_fg,
534   Color_pointer_bg,
535   Color_border,
536 #ifndef NO_BOLD_UNDERLINE_REVERSE
537   Color_BD,
538   Color_IT,
539   Color_UL,
540   Color_RV,
541 #endif
542 #if ENABLE_FRILLS
543   Color_underline,
544 #endif
545 #ifdef OPTION_HC
546   Color_HC,
547 #endif
548 #ifdef KEEP_SCROLLCOLOR
549   Color_scroll,
550   Color_trough,
551 #endif
552 #if ENABLE_TRANSPARENCY
553   Color_tint,
554 #endif
555 #if OFF_FOCUS_FADING
556   Color_fade,
557 #endif
558   NRS_COLORS,                 /* */
559 #ifdef KEEP_SCROLLCOLOR
560   Color_topShadow = NRS_COLORS,
561   Color_bottomShadow,
562   TOTAL_COLORS
563 #else
564   TOTAL_COLORS = NRS_COLORS
565 #endif
566 };
567
568 #define Color_Bits      7 // 0 .. maxTermCOLOR
569
570 /*
571  * Resource list
572  */
573 enum {
574 # define def(name) Rs_ ## name,
575 # define reserve(name,count) Rs_ ## name ## _ = Rs_ ## name + (count) - 1,
576 # include "rsinc.h"
577 # undef def
578 # undef reserve
579   NUM_RESOURCES
580 };
581
582 /* DEC private modes */
583 #define PrivMode_132            (1UL<<0)
584 #define PrivMode_132OK          (1UL<<1)
585 #define PrivMode_rVideo         (1UL<<2)
586 #define PrivMode_relOrigin      (1UL<<3)
587 #define PrivMode_Screen         (1UL<<4)
588 #define PrivMode_Autowrap       (1UL<<5)
589 #define PrivMode_aplCUR         (1UL<<6)
590 #define PrivMode_aplKP          (1UL<<7)
591 #define PrivMode_HaveBackSpace  (1UL<<8)
592 #define PrivMode_BackSpace      (1UL<<9)
593 #define PrivMode_ShiftKeys      (1UL<<10)
594 #define PrivMode_VisibleCursor  (1UL<<11)
595 #define PrivMode_MouseX10       (1UL<<12)
596 #define PrivMode_MouseX11       (1UL<<13)
597 #define PrivMode_scrollBar      (1UL<<14)
598 #define PrivMode_TtyOutputInh   (1UL<<15)
599 #define PrivMode_Keypress       (1UL<<16)
600 #define PrivMode_smoothScroll   (1UL<<17)
601 #define PrivMode_vt52           (1UL<<18)
602 #define PrivMode_LFNL           (1UL<<19)
603 #define PrivMode_MouseBtnEvent  (1UL<<20)
604 #define PrivMode_MouseAnyEvent  (1UL<<21)
605 /* too annoying to implement X11 highlight tracking */
606 /* #define PrivMode_MouseX11Track       (1LU<<20) */
607
608 #define PrivMode_mouse_report   (PrivMode_MouseX10|PrivMode_MouseX11|PrivMode_MouseBtnEvent|PrivMode_MouseAnyEvent)
609
610 #ifdef ALLOW_132_MODE
611 # define PrivMode_Default (PrivMode_Autowrap|PrivMode_ShiftKeys|PrivMode_VisibleCursor|PrivMode_132OK)
612 #else
613 # define PrivMode_Default (PrivMode_Autowrap|PrivMode_ShiftKeys|PrivMode_VisibleCursor)
614 #endif
615
616 // do not change these constants lightly, there are many interdependencies
617 #define IMBUFSIZ               128     // input modifier buffer sizes
618 #define KBUFSZ                 512     // size of keyboard mapping buffer
619 #define CBUFSIZ                2048    // size of command buffer
620 #define UBUFSIZ                2048    // character buffer
621
622 #ifndef PATH_MAX
623 # define PATH_MAX 16384
624 #endif
625
626 /* Motif window hints */
627 #define MWM_HINTS_FUNCTIONS     (1L << 0)
628 #define MWM_HINTS_DECORATIONS   (1L << 1)
629 #define MWM_HINTS_INPUT_MODE    (1L << 2)
630 #define MWM_HINTS_STATUS        (1L << 3)
631 /* bit definitions for MwmHints.functions */
632 #define MWM_FUNC_ALL            (1L << 0)
633 #define MWM_FUNC_RESIZE         (1L << 1)
634 #define MWM_FUNC_MOVE           (1L << 2)
635 #define MWM_FUNC_MINIMIZE       (1L << 3)
636 #define MWM_FUNC_MAXIMIZE       (1L << 4)
637 #define MWM_FUNC_CLOSE          (1L << 5)
638 /* bit definitions for MwmHints.decorations */
639 #define MWM_DECOR_ALL           (1L << 0)
640 #define MWM_DECOR_BORDER        (1L << 1)
641 #define MWM_DECOR_RESIZEH       (1L << 2)
642 #define MWM_DECOR_TITLE         (1L << 3)
643 #define MWM_DECOR_MENU          (1L << 4)
644 #define MWM_DECOR_MINIMIZE      (1L << 5)
645 #define MWM_DECOR_MAXIMIZE      (1L << 6)
646 /* bit definitions for MwmHints.inputMode */
647 #define MWM_INPUT_MODELESS                  0
648 #define MWM_INPUT_PRIMARY_APPLICATION_MODAL 1
649 #define MWM_INPUT_SYSTEM_MODAL              2
650 #define MWM_INPUT_FULL_APPLICATION_MODAL    3
651 #define PROP_MWM_HINTS_ELEMENTS             5
652
653 /*
654  *****************************************************************************
655  * MACRO DEFINES
656  *****************************************************************************
657  */
658 #define dLocal(type,name)       type const name = this->name
659
660 // for speed reasons, we assume that all codepoints 32 to 126 are
661 // single-width.
662 #define WCWIDTH(c)              (IN_RANGE_INC (c, 0x20, 0x7e) ? 1 : wcwidth (c))
663
664 /* convert pixel dimensions to row/column values.  Everything as int32_t */
665 #define Pixel2Col(x)            Pixel2Width((int32_t)(x))
666 #define Pixel2Row(y)            Pixel2Height((int32_t)(y))
667 #define Pixel2Width(x)          ((int32_t)(x) / (int32_t)fwidth)
668 #define Pixel2Height(y)         ((int32_t)(y) / (int32_t)fheight)
669 #define Col2Pixel(col)          ((int32_t)Width2Pixel(col))
670 #define Row2Pixel(row)          ((int32_t)Height2Pixel(row))
671 #define Width2Pixel(n)          ((int32_t)(n) * (int32_t)fwidth)
672 #define Height2Pixel(n)         ((int32_t)(n) * (int32_t)fheight)
673
674 // for m >= -n, ensure remainder lies between 0..n-1
675 #define MOD(m,n) (((m) + (n)) % (n))
676
677 #define LINENO(n) MOD (term_start + int(n), total_rows)
678 #define ROW(n) row_buf [LINENO (n)]
679
680 /* how to build & extract colors and attributes */
681 #define GET_BASEFG(x)           (((x) & RS_fgMask))
682 #define GET_BASEBG(x)           (((x) & RS_bgMask)>>Color_Bits)
683
684 #define GET_FONT(x)             (((x) & RS_fontMask) >> RS_fontShift)
685 #define SET_FONT(x,fid)         (((x) & ~RS_fontMask) | ((fid) << RS_fontShift))
686
687 #define GET_STYLE(x)            (((x) & RS_styleMask) >> RS_styleShift)
688 #define SET_STYLE(x,style)      (((x) & ~RS_styleMask) | ((style) << RS_styleShift))
689
690 #define GET_ATTR(x)             (((x) & RS_attrMask))
691 #define GET_BGATTR(x)                                                   \
692     (((x) & RS_RVid) ? (((x) & (RS_attrMask & ~RS_RVid))                \
693                         | (((x) & RS_fgMask)<<Color_Bits))              \
694                      : ((x) & (RS_attrMask | RS_bgMask)))
695 #define SET_FGCOLOR(x,fg)       (((x) & ~RS_fgMask)   | (fg))
696 #define SET_BGCOLOR(x,bg)       (((x) & ~RS_bgMask)   | ((bg)<<Color_Bits))
697 #define SET_ATTR(x,a)           (((x) & ~RS_attrMask) | (a))
698
699 #define RS_SAME(a,b)            (!(((a) ^ (b)) & ~RS_Careful))
700
701 #define PIXCOLOR_NAME(idx)      rs[Rs_color + (idx)]
702 #define ISSET_PIXCOLOR(idx)     (!!rs[Rs_color + (idx)])
703
704 #if ENABLE_STYLES
705 # define FONTSET(style) fontset[GET_STYLE (style)]
706 #else
707 # define FONTSET(style) fontset[0]
708 #endif
709
710 #ifdef HAVE_SCROLLBARS
711 # define scrollbar_TotalWidth() (scrollBar.width + sb_shadow * 2)
712 #else
713 # define scrollbar_TotalWidth() (0)
714 #endif
715 #define scrollbar_isMotion()    (scrollBar.state == 'm')
716 #define scrollbar_isUp()        (scrollBar.state == 'U')
717 #define scrollbar_isDn()        (scrollBar.state == 'D')
718 #define scrollbar_isUpDn()      isupper (scrollBar.state)
719 #define isScrollbarWindow(w)    (scrollBar.state && (w) == scrollBar.win)
720
721 #define scrollbarnext_dnval()   (scrollBar.end + (scrollBar.width + 1))
722 #define scrollbarnext_upButton(y)       ((y) > scrollBar.end \
723                                          && (y) <= scrollbarnext_dnval ())
724 #define scrollbarnext_dnButton(y)       ((y) > scrollbarnext_dnval())
725 #define SCROLLNEXT_MINHEIGHT    SB_THUMB_MIN_HEIGHT
726 #define scrollbarrxvt_upButton(y)       ((y) < scrollBar.beg)
727 #define scrollbarrxvt_dnButton(y)       ((y) > scrollBar.end)
728 #define SCROLLRXVT_MINHEIGHT    10
729 #define SCROLLXTERM_MINHEIGHT   10
730
731 #define scrollbar_minheight()   (scrollBar.style == R_SB_NEXT        \
732                                  ? SCROLLNEXT_MINHEIGHT                 \
733                                  : SCROLLRXVT_MINHEIGHT)
734 #define scrollbar_above_slider(y)       ((y) < scrollBar.top)
735 #define scrollbar_below_slider(y)       ((y) > scrollBar.bot)
736 #define scrollbar_position(y)           ((y) - scrollBar.beg)
737 #define scrollbar_size()                (scrollBar.end - scrollBar.beg \
738                                          - scrollbar_minheight ())
739
740 typedef callback<void (const char *)> log_callback;
741 typedef callback<int (int)> getfd_callback;
742
743 #define SET_LOCALE(locale) rxvt_set_locale (locale)
744 extern bool rxvt_set_locale (const char *locale) NOTHROW;
745 extern void rxvt_push_locale (const char *locale) NOTHROW;
746 extern void rxvt_pop_locale () NOTHROW;
747
748 /****************************************************************************/
749
750 #define LINE_LONGER     0x0001 // line is continued on the next row
751 #define LINE_FILTERED   0x0002 // line has been filtered
752 #define LINE_COMPRESSED 0x0004 // line has been compressed (NYI)
753 #define LINE_FILTER     0x0008 // line needs to be filtered before display (NYI)
754 #define LINE_BIDI       0x0010 // line needs bidi (NYI)
755
756 struct line_t {
757    text_t *t; // terminal the text
758    rend_t *r; // rendition, uses RS_ flags
759    tlen_t_ l; // length of each text line, LINE_CONT == continued on next line
760    uint32_t f; // flags
761
762    bool is_longer ()
763    {
764      return f & LINE_LONGER;
765    }
766
767    void is_longer (int set)
768    {
769      if (set)
770        f |= LINE_LONGER;
771      else
772        f &= ~LINE_LONGER;
773    }
774
775    void clear ()
776    {
777      t = 0;
778      r = 0;
779      l = 0;
780      f = 0;
781    }
782
783    void touch () // call whenever a line is changed/touched/updated
784    {
785 #if ENABLE_PERL
786      f &= ~LINE_FILTERED;
787 #endif
788    }
789
790    void touch (int col)
791    {
792      max_it (l, col);
793      touch ();
794    }
795 };
796
797 /****************************************************************************/
798
799 // primivite wrapper around mbstate_t to ensure initialisation
800 struct mbstate {
801   mbstate_t mbs;
802
803   operator mbstate_t *() { return &mbs; }
804   void reset () { memset (&mbs, 0, sizeof (mbs)); }
805   mbstate () { reset (); }
806 };
807
808 /****************************************************************************/
809
810 #define UNICODE_MASK 0x1fffffUL
811
812 #if UNICODE3
813 # define COMPOSE_LO 0x40000000UL
814 # define COMPOSE_HI 0x400fffffUL
815 # define IS_COMPOSE(n) ((int32_t)(n) >= COMPOSE_LO)
816 #else
817 # if ENABLE_PERL
818 #  define COMPOSE_LO 0xe000UL // our _own_ functions don't like (illegal) surrogates
819 #  define COMPOSE_HI 0xf8ffUL // in utf-8, so use private use area only
820 # else
821 #  define COMPOSE_LO 0xd800UL
822 #  define COMPOSE_HI 0xf8ffUL
823 # endif
824 # define IS_COMPOSE(n) IN_RANGE_INC ((n), COMPOSE_LO, COMPOSE_HI)
825 #endif
826
827 #if ENABLE_COMBINING
828 // compose chars are used to represent composite characters
829 // that are not representable in unicode, as well as characters
830 // not fitting in the BMP.
831 struct compose_char {
832   unicode_t c1, c2; // any chars != NOCHAR are valid
833   compose_char (unicode_t c1, unicode_t c2)
834   : c1(c1), c2(c2)
835   { }
836 };
837
838 class rxvt_composite_vec {
839   vector<compose_char> v;
840 public:
841   text_t compose (unicode_t c1, unicode_t c2 = NOCHAR);
842   int expand (unicode_t c, wchar_t *r);
843   compose_char *operator [](text_t c)
844   {
845     return c >= COMPOSE_LO && c < COMPOSE_LO + v.size ()
846            ? &v[c - COMPOSE_LO]
847            : 0;
848   }
849 };
850
851 extern class rxvt_composite_vec rxvt_composite;
852 #endif
853
854 /****************************************************************************/
855
856 #ifdef KEYSYM_RESOURCE
857 class keyboard_manager;
858 #endif
859
860 struct rxvt_term : zero_initialized, rxvt_vars, rxvt_screen {
861
862   // special markers with magic addresses
863   static const char resval_undef [];    // options specifically unset
864   static const char resval_on [];       // boolean options switched on
865   static const char resval_off [];      // or off
866   
867   log_callback   *log_hook;             // log error messages through this hook, if != 0
868   getfd_callback *getfd_hook;           // convert remote to local fd, if != 0
869 #if ENABLE_PERL
870   rxvt_perl_term  perl;
871 #endif
872   struct mbstate  mbstate;              // current input multibyte state
873
874   unsigned char   want_refresh:1,
875                   current_screen:1,     /* primary or secondary              */
876                   num_scr_allow:1,
877                   bypass_keystate:1,
878 #ifdef CURSOR_BLINK
879                   hidden_cursor:1,
880 #endif
881 #ifdef TEXT_BLINK
882                   hidden_text:1,
883 #endif
884 #ifdef POINTER_BLANK
885                   hidden_pointer:1,
886 #endif
887                   enc_utf8:1,           /* wether locale uses utf-8 */
888                   seen_input:1,         /* wether we have seen some program output yet */
889                   seen_resize:1,        /* wether we had a resize event */
890                   parsed_geometry:1;
891
892   unsigned char   refresh_type,
893 #ifdef META8_OPTION
894                   meta_char,            /* Alt-key prefix */
895 #endif
896                   scrollbar_align,
897                   selection_wait,
898                   selection_type;
899 /* ---------- */
900   bool            rvideo_state, rvideo_mode;
901 #ifndef NO_BELL
902   bool            rvideo_bell;
903 #endif
904   int             num_scr;              /* screen: number lines scrolled */
905   int             prev_ncol,            /* screen: previous number of columns */
906                   prev_nrow;            /* screen: previous number of rows */
907 /* ---------- */
908   rend_t          rstyle;
909 /* ---------- */
910 #ifdef SELECTION_SCROLLING
911   int             scroll_selection_lines;
912   enum page_dirn  scroll_selection_dir;
913   int             selection_save_x,
914                   selection_save_y,
915                   selection_save_state;
916 #endif
917 /* ---------- */
918   int             csrO,       /* Hops - csr offset in thumb/slider to      */
919                               /*   give proper Scroll behaviour            */
920 #if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING)
921                   mouse_slip_wheel_speed,
922 #endif
923                   refresh_count,
924                   last_bot,   /* scrollbar last bottom position            */
925                   last_top,   /* scrollbar last top position               */
926                   last_state, /* scrollbar last state                      */
927                   scrollbar_len,
928                   window_vt_x,
929                   window_vt_y,
930                   window_sb_x,
931                   mouse_row,
932                   mouse_col,
933 # ifdef POINTER_BLANK
934                   pointerBlankDelay,
935 # endif
936                   allowedxerror;
937 /* ---------- */
938   unsigned int    ModLevel3Mask,
939                   ModMetaMask,
940                   ModNumLockMask;
941   int             old_width,  /* last used width in screen resize          */
942                   old_height; /* last used height in screen resize         */
943   unsigned long   priv_modes,
944                   SavedModes;
945 /* ---------- */
946   Atom            *xa;
947 /* ---------- */
948 #ifdef RXVT_SCROLLBAR
949   GC              scrollbarGC,
950                   topShadowGC,
951                   botShadowGC;
952 #endif
953 #ifdef XTERM_SCROLLBAR
954   GC              xscrollbarGC,
955                   ShadowGC;
956 #endif
957 #ifdef PLAIN_SCROLLBAR
958   GC              pscrollbarGC;
959 #endif
960 #ifdef NEXT_SCROLLBAR
961   GC              blackGC,
962                   whiteGC,
963                   grayGC,
964                   darkGC,
965                   stippleGC;
966   Pixmap          dimple,
967                   upArrow,
968                   downArrow,
969                   upArrowHi,
970                   downArrowHi;
971 #endif
972 /* ---------- */
973   Time            selection_time,
974                   selection_request_time;
975   pid_t           cmd_pid;    /* process id of child */
976   char *          incr_buf;
977   size_t          incr_buf_size, incr_buf_fill;
978 /* ---------- */
979   Cursor          leftptr_cursor;
980 /* ---------- */
981   struct mouse_event MEvent;
982   XComposeStatus  compose;
983   ttymode_t       tio;
984   row_col_t       oldcursor;
985 #ifdef HAVE_BG_PIXMAP
986   bgPixmap_t      bgPixmap;
987 #endif
988 #ifdef HAVE_AFTERIMAGE
989   ASVisual       *asv;
990   ASImageManager *asimman;
991 #endif
992
993 #if ENABLE_OVERLAY
994   int ov_x, ov_y, ov_w, ov_h; // overlay dimensions
995   text_t **ov_text;
996   rend_t **ov_rend;
997
998   void scr_swap_overlay () NOTHROW;
999   void scr_overlay_new (int x, int y, int w, int h) NOTHROW;
1000   void scr_overlay_off () NOTHROW;
1001   void scr_overlay_set (int x, int y,
1002                         text_t text,
1003                         rend_t rend = OVERLAY_RSTYLE) NOTHROW;
1004   void scr_overlay_set (int x, int y, const char *s) NOTHROW;
1005   void scr_overlay_set (int x, int y, const wchar_t *s) NOTHROW;
1006 #endif
1007
1008   vector<void *> allocated;           // free these memory blocks with free()
1009
1010   char            env_windowid[21];   /* environmental variable WINDOWID */
1011   char            env_colorfgbg[sizeof ("COLORFGBG=default;default;bg") + 1];
1012   char           *env_display;        /* environmental variable DISPLAY  */
1013   char           *env_term;           /* environmental variable TERM     */
1014
1015   char           *locale;
1016   char            charsets[4];
1017   char           *v_buffer;           /* pointer to physical buffer */
1018   unsigned int    v_buflen;           /* size of area to write */
1019   stringvec      *argv, *envv;        /* if != 0, will be freed at destroy time */
1020
1021 #ifdef KEYSYM_RESOURCE
1022   keyboard_manager *keyboard;
1023 #endif
1024
1025   const char     *rs[NUM_RESOURCES];
1026   /* command input buffering */
1027   char           *cmdbuf_ptr, *cmdbuf_endp;
1028   char            cmdbuf_base[CBUFSIZ];
1029
1030   ptytty         *pty;
1031
1032   rxvt_salloc    *talloc;             // text line allocator
1033   rxvt_salloc    *ralloc;             // rend line allocator
1034
1035   static vector<rxvt_term *> termlist; // a vector of all running rxvt_term's
1036
1037 #if ENABLE_FRILLS || ISO_14755
1038   // ISO 14755 entry support
1039   unicode_t iso14755buf;
1040   void commit_iso14755 ();
1041   int hex_keyval (XKeyEvent &ev);
1042 # if ISO_14755
1043   void iso14755_51 (unicode_t ch, rend_t r = DEFAULT_RSTYLE, int x = 0, int y = -1);
1044   void iso14755_54 (int x, int y);
1045 # endif
1046 #endif
1047
1048   long vt_emask, vt_emask_perl, vt_emask_xim, vt_emask_mouse;
1049
1050   void vt_select_input () const NOTHROW
1051   {
1052     XSelectInput (dpy, vt, vt_emask | vt_emask_perl | vt_emask_xim | vt_emask_mouse);
1053   }
1054
1055 #if ENABLE_TRANSPARENCY || ENABLE_PERL
1056   void rootwin_cb (XEvent &xev);
1057   xevent_watcher rootwin_ev;
1058 #endif
1059 #ifdef HAVE_BG_PIXMAP
1060   int update_background ();
1061   void update_background_cb (time_watcher &w);
1062   time_watcher update_background_ev;
1063 #endif
1064
1065   void x_cb (XEvent &xev);
1066   xevent_watcher termwin_ev;
1067   xevent_watcher vt_ev;
1068 #ifdef HAVE_SCROLLBARS
1069   xevent_watcher scrollbar_ev;
1070 #endif
1071
1072   void child_cb (child_watcher &w, int status); child_watcher child_ev;
1073   void check_cb (check_watcher &w); check_watcher check_ev;
1074   void destroy_cb (time_watcher &w); time_watcher destroy_ev;
1075   void flush ();
1076   void flush_cb (time_watcher &w); time_watcher flush_ev;
1077   bool pty_fill ();
1078   void pty_cb (io_watcher &w, short revents); io_watcher pty_ev;
1079   void incr_cb (time_watcher &w) NOTHROW; time_watcher incr_ev;
1080
1081 #ifdef CURSOR_BLINK
1082   void cursor_blink_cb (time_watcher &w); time_watcher cursor_blink_ev;
1083 #endif
1084 #ifdef TEXT_BLINK
1085   void text_blink_cb (time_watcher &w); time_watcher text_blink_ev;
1086 #endif
1087 #ifndef NO_BELL     
1088   void bell_cb (time_watcher &w); time_watcher bell_ev;
1089 #endif
1090
1091 #ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING
1092   void cont_scroll_cb (time_watcher &w); time_watcher cont_scroll_ev;
1093 #endif
1094 #ifdef SELECTION_SCROLLING
1095   void sel_scroll_cb (time_watcher &w); time_watcher sel_scroll_ev;
1096 #endif
1097 #if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING)
1098   void slip_wheel_cb (time_watcher &w); time_watcher slip_wheel_ev;
1099 #endif
1100
1101 #ifdef POINTER_BLANK
1102   void pointer_cb (time_watcher &w); time_watcher pointer_ev;
1103   void pointer_blank ();
1104 #endif
1105   void pointer_unblank ();
1106
1107   void tt_printf (const char *fmt,...);
1108   void tt_write (const char *data, unsigned int len);
1109   void pty_write ();
1110
1111   bool init (stringvec *argv, stringvec *envv)
1112   {
1113     this->argv = argv;
1114     return init (argv->size (), argv->begin (), envv);
1115   }
1116
1117   void make_current () const // make this the "currently active" urxvt instance
1118   {
1119     SET_R (this);
1120     set_environ (envv);
1121     rxvt_set_locale (locale);
1122   }
1123
1124 #if USE_XIM
1125   rxvt_xim *input_method;
1126   XIC      Input_Context;
1127   XIMStyle input_style;
1128   XPoint   spot; // most recently sent spot position
1129
1130   void im_destroy ();
1131   void im_cb (); im_watcher im_ev;
1132   void im_set_size (XRectangle &size);
1133   void im_set_position (XPoint &pos) NOTHROW;
1134   void im_set_color (unsigned long &fg, unsigned long &bg);
1135   void im_set_preedit_area (XRectangle &preedit_rect, XRectangle &status_rect, const XRectangle &needed_rect);
1136
1137   bool IMisRunning ();
1138   void IMSendSpot ();
1139   bool IM_get_IC (const char *modifiers);
1140   void IMSetPosition ();
1141 #endif
1142
1143   // command.C
1144   void key_press (XKeyEvent &ev);
1145   void key_release (XKeyEvent &ev);
1146   unsigned int cmd_write (const char *str, unsigned int count);
1147
1148   wchar_t next_char () NOTHROW;
1149   wchar_t cmd_getc () THROW ((class out_of_input));
1150   uint32_t next_octet () NOTHROW;
1151   uint32_t cmd_get8 () THROW ((class out_of_input));
1152
1153   bool cmd_parse ();
1154   void mouse_report (XButtonEvent &ev);
1155   void button_press (XButtonEvent &ev);
1156   void button_release (XButtonEvent &ev);
1157   void focus_in ();
1158   void focus_out ();
1159   void update_fade_color (unsigned int idx);
1160 #ifdef PRINTPIPE
1161   FILE *popen_printer ();
1162   int pclose_printer (FILE *stream);
1163 #endif
1164   void process_print_pipe ();
1165   void process_nonprinting (unicode_t ch);
1166   void process_escape_vt52 (unicode_t ch);
1167   void process_escape_seq ();
1168   void process_csi_seq ();
1169   void process_window_ops (const int *args, unsigned int nargs);
1170   char *get_to_st (unicode_t &ends_how);
1171   void process_dcs_seq ();
1172   void process_osc_seq ();
1173   void process_color_seq (int report, int color, const char *str, char resp);
1174   void process_xterm_seq (int op, const char *str, char resp);
1175   int privcases (int mode, unsigned long bit);
1176   void process_terminal_mode (int mode, int priv, unsigned int nargs, const int *arg);
1177   void process_sgr_mode (unsigned int nargs, const int *arg);
1178   void process_graphics ();
1179   // init.C
1180   bool init_vars ();
1181   void init_secondary ();
1182   const char **init_resources (int argc, const char *const *argv);
1183   void init_env ();
1184   void set_locale (const char *locale);
1185   void init_xlocale ();
1186   void init_command (const char *const *argv);
1187   void run_command (const char *const *argv);
1188   int run_child (const char *const *argv);
1189   void color_aliases (int idx);
1190   void create_windows (int argc, const char *const *argv);
1191   void Get_Colours ();
1192   void get_ourmods ();
1193   // main.C
1194   void tt_winch ();
1195   rxvt_term ();
1196   ~rxvt_term ();
1197   void destroy ();
1198   void emergency_cleanup ();
1199   bool init (int argc, const char *const *argv, stringvec *envv);
1200   void recolour_cursor ();
1201   void resize_all_windows (unsigned int newwidth, unsigned int newheight, int ignoreparent);
1202   void window_calc (unsigned int newwidth, unsigned int newheight);
1203   bool set_fonts ();
1204   void set_string_property (Atom prop, const char *str, int len = -1);
1205   void set_utf8_property (Atom prop, const char *str, int len = -1);
1206   void set_title (const char *str);
1207   void set_icon_name (const char *str);
1208   void set_window_color (int idx, const char *color);
1209   void set_colorfgbg ();
1210   bool set_color (rxvt_color &color, const char *name);
1211   void alias_color (int dst, int src);
1212   void set_widthheight (unsigned int newwidth, unsigned int newheight);
1213   void get_window_origin (int &x, int &y);
1214   Pixmap get_pixmap_property (int prop_id);
1215
1216   // screen.C
1217
1218   void lalloc (line_t &l) const
1219   {
1220     l.t = (text_t *)talloc->alloc ();
1221     l.r = (rend_t *)ralloc->alloc ();
1222   }
1223
1224 #if 0
1225   void lfree (line_t &l)
1226   {
1227     talloc->free (l.t);
1228     ralloc->free (l.r);
1229   }
1230 #endif
1231
1232   void lresize (line_t &l) const
1233   {
1234     if (!l.t)
1235       return;
1236
1237     l.t = (text_t *)talloc->alloc (l.t, prev_ncol * sizeof (text_t));
1238     l.r = (rend_t *)ralloc->alloc (l.r, prev_ncol * sizeof (rend_t));
1239
1240     l.l = min (l.l, ncol);
1241
1242     if (ncol > prev_ncol)
1243       scr_blank_line (l, prev_ncol, ncol - prev_ncol, DEFAULT_RSTYLE);
1244   }
1245
1246   int fgcolor_of (rend_t r) const NOTHROW
1247   {
1248     int base = GET_BASEFG (r);
1249 #ifndef NO_BRIGHTCOLOR
1250     if (r & RS_Bold
1251 # if ENABLE_STYLES
1252         && option (Opt_intensityStyles)
1253 # endif
1254         && IN_RANGE_INC (base, minCOLOR, minBrightCOLOR))
1255       base += minBrightCOLOR - minCOLOR;
1256 #endif
1257     return base;
1258   }
1259
1260   int bgcolor_of (rend_t r) const NOTHROW
1261   {
1262     int base = GET_BASEBG (r);
1263 #ifndef NO_BRIGHTCOLOR
1264     if (r & RS_Blink
1265 # if ENABLE_STYLES
1266         && option (Opt_intensityStyles)
1267 # endif
1268         && IN_RANGE_INC (base, minCOLOR, minBrightCOLOR))
1269       base += minBrightCOLOR - minCOLOR;
1270 #endif
1271     return base;
1272   }
1273
1274   bool option (uint8_t opt) const NOTHROW
1275   {
1276     return options[opt >> 3] & (1 << (opt & 7));
1277   }
1278
1279   void set_option (uint8_t opt, bool set = true) NOTHROW
1280   {
1281     if (set)
1282       options[opt >> 3] |= (1 << (opt & 7));
1283     else
1284       options[opt >> 3] &= ~(1 << (opt & 7));
1285   }
1286
1287   void PrivMode (int set, unsigned bit) NOTHROW
1288   {
1289     if (set)
1290       priv_modes |= bit;
1291     else
1292       priv_modes &= ~bit;
1293   }
1294
1295   // modifies first argument(!)
1296   void paste (char *data, unsigned int len) NOTHROW;
1297   void scr_blank_line (line_t &l, unsigned int col, unsigned int width, rend_t efs) const NOTHROW;
1298   void scr_blank_screen_mem (line_t &l, rend_t efs) const NOTHROW;
1299   int scr_scroll_text (int row1, int row2, int count) NOTHROW;
1300   void scr_reset ();
1301   void scr_release () NOTHROW;
1302   void scr_clear (bool really = false) NOTHROW;
1303   void scr_refresh () NOTHROW;
1304   bool scr_refresh_rend (rend_t mask, rend_t value) NOTHROW;
1305   void scr_erase_screen (int mode) NOTHROW;
1306 #if ENABLE_FRILLS
1307   void scr_erase_savelines () NOTHROW;
1308   void scr_backindex () NOTHROW;
1309   void scr_forwardindex () NOTHROW;
1310 #endif
1311   void scr_touch (bool refresh) NOTHROW;
1312   void scr_expose (int x, int y, int width, int height, bool refresh) NOTHROW;
1313   void scr_recolour () NOTHROW;
1314   void scr_remap_chars () NOTHROW;
1315   void scr_remap_chars (line_t &l) NOTHROW;
1316
1317   enum cursor_mode { SAVE, RESTORE };
1318
1319   void scr_poweron ();
1320   void scr_cursor (cursor_mode mode) NOTHROW;
1321   void scr_do_wrap () NOTHROW;
1322   void scr_swap_screen () NOTHROW;
1323   void scr_change_screen (int scrn);
1324   void scr_color (unsigned int color, int fgbg) NOTHROW;
1325   void scr_rendition (int set, int style) NOTHROW;
1326   void scr_add_lines (const wchar_t *str, int len, int minlines = 0) NOTHROW;
1327   void scr_backspace () NOTHROW;
1328   void scr_tab (int count, bool ht = false) NOTHROW;
1329   void scr_gotorc (int row, int col, int relative) NOTHROW;
1330   void scr_index (enum page_dirn direction) NOTHROW;
1331   void scr_erase_line (int mode) NOTHROW;
1332   void scr_E () NOTHROW;
1333   void scr_insdel_lines (int count, int insdel) NOTHROW;
1334   void scr_insdel_chars (int count, int insdel) NOTHROW;
1335   void scr_scroll_region (int top, int bot) NOTHROW;
1336   void scr_cursor_visible (int mode) NOTHROW;
1337   void scr_autowrap (int mode) NOTHROW;
1338   void scr_relative_origin (int mode) NOTHROW;
1339   void scr_insert_mode (int mode) NOTHROW;
1340   void scr_set_tab (int mode) NOTHROW;
1341   void scr_rvideo_mode (bool on) NOTHROW;
1342   void scr_report_position () NOTHROW;
1343   void set_font_style () NOTHROW;
1344   void scr_charset_choose (int set) NOTHROW;
1345   void scr_charset_set (int set, unsigned int ch) NOTHROW;
1346   void scr_move_to (int y, int len) NOTHROW;
1347   bool scr_page (enum page_dirn direction, int nlines) NOTHROW;
1348   bool scr_changeview (int new_view_start) NOTHROW;
1349   void scr_bell () NOTHROW;
1350   void scr_printscreen (int fullhist) NOTHROW;
1351   void scr_xor_rect (int beg_row, int beg_col, int end_row, int end_col, rend_t rstyle1, rend_t rstyle2) NOTHROW;
1352   void scr_xor_span (int beg_row, int beg_col, int end_row, int end_col, rend_t rstyle) NOTHROW;
1353   void scr_reverse_selection () NOTHROW;
1354   void scr_dump (int fd) NOTHROW;
1355
1356   void selection_check (int check_more) NOTHROW;
1357   void selection_paste (Window win, Atom prop, bool delete_prop) NOTHROW;
1358   void selection_property (Window win, Atom prop) NOTHROW;
1359   void selection_request (Time tm, int selnum = Sel_Primary) NOTHROW;
1360   int selection_request_other (Atom target, int selnum) NOTHROW;
1361   void selection_clear () NOTHROW;
1362   void selection_make (Time tm);
1363   bool selection_grab (Time tm) NOTHROW;
1364   void selection_start_colrow (int col, int row) NOTHROW;
1365   void selection_delimit_word (enum page_dirn dirn, const row_col_t *mark, row_col_t *ret) NOTHROW;
1366   void selection_extend_colrow (int32_t col, int32_t row, int button3, int buttonpress, int clickchange) NOTHROW;
1367   void selection_remove_trailing_spaces () NOTHROW;
1368   void selection_send (const XSelectionRequestEvent &rq) NOTHROW;
1369   void selection_click (int clicks, int x, int y) NOTHROW;
1370   void selection_extend (int x, int y, int flag) NOTHROW;
1371   void selection_rotate (int x, int y) NOTHROW;
1372
1373 #if defined(NEXT_SCROLLBAR)
1374   // scrollbar-next.C
1375   Pixmap renderPixmap (const char *const *data, int width, int height);
1376   void init_scrollbar_stuff ();
1377   void drawBevel (Drawable d, int x1, int y1, int w, int h);
1378   int scrollbar_show_next (int update, int last_top, int last_bot, int scrollbar_len);
1379 #endif
1380
1381 #if defined(RXVT_SCROLLBAR)
1382   // scrollbar-rxvt.C
1383   int scrollbar_show_rxvt (int update, int last_top, int last_bot, int scrollbar_len);
1384 #endif
1385
1386 #if defined(XTERM_SCROLLBAR)
1387   // scrollbar-xterm.C
1388   int scrollbar_show_xterm (int update, int last_top, int last_bot, int scrollbar_len);
1389 #endif
1390
1391 #if defined(PLAIN_SCROLLBAR)
1392   // scrollbar-plain.C
1393   int scrollbar_show_plain (int update, int last_top, int last_bot, int scrollbar_len);
1394 #endif
1395
1396   // scrollbar.C
1397   void resize_scrollbar ();
1398   int scrollbar_mapping (int map);
1399   int scrollbar_show (int update);
1400   void setup_scrollbar (const char *scrollalign, const char *scrollstyle, const char *thickness);
1401
1402   // xdefaults.C
1403   void get_options (int argc, const char *const *argv);
1404   int parse_keysym (const char *str, const char *arg);
1405   const char *x_resource (const char *name);
1406   void extract_resources ();
1407 };
1408
1409 #endif                          /* _RXVT_H_ */
1410