1 |
#ifndef RXVT_H_ /* include once only */ |
2 |
#define RXVT_H_ |
3 |
|
4 |
#include <stdio.h> |
5 |
#include <ctype.h> |
6 |
#include <errno.h> |
7 |
#include <stdarg.h> |
8 |
#include <stdlib.h> |
9 |
#ifdef HAVE_STDINT_H |
10 |
#include <stdint.h> |
11 |
#endif |
12 |
#include <sys/types.h> |
13 |
#include <unistd.h> |
14 |
#include <string.h> |
15 |
#include <assert.h> |
16 |
#ifdef HAVE_SYS_IOCTL_H |
17 |
#include <sys/ioctl.h> |
18 |
#endif |
19 |
#ifdef HAVE_SYS_STRREDIR_H |
20 |
#include <sys/strredir.h> |
21 |
#endif |
22 |
|
23 |
#if HAVE_WCHAR_H |
24 |
# include <wchar.h> |
25 |
#else |
26 |
// stdlib.h might provide it |
27 |
#endif |
28 |
|
29 |
// we assume that Xlib.h defines XPointer, and it does since at least 1994... |
30 |
|
31 |
extern "C" { |
32 |
#include <X11/Xlib.h> |
33 |
#include <X11/Xutil.h> |
34 |
#include <X11/Xresource.h> |
35 |
} |
36 |
|
37 |
#if UNICODE_3 |
38 |
typedef uint32_t text_t; |
39 |
#else |
40 |
typedef uint16_t text_t; // saves lots of memory |
41 |
#endif |
42 |
typedef uint32_t rend_t; |
43 |
typedef int32_t tlen_t; // was int16_t, but this results in smaller code and memory use |
44 |
typedef int32_t tlen_t_; // specifically for use in the line_t structure |
45 |
|
46 |
#include "feature.h" |
47 |
|
48 |
#if defined (ISO_14755) || defined (ENABLE_PERL) |
49 |
# define ENABLE_OVERLAY 1 |
50 |
#endif |
51 |
|
52 |
#if ENABLE_PERL |
53 |
# define ENABLE_FRILLS 1 |
54 |
# define ENABLE_COMBINING 1 |
55 |
#endif |
56 |
|
57 |
#if ENABLE_FRILLS |
58 |
# define ENABLE_XEMBED 1 |
59 |
# define ENABLE_EWMH 1 |
60 |
# define ENABLE_XIM_ONTHESPOT 1 |
61 |
# define CURSOR_BLINK 1 |
62 |
# define OPTION_HC 1 |
63 |
# define BUILTIN_GLYPHS 1 |
64 |
#else |
65 |
# define ENABLE_MINIMAL 1 |
66 |
#endif |
67 |
|
68 |
#include <limits.h> |
69 |
|
70 |
#include <X11/cursorfont.h> |
71 |
#include <X11/keysym.h> |
72 |
#include <X11/keysymdef.h> |
73 |
#include <X11/Xatom.h> |
74 |
|
75 |
#if HAVE_PIXBUF |
76 |
# include <gdk-pixbuf/gdk-pixbuf.h> |
77 |
#endif |
78 |
|
79 |
#if XRENDER && (HAVE_PIXBUF || ENABLE_TRANSPARENCY) |
80 |
# define HAVE_IMG 1 |
81 |
#endif |
82 |
|
83 |
#define ECB_NO_THREADS 1 |
84 |
#include "ecb.h" |
85 |
|
86 |
#include "encoding.h" |
87 |
#include "rxvtutil.h" |
88 |
#include "rxvtfont.h" |
89 |
#include "rxvttoolkit.h" |
90 |
#include "rxvtimg.h" |
91 |
#include "scrollbar.h" |
92 |
#include "ev_cpp.h" |
93 |
#include "libptytty.h" |
94 |
|
95 |
#include "rxvtperl.h" |
96 |
|
97 |
// try to avoid some macros to decrease code size, on some systems |
98 |
#if ENABLE_MINIMAL |
99 |
# define strcmp(a,b) (strcmp)(a,b) |
100 |
# define strlen(a) (strlen)(a) |
101 |
# define strcpy(a,b) (strcpy)(a,b) |
102 |
# define memset(a,c,l) (memset)(a,c,l) |
103 |
# define memcpy(a,b,l) (memcpy)(a,b,l) |
104 |
#endif |
105 |
|
106 |
/* |
107 |
***************************************************************************** |
108 |
* SYSTEM HACKS |
109 |
***************************************************************************** |
110 |
*/ |
111 |
|
112 |
#include <termios.h> |
113 |
|
114 |
#ifndef STDIN_FILENO |
115 |
# define STDIN_FILENO 0 |
116 |
# define STDOUT_FILENO 1 |
117 |
# define STDERR_FILENO 2 |
118 |
#endif |
119 |
|
120 |
#ifndef EXIT_SUCCESS /* missing from <stdlib.h> */ |
121 |
# define EXIT_SUCCESS 0 /* exit function success */ |
122 |
# define EXIT_FAILURE 1 /* exit function failure */ |
123 |
#endif |
124 |
|
125 |
/****************************************************************************/ |
126 |
|
127 |
// exception thrown on fatal (per-instance) errors |
128 |
class rxvt_failure_exception { }; |
129 |
|
130 |
// exception thrown when the command parser runs out of input data |
131 |
class out_of_input { }; |
132 |
|
133 |
/* |
134 |
***************************************************************************** |
135 |
* PROTOTYPES |
136 |
***************************************************************************** |
137 |
*/ |
138 |
// main.C |
139 |
#define SET_LOCALE(locale) rxvt_set_locale (locale) |
140 |
extern bool rxvt_set_locale (const char *locale) noexcept; |
141 |
extern void rxvt_push_locale (const char *locale) noexcept; |
142 |
extern void rxvt_pop_locale () noexcept; |
143 |
void rxvt_init (); |
144 |
|
145 |
// misc.C |
146 |
char * rxvt_wcstombs (const wchar_t *str, int len = -1); |
147 |
wchar_t * rxvt_mbstowcs (const char *str, int len = -1); |
148 |
char * rxvt_wcstoutf8 (const wchar_t *str, int len = -1); |
149 |
wchar_t * rxvt_utf8towcs (const char *str, int len = -1); |
150 |
|
151 |
const char * rxvt_basename (const char *str) noexcept; |
152 |
void rxvt_vlog (const char *fmt, va_list arg_ptr) noexcept; |
153 |
void rxvt_log (const char *fmt,...) noexcept; |
154 |
void rxvt_warn (const char *fmt,...) noexcept; |
155 |
ecb_noreturn ecb_cold |
156 |
void rxvt_fatal (const char *fmt, ...); |
157 |
ecb_noreturn ecb_cold |
158 |
void rxvt_exit_failure (); |
159 |
|
160 |
void * rxvt_malloc (size_t size); |
161 |
void * rxvt_calloc (size_t number, size_t size); |
162 |
void * rxvt_realloc (void *ptr, size_t size); |
163 |
|
164 |
char * rxvt_strtrim (char *str) noexcept; |
165 |
char ** rxvt_strsplit (char delim, const char *str) noexcept; |
166 |
|
167 |
static inline void |
168 |
rxvt_free_strsplit (char **ptr) noexcept |
169 |
{ |
170 |
free (ptr[0]); |
171 |
free (ptr); |
172 |
} |
173 |
|
174 |
KeySym rxvt_XKeycodeToKeysym (Display *dpy, KeyCode keycode, int index); |
175 |
|
176 |
///////////////////////////////////////////////////////////////////////////// |
177 |
|
178 |
// temporarily replace the process environment |
179 |
extern char **environ; |
180 |
extern char **rxvt_environ; // the original environ pointer |
181 |
|
182 |
static inline void |
183 |
set_environ (char **envv) |
184 |
{ |
185 |
#if ENABLE_PERL |
186 |
assert (envv); |
187 |
#else |
188 |
if (envv) |
189 |
#endif |
190 |
environ = envv; |
191 |
} |
192 |
|
193 |
struct localise_env |
194 |
{ |
195 |
char **orig_env; |
196 |
|
197 |
localise_env (char **new_env) |
198 |
{ |
199 |
orig_env = environ; |
200 |
environ = new_env; |
201 |
} |
202 |
|
203 |
~localise_env () |
204 |
{ |
205 |
environ = orig_env; |
206 |
} |
207 |
}; |
208 |
|
209 |
/* |
210 |
***************************************************************************** |
211 |
* STRUCTURES AND TYPEDEFS |
212 |
***************************************************************************** |
213 |
*/ |
214 |
|
215 |
/* |
216 |
* the 'essential' information for reporting Mouse Events |
217 |
* pared down from XButtonEvent |
218 |
*/ |
219 |
struct mouse_event |
220 |
{ |
221 |
int clicks; |
222 |
Time time; /* milliseconds */ |
223 |
unsigned int state; /* key or button mask */ |
224 |
unsigned int button; /* detail */ |
225 |
}; |
226 |
|
227 |
#if ENABLE_XEMBED |
228 |
// XEMBED messages |
229 |
# define XEMBED_EMBEDDED_NOTIFY 0 |
230 |
# define XEMBED_WINDOW_ACTIVATE 1 |
231 |
# define XEMBED_WINDOW_DEACTIVATE 2 |
232 |
# define XEMBED_REQUEST_FOCUS 3 |
233 |
# define XEMBED_FOCUS_IN 4 |
234 |
# define XEMBED_FOCUS_OUT 5 |
235 |
# define XEMBED_FOCUS_NEXT 6 |
236 |
# define XEMBED_FOCUS_PREV 7 |
237 |
|
238 |
# define XEMBED_MODALITY_ON 10 |
239 |
# define XEMBED_MODALITY_OFF 11 |
240 |
# define XEMBED_REGISTER_ACCELERATOR 12 |
241 |
# define XEMBED_UNREGISTER_ACCELERATOR 13 |
242 |
# define XEMBED_ACTIVATE_ACCELERATOR 14 |
243 |
|
244 |
// XEMBED detail code |
245 |
# define XEMBED_FOCUS_CURRENT 0 |
246 |
# define XEMBED_FOCUS_FIRST 1 |
247 |
# define XEMBED_FOCUS_LAST 2 |
248 |
|
249 |
# define XEMBED_MAPPED (1 << 0) |
250 |
#endif |
251 |
|
252 |
/* |
253 |
***************************************************************************** |
254 |
* NORMAL DEFINES |
255 |
***************************************************************************** |
256 |
*/ |
257 |
|
258 |
/* COLORTERM, TERM environment variables */ |
259 |
#define COLORTERMENV "rxvt" |
260 |
#if HAVE_IMG |
261 |
# define COLORTERMENVFULL COLORTERMENV "-xpm" |
262 |
#else |
263 |
# define COLORTERMENVFULL COLORTERMENV |
264 |
#endif |
265 |
#ifndef TERMENV |
266 |
# if USE_256_COLORS |
267 |
# define TERMENV "rxvt-unicode-256color" |
268 |
# else |
269 |
# define TERMENV "rxvt-unicode" |
270 |
# endif |
271 |
#endif |
272 |
|
273 |
// Hidden color cube for indexed 24-bit colors. There are fewer blue levels |
274 |
// because normal human eye is less sensitive to the blue component than to |
275 |
// the red or green. (https://en.m.wikipedia.org/wiki/Color_depth#8-bit_color) |
276 |
#if USE_256_COLORS |
277 |
// 7x7x5=245 < 254 unused color indices |
278 |
# define Red_levels 7 |
279 |
# define Green_levels 7 |
280 |
# define Blue_levels 5 |
281 |
#else |
282 |
// 6x6x4=144 < 166 unused color indices |
283 |
# define Red_levels 6 |
284 |
# define Green_levels 6 |
285 |
# define Blue_levels 4 |
286 |
#endif |
287 |
|
288 |
#define RGB24_CUBE_SIZE (Red_levels * Green_levels * Blue_levels) |
289 |
|
290 |
#if defined (NO_MOUSE_REPORT) && !defined (NO_MOUSE_REPORT_SCROLLBAR) |
291 |
# define NO_MOUSE_REPORT_SCROLLBAR 1 |
292 |
#endif |
293 |
|
294 |
#define scrollBar_esc 30 |
295 |
|
296 |
#if !defined (RXVT_SCROLLBAR) && !defined (NEXT_SCROLLBAR) |
297 |
# define NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING 1 |
298 |
#endif |
299 |
|
300 |
enum { |
301 |
NO_REFRESH = 0, /* Window not visible at all! */ |
302 |
FAST_REFRESH = 1, /* Fully exposed window */ |
303 |
SLOW_REFRESH = 2, /* Partially exposed window */ |
304 |
}; |
305 |
|
306 |
#ifdef NO_SECONDARY_SCREEN |
307 |
# define NSCREENS 0 |
308 |
#else |
309 |
# define NSCREENS 1 |
310 |
#endif |
311 |
|
312 |
/* flags for rxvt_term::scr_gotorc () */ |
313 |
enum { |
314 |
C_RELATIVE = 1, /* col movement is relative */ |
315 |
R_RELATIVE = 2, /* row movement is relative */ |
316 |
RELATIVE = C_RELATIVE | R_RELATIVE, |
317 |
}; |
318 |
|
319 |
/* modes for rxvt_term::scr_insdel_chars (), rxvt_term::scr_insdel_lines () */ |
320 |
enum { |
321 |
INSERT = -1, /* don't change these values */ |
322 |
DELETE = +1, |
323 |
ERASE = +2, |
324 |
}; |
325 |
|
326 |
/* modes for rxvt_term::scr_page () - scroll page. used by scrollbar window */ |
327 |
enum page_dirn { |
328 |
DN = -1, |
329 |
NO_DIR = 0, |
330 |
UP = 1, |
331 |
}; |
332 |
|
333 |
/* arguments for rxvt_term::scr_change_screen () */ |
334 |
enum { |
335 |
PRIMARY = 0, |
336 |
SECONDARY, |
337 |
}; |
338 |
|
339 |
// define various rendition bits and masks. the rendition word |
340 |
// is 32 bits in size, and we should use it as efficiently as possible |
341 |
|
342 |
#define RS_None 0 |
343 |
|
344 |
// GET_BGATTR depends on RS_fgShift > RS_bgShift |
345 |
#define RS_colorMask ((1UL << Color_Bits) - 1UL) |
346 |
#define RS_bgShift 0 |
347 |
#define RS_fgShift (RS_bgShift + Color_Bits) |
348 |
#define RS_bgMask (RS_colorMask << RS_bgShift) |
349 |
#define RS_fgMask (RS_colorMask << RS_fgShift) |
350 |
|
351 |
// must have space for rxvt_fontset::fontCount * 2 + 2 values |
352 |
#define RS_fontShift (RS_fgShift + Color_Bits) |
353 |
#define RS_Careful (1UL << RS_fontShift) /* be careful when drawing these */ |
354 |
#define RS_fontCount rxvt_fontset::fontCount |
355 |
#define RS_fontMask ((RS_fontCount << (RS_fontShift + 1)) | RS_Careful) // includes RS_Careful |
356 |
|
357 |
// toggle this to force redraw, must be != RS_Careful and otherwise "pretty neutral" |
358 |
#define RS_redraw (2UL << RS_fontShift) |
359 |
|
360 |
#define RS_Sel (1UL << 22) |
361 |
|
362 |
// 4 custom bits for extensions |
363 |
#define RS_customCount 16UL |
364 |
#define RS_customShift 23 |
365 |
#define RS_customMask ((RS_customCount - 1UL) << RS_customShift) |
366 |
|
367 |
// font styles |
368 |
#define RS_Bold (1UL << RS_styleShift) |
369 |
#define RS_Italic (2UL << RS_styleShift) |
370 |
|
371 |
#define RS_styleCount 4 |
372 |
#define RS_styleShift 27 |
373 |
#define RS_styleMask (RS_Bold | RS_Italic) |
374 |
|
375 |
// fake styles |
376 |
#define RS_Blink (1UL << 29) |
377 |
#define RS_RVid (1UL << 30) // reverse video |
378 |
#define RS_Uline (1UL << 31) // underline |
379 |
|
380 |
#define RS_baseattrMask (RS_Italic | RS_Bold | RS_Blink | RS_RVid | RS_Uline) |
381 |
#define RS_attrMask (RS_baseattrMask | RS_fontMask) |
382 |
|
383 |
#define DEFAULT_RSTYLE (RS_None | (Color_fg << RS_fgShift) | (Color_bg << RS_bgShift)) |
384 |
#define OVERLAY_RSTYLE (RS_None | (Color_Black << RS_fgShift) | (Color_Yellow << RS_bgShift)) |
385 |
|
386 |
enum { |
387 |
C0_NUL = 0x00, |
388 |
C0_SOH, C0_STX, C0_ETX, C0_EOT, C0_ENQ, C0_ACK, C0_BEL, |
389 |
C0_BS , C0_HT , C0_LF , C0_VT , C0_FF , C0_CR , C0_SO , C0_SI , |
390 |
C0_DLE, C0_DC1, C0_DC2, D0_DC3, C0_DC4, C0_NAK, C0_SYN, C0_ETB, |
391 |
C0_CAN, C0_EM , C0_SUB, C0_ESC, C0_IS4, C0_IS3, C0_IS2, C0_IS1, |
392 |
}; |
393 |
#define CHAR_ST 0x9c /* 0234 */ |
394 |
|
395 |
/* |
396 |
* XTerm Operating System Commands: ESC ] Ps;Pt (ST|BEL) |
397 |
* colour extensions by Christian W. Zuckschwerdt <zany@triq.net> |
398 |
*/ |
399 |
enum { |
400 |
XTerm_name = 0, |
401 |
XTerm_iconName = 1, |
402 |
XTerm_title = 2, |
403 |
XTerm_property = 3, // change X property |
404 |
XTerm_Color = 4, // change colors |
405 |
XTerm_Color00 = 10, // change fg color |
406 |
XTerm_Color01 = 11, // change bg color |
407 |
XTerm_Color_cursor = 12, // change actual 'Cursor' color |
408 |
XTerm_Color_pointer_fg = 13, // change actual 'Pointer' fg color |
409 |
XTerm_Color_pointer_bg = 14, // change actual 'Pointer' bg color |
410 |
XTerm_Color05 = 15, // not implemented (tektronix fg) |
411 |
XTerm_Color06 = 16, // not implemented (tektronix bg) |
412 |
XTerm_Color_HC = 17, // change actual 'Highlight' bg color |
413 |
XTerm_Color_HTC = 19, // change actual 'Highlight' fg color |
414 |
XTerm_logfile = 46, // not implemented |
415 |
XTerm_font = 50, |
416 |
|
417 |
XTerm_konsole30 = 30, // reserved for konsole |
418 |
XTerm_konsole31 = 31, // reserved for konsole |
419 |
XTerm_emacs51 = 51, // reserved for emacs shell |
420 |
/* |
421 |
* rxvt extensions of XTerm OSCs: ESC ] Ps;Pt (ST|BEL) |
422 |
*/ |
423 |
|
424 |
// deprecated |
425 |
Rxvt_restoreFG = 39, |
426 |
Rxvt_restoreBG = 49, |
427 |
|
428 |
Rxvt_dumpscreen = 55, // dump scrollback and all of screen |
429 |
|
430 |
URxvt_locale = 701, // change locale |
431 |
URxvt_version = 702, // request version |
432 |
|
433 |
URxvt_Color_IT = 704, // change actual 'Italic' colour |
434 |
URxvt_Color_BD = 706, // change actual 'Bold' color |
435 |
URxvt_Color_UL = 707, // change actual 'Underline' color |
436 |
URxvt_Color_border = 708, |
437 |
|
438 |
URxvt_font = 710, |
439 |
URxvt_boldFont = 711, |
440 |
URxvt_italicFont = 712, |
441 |
URxvt_boldItalicFont = 713, |
442 |
|
443 |
URxvt_view_up = 720, |
444 |
URxvt_view_down = 721, |
445 |
|
446 |
URxvt_perl = 777, // for use by perl extensions, starts with "extension-name;" |
447 |
}; |
448 |
|
449 |
/* Words starting with `Color_' are colours. Others are counts */ |
450 |
/* |
451 |
* The PixColor and rendition colour usage should probably be decoupled |
452 |
* on the unnecessary items, e.g. Color_pointer, but won't bother |
453 |
* until we need to. Also, be aware of usage in pixcolor_set |
454 |
*/ |
455 |
|
456 |
enum colour_list { |
457 |
Color_none = -2, |
458 |
Color_transparent = -1, |
459 |
Color_fg = 0, |
460 |
Color_bg, |
461 |
minCOLOR, /* 2 */ |
462 |
Color_Black = minCOLOR, |
463 |
Color_Red3, |
464 |
Color_Green3, |
465 |
Color_Yellow3, |
466 |
Color_Blue3, |
467 |
Color_Magenta3, |
468 |
Color_Cyan3, |
469 |
maxCOLOR, /* minCOLOR + 7 */ |
470 |
#ifndef NO_BRIGHTCOLOR |
471 |
Color_AntiqueWhite = maxCOLOR, |
472 |
minBrightCOLOR, /* maxCOLOR + 1 */ |
473 |
Color_Grey25 = minBrightCOLOR, |
474 |
Color_Red, |
475 |
Color_Green, |
476 |
Color_Yellow, |
477 |
Color_Blue, |
478 |
Color_Magenta, |
479 |
Color_Cyan, |
480 |
maxBrightCOLOR, /* minBrightCOLOR + 7 */ |
481 |
Color_White = maxBrightCOLOR, |
482 |
#else |
483 |
Color_White = maxCOLOR, |
484 |
#endif |
485 |
minTermCOLOR = Color_White + 1, |
486 |
#if USE_256_COLORS |
487 |
maxTermCOLOR = Color_White + 240, |
488 |
#else |
489 |
maxTermCOLOR = Color_White + 72, |
490 |
#endif |
491 |
minTermCOLOR24, |
492 |
maxTermCOLOR24 = minTermCOLOR24 + |
493 |
RGB24_CUBE_SIZE - 1, |
494 |
#ifndef NO_CURSORCOLOR |
495 |
Color_cursor, |
496 |
Color_cursor2, |
497 |
#endif |
498 |
Color_pointer_fg, |
499 |
Color_pointer_bg, |
500 |
Color_border, |
501 |
#ifndef NO_BOLD_UNDERLINE_REVERSE |
502 |
Color_BD, |
503 |
Color_IT, |
504 |
Color_UL, |
505 |
Color_RV, |
506 |
#endif |
507 |
#if ENABLE_FRILLS |
508 |
Color_underline, |
509 |
#endif |
510 |
#ifdef OPTION_HC |
511 |
Color_HC, |
512 |
Color_HTC, |
513 |
#endif |
514 |
Color_scroll, |
515 |
#ifdef RXVT_SCROLLBAR |
516 |
Color_trough, |
517 |
#endif |
518 |
#if OFF_FOCUS_FADING |
519 |
Color_fade, |
520 |
#endif |
521 |
NRS_COLORS, /* */ |
522 |
#ifdef RXVT_SCROLLBAR |
523 |
Color_topShadow = NRS_COLORS, |
524 |
Color_bottomShadow, |
525 |
TOTAL_COLORS |
526 |
#else |
527 |
TOTAL_COLORS = NRS_COLORS |
528 |
#endif |
529 |
}; |
530 |
|
531 |
#if USE_256_COLORS |
532 |
# define Color_Bits 9 // 0 .. maxTermCOLOR24 |
533 |
#else |
534 |
# define Color_Bits 8 // 0 .. maxTermCOLOR24 |
535 |
#endif |
536 |
|
537 |
#if maxTermCOLOR24 >= (1 << Color_Bits) |
538 |
# error color index overflow |
539 |
#endif |
540 |
|
541 |
/* |
542 |
* Resource list |
543 |
*/ |
544 |
enum { |
545 |
# define def(name) Rs_ ## name, |
546 |
# define reserve(name,count) Rs_ ## name ## _ = Rs_ ## name + (count) - 1, |
547 |
# include "rsinc.h" |
548 |
# undef def |
549 |
# undef reserve |
550 |
NUM_RESOURCES |
551 |
}; |
552 |
|
553 |
/* DEC private modes */ |
554 |
#define PrivMode_132 (1UL<<0) |
555 |
#define PrivMode_132OK (1UL<<1) |
556 |
#define PrivMode_rVideo (1UL<<2) |
557 |
#define PrivMode_relOrigin (1UL<<3) |
558 |
#define PrivMode_Screen (1UL<<4) |
559 |
#define PrivMode_Autowrap (1UL<<5) |
560 |
#define PrivMode_aplCUR (1UL<<6) |
561 |
#define PrivMode_aplKP (1UL<<7) |
562 |
#define PrivMode_HaveBackSpace (1UL<<8) |
563 |
#define PrivMode_BackSpace (1UL<<9) |
564 |
#define PrivMode_ShiftKeys (1UL<<10) |
565 |
#define PrivMode_VisibleCursor (1UL<<11) |
566 |
#define PrivMode_MouseX10 (1UL<<12) |
567 |
#define PrivMode_MouseX11 (1UL<<13) |
568 |
#define PrivMode_scrollBar (1UL<<14) |
569 |
#define PrivMode_TtyOutputInh (1UL<<15) |
570 |
#define PrivMode_Keypress (1UL<<16) |
571 |
#define PrivMode_smoothScroll (1UL<<17) |
572 |
#define PrivMode_vt52 (1UL<<18) |
573 |
#define PrivMode_LFNL (1UL<<19) |
574 |
#define PrivMode_MouseBtnEvent (1UL<<20) |
575 |
#define PrivMode_MouseAnyEvent (1UL<<21) |
576 |
#define PrivMode_BracketPaste (1UL<<22) |
577 |
#define PrivMode_ExtMouseUTF8 (1UL<<23) // xterm pseudo-utf-8 hack |
578 |
#define PrivMode_ExtMouseUrxvt (1UL<<24) // xterm pseudo-utf-8, but works in non-utf-8-locales |
579 |
#define PrivMode_BlinkingCursor (1UL<<25) |
580 |
#define PrivMode_FocusEvent (1UL<<26) |
581 |
#define PrivMode_ExtMouseSGR (1UL<<27) |
582 |
|
583 |
#define PrivMode_mouse_report (PrivMode_MouseX10|PrivMode_MouseX11|PrivMode_MouseBtnEvent|PrivMode_MouseAnyEvent) |
584 |
|
585 |
#ifdef ALLOW_132_MODE |
586 |
# define PrivMode_Default (PrivMode_Autowrap|PrivMode_ShiftKeys|PrivMode_VisibleCursor|PrivMode_132OK) |
587 |
#else |
588 |
# define PrivMode_Default (PrivMode_Autowrap|PrivMode_ShiftKeys|PrivMode_VisibleCursor) |
589 |
#endif |
590 |
|
591 |
// do not change these constants lightly, there are many interdependencies |
592 |
#define IMBUFSIZ 128 // input modifier buffer sizes |
593 |
#define KBUFSZ 512 // size of keyboard mapping buffer |
594 |
#define CBUFSIZ 32768 // size of command buffer (longest command sequence possible) |
595 |
#define CBUFCNT 8 // never call pty_fill/cmd_parse more than this often in a row |
596 |
#define UBUFSIZ 2048 // character buffer |
597 |
|
598 |
#if ENABLE_FRILLS |
599 |
# include <X11/Xmd.h> |
600 |
typedef struct _mwmhints |
601 |
{ |
602 |
CARD32 flags; |
603 |
CARD32 functions; |
604 |
CARD32 decorations; |
605 |
INT32 input_mode; |
606 |
CARD32 status; |
607 |
} MWMHints; |
608 |
#endif |
609 |
|
610 |
/* Motif window hints */ |
611 |
#define MWM_HINTS_FUNCTIONS (1L << 0) |
612 |
#define MWM_HINTS_DECORATIONS (1L << 1) |
613 |
#define MWM_HINTS_INPUT_MODE (1L << 2) |
614 |
#define MWM_HINTS_STATUS (1L << 3) |
615 |
/* bit definitions for MwmHints.functions */ |
616 |
#define MWM_FUNC_ALL (1L << 0) |
617 |
#define MWM_FUNC_RESIZE (1L << 1) |
618 |
#define MWM_FUNC_MOVE (1L << 2) |
619 |
#define MWM_FUNC_MINIMIZE (1L << 3) |
620 |
#define MWM_FUNC_MAXIMIZE (1L << 4) |
621 |
#define MWM_FUNC_CLOSE (1L << 5) |
622 |
/* bit definitions for MwmHints.decorations */ |
623 |
#define MWM_DECOR_ALL (1L << 0) |
624 |
#define MWM_DECOR_BORDER (1L << 1) |
625 |
#define MWM_DECOR_RESIZEH (1L << 2) |
626 |
#define MWM_DECOR_TITLE (1L << 3) |
627 |
#define MWM_DECOR_MENU (1L << 4) |
628 |
#define MWM_DECOR_MINIMIZE (1L << 5) |
629 |
#define MWM_DECOR_MAXIMIZE (1L << 6) |
630 |
/* bit definitions for MwmHints.inputMode */ |
631 |
#define MWM_INPUT_MODELESS 0 |
632 |
#define MWM_INPUT_PRIMARY_APPLICATION_MODAL 1 |
633 |
#define MWM_INPUT_SYSTEM_MODAL 2 |
634 |
#define MWM_INPUT_FULL_APPLICATION_MODAL 3 |
635 |
#define PROP_MWM_HINTS_ELEMENTS 5 |
636 |
|
637 |
/* |
638 |
***************************************************************************** |
639 |
* MACRO DEFINES |
640 |
***************************************************************************** |
641 |
*/ |
642 |
|
643 |
// speed hack, copy some member variable into a local variable of the same name |
644 |
#define dLocal(type,name) type const name = this->name |
645 |
|
646 |
// for speed reasons, we assume that all codepoints 32 to 126 are |
647 |
// single-width. |
648 |
#define WCWIDTH(c) (IN_RANGE_INC (c, 0x20, 0x7e) ? 1 : wcwidth (c)) |
649 |
|
650 |
/* convert pixel dimensions to row/column values. Everything as int32_t */ |
651 |
#define Pixel2Col(x) Pixel2Width((int32_t)(x)) |
652 |
#define Pixel2Row(y) Pixel2Height((int32_t)(y)) |
653 |
#define Pixel2Width(x) ((int32_t)(x) / (int32_t)fwidth) |
654 |
#define Pixel2Height(y) ((int32_t)(y) / (int32_t)fheight) |
655 |
#define Col2Pixel(col) ((int32_t)Width2Pixel(col)) |
656 |
#define Row2Pixel(row) ((int32_t)Height2Pixel(row)) |
657 |
#define Width2Pixel(n) ((int32_t)(n) * (int32_t)fwidth) |
658 |
#define Height2Pixel(n) ((int32_t)(n) * (int32_t)fheight) |
659 |
|
660 |
#define LINENO_of(t,n) MOD ((t)->term_start + int(n), (t)->total_rows) |
661 |
#define ROW_of(t,n) (t)->row_buf [LINENO_of ((t), n)] |
662 |
|
663 |
#define LINENO(n) LINENO_of (this, n) |
664 |
#define ROW(n) ROW_of (this, n) |
665 |
|
666 |
/* how to build & extract colors and attributes */ |
667 |
#define GET_BASEFG(x) (((x) & RS_fgMask) >> RS_fgShift) |
668 |
#define GET_BASEBG(x) (((x) & RS_bgMask) >> RS_bgShift) |
669 |
|
670 |
#define GET_FONT(x) (((x) & RS_fontMask) >> RS_fontShift) |
671 |
#define SET_FONT(x,fid) (((x) & ~RS_fontMask) | ((fid) << RS_fontShift)) |
672 |
|
673 |
#define GET_STYLE(x) (((x) & RS_styleMask) >> RS_styleShift) |
674 |
#define SET_STYLE(x,style) (((x) & ~RS_styleMask) | ((style) << RS_styleShift)) |
675 |
|
676 |
#define GET_ATTR(x) (((x) & RS_attrMask)) |
677 |
#define SET_FGCOLOR(x,fg) (((x) & ~RS_fgMask) | ((fg) << RS_fgShift)) |
678 |
#define SET_BGCOLOR(x,bg) (((x) & ~RS_bgMask) | ((bg) << RS_bgShift)) |
679 |
#define SET_ATTR(x,a) (((x) & ~RS_attrMask) | (a)) |
680 |
|
681 |
#define RS_SAME(a,b) (!(((a) ^ (b)) & ~RS_Careful)) |
682 |
|
683 |
#define PIXCOLOR_NAME(idx) rs[Rs_color + (idx)] |
684 |
#define ISSET_PIXCOLOR(idx) (!!rs[Rs_color + (idx)]) |
685 |
|
686 |
#if ENABLE_STYLES |
687 |
# define FONTSET_of(t,style) (t)->fontset[GET_STYLE (style)] |
688 |
#else |
689 |
# define FONTSET_of(t,style) (t)->fontset[0] |
690 |
#endif |
691 |
|
692 |
#define FONTSET(style) FONTSET_of (this, style) |
693 |
|
694 |
typedef callback<void (const char *)> log_callback; |
695 |
typedef callback<int (int)> getfd_callback; |
696 |
|
697 |
/****************************************************************************/ |
698 |
|
699 |
#define LINE_LONGER 0x0001 // line is continued on the next row |
700 |
#define LINE_FILTERED 0x0002 // line has been filtered |
701 |
#define LINE_COMPRESSED 0x0004 // line has been compressed (NYI) |
702 |
#define LINE_FILTER 0x0008 // line needs to be filtered before display (NYI) |
703 |
#define LINE_BIDI 0x0010 // line needs bidi (NYI) |
704 |
|
705 |
struct line_t |
706 |
{ |
707 |
text_t *t; // terminal the text |
708 |
rend_t *r; // rendition, uses RS_ flags |
709 |
tlen_t_ l; // length of each text line |
710 |
uint32_t f; // flags |
711 |
|
712 |
bool valid () |
713 |
{ |
714 |
return l >= 0; |
715 |
} |
716 |
|
717 |
void alloc () |
718 |
{ |
719 |
l = 0; |
720 |
} |
721 |
|
722 |
bool is_longer () |
723 |
{ |
724 |
return f & LINE_LONGER; |
725 |
} |
726 |
|
727 |
void is_longer (int set) |
728 |
{ |
729 |
if (set) |
730 |
f |= LINE_LONGER; |
731 |
else |
732 |
f &= ~LINE_LONGER; |
733 |
} |
734 |
|
735 |
void clear () |
736 |
{ |
737 |
t = 0; |
738 |
r = 0; |
739 |
l = 0; |
740 |
f = 0; |
741 |
} |
742 |
|
743 |
void touch () // call whenever a line is changed/touched/updated |
744 |
{ |
745 |
#if ENABLE_PERL |
746 |
f &= ~LINE_FILTERED; |
747 |
#endif |
748 |
} |
749 |
|
750 |
void touch (int col) |
751 |
{ |
752 |
max_it (l, col); |
753 |
touch (); |
754 |
} |
755 |
}; |
756 |
|
757 |
/****************************************************************************/ |
758 |
|
759 |
// primitive wrapper around mbstate_t to ensure initialisation |
760 |
struct mbstate |
761 |
{ |
762 |
mbstate_t mbs; |
763 |
|
764 |
operator mbstate_t *() { return &mbs; } |
765 |
void reset () { memset (&mbs, 0, sizeof (mbs)); } |
766 |
mbstate () { reset (); } |
767 |
}; |
768 |
|
769 |
/****************************************************************************/ |
770 |
|
771 |
#define UNICODE_MASK 0x1fffffUL |
772 |
|
773 |
#if UNICODE_3 |
774 |
# define COMPOSE_LO 0x110000UL |
775 |
# define COMPOSE_HI 0x1fffffUL |
776 |
# define IS_COMPOSE(n) ((int32_t)(n) >= COMPOSE_LO) |
777 |
#else |
778 |
# if ENABLE_PERL |
779 |
# define COMPOSE_LO 0xe000UL // our _own_ functions don't like (illegal) surrogates |
780 |
# define COMPOSE_HI 0xf8ffUL // in utf-8, so use private use area only |
781 |
# else |
782 |
# define COMPOSE_LO 0xd800UL |
783 |
# define COMPOSE_HI 0xf8ffUL |
784 |
# endif |
785 |
# define IS_COMPOSE(n) IN_RANGE_INC ((n), COMPOSE_LO, COMPOSE_HI) |
786 |
#endif |
787 |
|
788 |
#if ENABLE_COMBINING |
789 |
// compose chars are used to represent composite characters |
790 |
// that are not representable in unicode, as well as characters |
791 |
// not fitting in the BMP. |
792 |
struct compose_char |
793 |
{ |
794 |
// c1 can be any chaarcter != NOCHAR, including another compose character |
795 |
// c2 must always be a zero-width character or NOCHAR, in case |
796 |
// this just extends beyondthe BMP. |
797 |
unicode_t c1, c2; |
798 |
|
799 |
compose_char (unicode_t c1, unicode_t c2) |
800 |
: c1(c1), c2(c2) |
801 |
{ } |
802 |
}; |
803 |
|
804 |
struct rxvt_composite_vec |
805 |
{ |
806 |
vector<compose_char> v; |
807 |
|
808 |
text_t compose (unicode_t c1, unicode_t c2 = NOCHAR); |
809 |
template<typename T> int expand (unicode_t c, T *r); |
810 |
int expand (unicode_t c) { return expand (c, (text_t *)0); } |
811 |
compose_char *operator [](text_t c) |
812 |
{ |
813 |
return c >= COMPOSE_LO && c < COMPOSE_LO + v.size () |
814 |
? &v[c - COMPOSE_LO] |
815 |
: 0; |
816 |
} |
817 |
}; |
818 |
|
819 |
extern class rxvt_composite_vec rxvt_composite; |
820 |
#endif |
821 |
|
822 |
// expand the sequence into a static array |
823 |
// works even without ENABLE_COMBINING |
824 |
template<typename T> |
825 |
struct rxvt_compose_expand_static |
826 |
{ |
827 |
#if ENABLE_COMBINING |
828 |
// we arbitrarily limit the maximum number of compose sequences |
829 |
// so we can store them in a static array on the stack. |
830 |
enum { max_size = 48 }; |
831 |
|
832 |
T chrs[max_size]; |
833 |
|
834 |
// expand sequence and return start ptr |
835 |
// guarantees at least one output |
836 |
// get the length with length () on that ptr |
837 |
T *operator ()(unicode_t c) |
838 |
{ |
839 |
T *cur = chrs + max_size; |
840 |
|
841 |
while (ecb_expect_false (IS_COMPOSE (c))) |
842 |
if (ecb_expect_true (c - COMPOSE_LO < rxvt_composite.v.size ())) |
843 |
{ |
844 |
compose_char *cc = &rxvt_composite.v [c - COMPOSE_LO]; |
845 |
|
846 |
if (cc->c2 != NOCHAR) |
847 |
{ |
848 |
cur -= cur > chrs; *cur = cc->c2; |
849 |
} |
850 |
|
851 |
c = cc->c1; |
852 |
} |
853 |
else |
854 |
c = NOCHAR; |
855 |
|
856 |
cur -= cur > chrs; *cur = c; |
857 |
|
858 |
return cur; |
859 |
} |
860 |
|
861 |
int length (T *first) |
862 |
{ |
863 |
return chrs + max_size - first; |
864 |
} |
865 |
#else |
866 |
T chr; |
867 |
|
868 |
T *operator ()(text_t c); |
869 |
{ |
870 |
chr = c; |
871 |
return &chr; |
872 |
} |
873 |
|
874 |
int length (T *first) |
875 |
{ |
876 |
return 1; |
877 |
} |
878 |
#endif |
879 |
}; |
880 |
|
881 |
/****************************************************************************/ |
882 |
|
883 |
#ifdef KEYSYM_RESOURCE |
884 |
class keyboard_manager; |
885 |
#endif |
886 |
|
887 |
typedef struct rxvt_term *rxvt_t; |
888 |
|
889 |
extern rxvt_t rxvt_current_term; |
890 |
|
891 |
#define SET_R(r) rxvt_current_term = const_cast<rxvt_term *>(r) |
892 |
#define GET_R rxvt_current_term |
893 |
|
894 |
/* ------------------------------------------------------------------------- */ |
895 |
struct overlay_base |
896 |
{ |
897 |
int x, y, w, h; // overlay dimensions |
898 |
text_t **text; |
899 |
rend_t **rend; |
900 |
|
901 |
// while tempting to add swap() etc. here, it effectively only increases code size |
902 |
}; |
903 |
|
904 |
/* ------------------------------------------------------------------------- */ |
905 |
|
906 |
typedef struct |
907 |
{ |
908 |
int row; |
909 |
int col; |
910 |
} row_col_t; |
911 |
|
912 |
/* |
913 |
* terminal limits: |
914 |
* |
915 |
* width : 1 <= width |
916 |
* height : 1 <= height |
917 |
* ncol : 1 <= ncol <= MAX(tlen_t) |
918 |
* nrow : 1 <= nrow <= MAX(int) |
919 |
* saveLines : 0 <= saveLines <= MAX(int) |
920 |
* term_start : 0 <= term_start < saveLines |
921 |
* total_rows : nrow + saveLines |
922 |
* |
923 |
* top_row : -saveLines <= top_row <= 0 |
924 |
* view_start : top_row <= view_start <= 0 |
925 |
* |
926 |
* | most coordinates are stored relative to term_start, |
927 |
* ROW_BUF | which is the first line of the terminal screen |
928 |
* |························= row_buf[0] |
929 |
* |························= row_buf[1] |
930 |
* |························= row_buf[2] etc. |
931 |
* | |
932 |
* +------------+···········= term_start + top_row |
933 |
* | scrollback | |
934 |
* | scrollback +---------+·= term_start + view_start |
935 |
* | scrollback | display | |
936 |
* | scrollback | display | |
937 |
* +------------+·display·+·= term_start |
938 |
* | terminal | display | |
939 |
* | terminal +---------+ |
940 |
* | terminal | |
941 |
* | terminal | |
942 |
* +------------+···········= term_start + nrow - 1 |
943 |
* | |
944 |
* | |
945 |
* END······················= total_rows |
946 |
*/ |
947 |
|
948 |
struct TermWin_t |
949 |
{ |
950 |
int vt_width; /* actual window width [pixels] */ |
951 |
int vt_height; /* actual window height [pixels] */ |
952 |
int width; /* window width [pixels] */ |
953 |
int height; /* window height [pixels] */ |
954 |
int fwidth; /* font width [pixels] */ |
955 |
int fheight; /* font height [pixels] */ |
956 |
int fbase; /* font ascent (baseline) [pixels] */ |
957 |
int ncol; /* window columns [characters] */ |
958 |
int nrow; /* window rows [characters] */ |
959 |
int focus; /* window has focus */ |
960 |
int mapped; /* window state mapped? */ |
961 |
int int_bwidth; /* internal border width */ |
962 |
int ext_bwidth; /* external border width */ |
963 |
int lineSpace; /* number of extra pixels between rows */ |
964 |
int letterSpace; /* number of extra pixels between columns */ |
965 |
int saveLines; /* number of lines that fit in scrollback */ |
966 |
int total_rows; /* total number of rows in this terminal */ |
967 |
int term_start; /* term lines start here */ |
968 |
int view_start; /* scrollback view starts here */ |
969 |
int top_row; /* topmost row index of scrollback */ |
970 |
Window parent; /* parent identifier */ |
971 |
Window vt; /* vt100 window */ |
972 |
GC gc; /* GC for drawing */ |
973 |
rxvt_drawable *drawable; |
974 |
rxvt_fontset *fontset[4]; |
975 |
}; |
976 |
|
977 |
/* |
978 |
* screen accounting: |
979 |
* screen_t elements |
980 |
* row: Cursor row position : 0 <= row < nrow |
981 |
* col: Cursor column position : 0 <= col < ncol |
982 |
* tscroll: Scrolling region top row inclusive : 0 <= row < nrow |
983 |
* bscroll: Scrolling region bottom row inclusive : 0 <= row < nrow |
984 |
* |
985 |
* selection_t elements |
986 |
* clicks: 1, 2 or 3 clicks - 4 indicates a special condition of 1 where |
987 |
* nothing is selected |
988 |
* beg: row/column of beginning of selection : never past mark |
989 |
* mark: row/column of initial click : never past end |
990 |
* end: row/column of one character past end of selection |
991 |
* * Note: top_row <= beg.row <= mark.row <= end.row < nrow |
992 |
* * Note: col == -1 ==> we're left of screen |
993 |
* |
994 |
*/ |
995 |
struct screen_t |
996 |
{ |
997 |
row_col_t cur; /* cursor position on the screen */ |
998 |
int tscroll; /* top of settable scroll region */ |
999 |
int bscroll; /* bottom of settable scroll region */ |
1000 |
unsigned int charset; /* character set number [0..3] */ |
1001 |
unsigned int flags; /* see below */ |
1002 |
row_col_t s_cur; /* saved cursor position */ |
1003 |
unsigned int s_charset; /* saved character set number [0..3] */ |
1004 |
char s_charset_char; |
1005 |
rend_t s_rstyle; /* saved rendition style */ |
1006 |
}; |
1007 |
|
1008 |
enum selection_op_t |
1009 |
{ |
1010 |
SELECTION_CLEAR = 0, /* nothing selected */ |
1011 |
SELECTION_INIT, /* marked a point */ |
1012 |
SELECTION_BEGIN, /* started a selection */ |
1013 |
SELECTION_CONT, /* continued selection */ |
1014 |
SELECTION_DONE /* selection put in CUT_BUFFER0 */ |
1015 |
}; |
1016 |
|
1017 |
struct selection_t |
1018 |
{ |
1019 |
wchar_t *text; /* selected text */ |
1020 |
unsigned int len; /* length of selected text */ |
1021 |
unsigned int screen; /* screen being used */ |
1022 |
unsigned int clicks; /* number of clicks */ |
1023 |
selection_op_t op; /* current operation */ |
1024 |
bool rect; /* rectangular selection? */ |
1025 |
row_col_t beg; /* beginning of selection <= mark */ |
1026 |
row_col_t mark; /* point of initial click <= end */ |
1027 |
row_col_t end; /* one character past end point */ |
1028 |
wchar_t *clip_text; /* text copied to the clipboard */ |
1029 |
unsigned int clip_len; /* length of clipboard text */ |
1030 |
}; |
1031 |
|
1032 |
/* ------------------------------------------------------------------------- */ |
1033 |
|
1034 |
/* screen_t flags */ |
1035 |
#define Screen_Relative (1<<0) /* relative origin mode flag */ |
1036 |
#define Screen_VisibleCursor (1<<1) /* cursor visible? */ |
1037 |
#define Screen_Autowrap (1<<2) /* auto-wrap flag */ |
1038 |
#define Screen_Insert (1<<3) /* insert mode (vs. overstrike) */ |
1039 |
#define Screen_WrapNext (1<<4) /* need to wrap for next char? */ |
1040 |
#define Screen_DefaultFlags (Screen_VisibleCursor | Screen_Autowrap) |
1041 |
|
1042 |
/* rxvt_vars.options */ |
1043 |
enum { |
1044 |
# define def(name) Opt_ ## name, |
1045 |
# define nodef(name) Opt_prev_ ## name, Opt_ ## name = 0, Opt_next_ ## name = Opt_prev_ ## name - 1, |
1046 |
Opt_0, |
1047 |
# include "optinc.h" |
1048 |
# undef nodef |
1049 |
# undef def |
1050 |
Opt_count |
1051 |
}; |
1052 |
|
1053 |
/* ------------------------------------------------------------------------- */ |
1054 |
|
1055 |
struct rxvt_vars : TermWin_t |
1056 |
{ |
1057 |
scrollBar_t scrollBar; |
1058 |
uint8_t options[(Opt_count + 7) >> 3]; |
1059 |
XSizeHints szHint; |
1060 |
rxvt_color *pix_colors; |
1061 |
Cursor TermWin_cursor; /* cursor for vt window */ |
1062 |
|
1063 |
line_t *row_buf; // all lines, scrollback + terminal, circular |
1064 |
line_t *drawn_buf; // text on screen |
1065 |
line_t *swap_buf; // lines for swap buffer |
1066 |
char *tabs; /* per location: 1 == tab-stop */ |
1067 |
screen_t screen; |
1068 |
screen_t swap; |
1069 |
selection_t selection; |
1070 |
rxvt_color pix_colors_focused[TOTAL_COLORS]; |
1071 |
#ifdef OFF_FOCUS_FADING |
1072 |
rxvt_color pix_colors_unfocused[TOTAL_COLORS]; |
1073 |
#endif |
1074 |
}; |
1075 |
|
1076 |
struct rxvt_term : zero_initialized, rxvt_vars, rxvt_screen |
1077 |
{ |
1078 |
|
1079 |
// special markers with magic addresses |
1080 |
static const char resval_undef []; // options specifically unset |
1081 |
static const char resval_on []; // boolean options switched on |
1082 |
static const char resval_off []; // or off |
1083 |
|
1084 |
log_callback *log_hook; // log error messages through this hook, if != 0 |
1085 |
getfd_callback *getfd_hook; // convert remote to local fd, if != 0 |
1086 |
#if ENABLE_PERL |
1087 |
rxvt_perl_term perl; |
1088 |
#endif |
1089 |
struct mbstate mbstate; // current input multibyte state |
1090 |
|
1091 |
unsigned char want_refresh:1, |
1092 |
current_screen:1, /* primary or secondary */ |
1093 |
num_scr_allow:1, |
1094 |
bypass_keystate:1, |
1095 |
#if ENABLE_FRILLS |
1096 |
urgency_hint:1, |
1097 |
#endif |
1098 |
#if CURSOR_BLINK |
1099 |
hidden_cursor:1, |
1100 |
#endif |
1101 |
#if TEXT_BLINK |
1102 |
hidden_text:1, |
1103 |
#endif |
1104 |
#if POINTER_BLANK |
1105 |
hidden_pointer:1, |
1106 |
#endif |
1107 |
enc_utf8:1, /* whether locale uses utf-8 */ |
1108 |
seen_input:1, /* whether we have seen some program output yet */ |
1109 |
seen_resize:1, /* whether we had a resize event */ |
1110 |
init_done:1, |
1111 |
parsed_geometry:1; |
1112 |
|
1113 |
unsigned char refresh_type, |
1114 |
#ifdef META8_OPTION |
1115 |
meta_char; /* Alt-key prefix */ |
1116 |
#endif |
1117 |
/* ---------- */ |
1118 |
bool rvideo_state, rvideo_mode; |
1119 |
#ifndef NO_BELL |
1120 |
bool rvideo_bell; |
1121 |
#endif |
1122 |
int num_scr; /* screen: number of lines scrolled */ |
1123 |
int prev_ncol, /* screen: previous number of columns */ |
1124 |
prev_nrow; /* screen: previous number of rows */ |
1125 |
/* ---------- */ |
1126 |
rend_t rstyle; |
1127 |
/* ---------- */ |
1128 |
#ifdef SELECTION_SCROLLING |
1129 |
int scroll_selection_lines; |
1130 |
int selection_save_x, |
1131 |
selection_save_y, |
1132 |
selection_save_state; |
1133 |
#endif |
1134 |
/* ---------- */ |
1135 |
int csrO, /* Hops - csr offset in thumb/slider to */ |
1136 |
/* give proper Scroll behaviour */ |
1137 |
#if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING) |
1138 |
mouse_slip_wheel_speed, |
1139 |
#endif |
1140 |
refresh_count, |
1141 |
window_vt_x, |
1142 |
window_vt_y, |
1143 |
mouse_row, |
1144 |
mouse_col, |
1145 |
# ifdef POINTER_BLANK |
1146 |
pointerBlankDelay, |
1147 |
# endif |
1148 |
multiClickTime, |
1149 |
cursor_type, |
1150 |
allowedxerror; |
1151 |
/* ---------- */ |
1152 |
unsigned int ModLevel3Mask, |
1153 |
ModMetaMask, |
1154 |
ModNumLockMask; |
1155 |
unsigned long priv_modes, |
1156 |
SavedModes; |
1157 |
/* ---------- */ |
1158 |
Atom *xa; |
1159 |
/* ---------- */ |
1160 |
Time selection_time, |
1161 |
clipboard_time; |
1162 |
rxvt_selection *selection_req; |
1163 |
pid_t cmd_pid; /* process id of child */ |
1164 |
/* ---------- */ |
1165 |
struct mouse_event MEvent; |
1166 |
XComposeStatus compose; |
1167 |
static struct termios def_tio; |
1168 |
row_col_t oldcursor; |
1169 |
|
1170 |
#ifdef HAVE_IMG |
1171 |
enum { |
1172 |
BG_IS_TRANSPARENT = 1 << 1, |
1173 |
BG_NEEDS_REFRESH = 1 << 2, |
1174 |
}; |
1175 |
|
1176 |
uint8_t bg_flags; |
1177 |
|
1178 |
rxvt_img *bg_img; |
1179 |
#endif |
1180 |
|
1181 |
#if ENABLE_OVERLAY |
1182 |
overlay_base ov; |
1183 |
|
1184 |
void scr_swap_overlay () noexcept; |
1185 |
void scr_overlay_new (int x, int y, int w, int h) noexcept; |
1186 |
void scr_overlay_off () noexcept; |
1187 |
void scr_overlay_set (int x, int y, |
1188 |
text_t text, |
1189 |
rend_t rend = OVERLAY_RSTYLE) noexcept; |
1190 |
void scr_overlay_set (int x, int y, const char *s) noexcept; |
1191 |
void scr_overlay_set (int x, int y, const wchar_t *s) noexcept; |
1192 |
#endif |
1193 |
|
1194 |
vector<void *> allocated; // free these memory blocks with free() |
1195 |
|
1196 |
int parent_x, parent_y; // parent window position relative to root, only updated on demand |
1197 |
|
1198 |
char *locale; |
1199 |
char charsets[4]; |
1200 |
char *v_buffer; /* pointer to physical buffer */ |
1201 |
unsigned int v_buflen; /* size of area to write */ |
1202 |
stringvec *argv, *envv; /* if != 0, will be freed at destroy time */ |
1203 |
char **env; |
1204 |
|
1205 |
#ifdef KEYSYM_RESOURCE |
1206 |
keyboard_manager *keyboard; |
1207 |
#endif |
1208 |
#ifndef NO_RESOURCES |
1209 |
XrmDatabase option_db; |
1210 |
#endif |
1211 |
|
1212 |
const char *rs[NUM_RESOURCES]; |
1213 |
/* command input buffering */ |
1214 |
char *cmdbuf_ptr, *cmdbuf_endp; |
1215 |
char cmdbuf_base[CBUFSIZ]; |
1216 |
|
1217 |
ptytty *pty; |
1218 |
|
1219 |
// chunk contains all line_t's as well as rend_t and text_t buffers |
1220 |
// for drawn_buf, swap_buf and row_buf, in this order |
1221 |
void *chunk; |
1222 |
size_t chunk_size; |
1223 |
|
1224 |
uint32_t rgb24_color[RGB24_CUBE_SIZE]; // the 24-bit color value |
1225 |
uint16_t rgb24_seqno[RGB24_CUBE_SIZE]; // which one is older? |
1226 |
uint16_t rgb24_sequence; |
1227 |
|
1228 |
static vector<rxvt_term *> termlist; // a vector of all running rxvt_term's |
1229 |
|
1230 |
#if ENABLE_FRILLS || ISO_14755 |
1231 |
// ISO 14755 entry support |
1232 |
unicode_t iso14755buf; |
1233 |
void commit_iso14755 (); |
1234 |
# if ISO_14755 |
1235 |
void iso14755_51 (unicode_t ch, rend_t r = DEFAULT_RSTYLE, int x = 0, int y = -1, int y2 = -1); |
1236 |
void iso14755_54 (int x, int y); |
1237 |
# endif |
1238 |
#endif |
1239 |
|
1240 |
long vt_emask, vt_emask_perl, vt_emask_xim, vt_emask_mouse; |
1241 |
|
1242 |
void vt_select_input () const noexcept |
1243 |
{ |
1244 |
XSelectInput (dpy, vt, vt_emask | vt_emask_perl | vt_emask_xim | vt_emask_mouse); |
1245 |
} |
1246 |
|
1247 |
#if ENABLE_PERL |
1248 |
void rootwin_cb (XEvent &xev); |
1249 |
xevent_watcher rootwin_ev; |
1250 |
#endif |
1251 |
|
1252 |
void x_cb (XEvent &xev); |
1253 |
xevent_watcher termwin_ev; |
1254 |
xevent_watcher vt_ev; |
1255 |
xevent_watcher scrollbar_ev; |
1256 |
|
1257 |
void child_cb (ev::child &w, int revents); ev::child child_ev; |
1258 |
void destroy_cb (ev::idle &w, int revents); ev::idle destroy_ev; |
1259 |
void refresh_check (); |
1260 |
void flush (); |
1261 |
void flush_cb (ev::timer &w, int revents); ev::timer flush_ev; |
1262 |
void cmdbuf_reify (); |
1263 |
void cmdbuf_append (const char *str, size_t count); |
1264 |
bool pty_fill (); |
1265 |
void pty_cb (ev::io &w, int revents); ev::io pty_ev; |
1266 |
|
1267 |
#ifdef CURSOR_BLINK |
1268 |
void cursor_blink_reset (); |
1269 |
void cursor_blink_cb (ev::timer &w, int revents); ev::timer cursor_blink_ev; |
1270 |
#endif |
1271 |
#ifdef TEXT_BLINK |
1272 |
void text_blink_cb (ev::timer &w, int revents); ev::timer text_blink_ev; |
1273 |
#endif |
1274 |
#ifndef NO_BELL |
1275 |
void bell_cb (ev::timer &w, int revents); ev::timer bell_ev; |
1276 |
#endif |
1277 |
|
1278 |
#ifndef NO_SCROLLBAR_BUTTON_CONTINUAL_SCROLLING |
1279 |
void cont_scroll_cb (ev::timer &w, int revents); ev::timer cont_scroll_ev; |
1280 |
#endif |
1281 |
#ifdef SELECTION_SCROLLING |
1282 |
void sel_scroll_cb (ev::timer &w, int revents); ev::timer sel_scroll_ev; |
1283 |
#endif |
1284 |
#if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING) |
1285 |
void slip_wheel_cb (ev::timer &w, int revents); ev::timer slip_wheel_ev; |
1286 |
#endif |
1287 |
|
1288 |
#ifdef POINTER_BLANK |
1289 |
void pointer_cb (ev::timer &w, int revents); ev::timer pointer_ev; |
1290 |
void pointer_blank (); |
1291 |
#endif |
1292 |
void pointer_unblank (); |
1293 |
|
1294 |
void tt_printf (const char *fmt,...); |
1295 |
void tt_write_ (const char *data, unsigned int len); |
1296 |
void tt_write (const char *data, unsigned int len); |
1297 |
void tt_write_user_input (const char *data, unsigned int len); |
1298 |
void pty_write (); |
1299 |
|
1300 |
void make_current () const // make this the "currently active" urxvt instance |
1301 |
{ |
1302 |
SET_R (this); |
1303 |
set_environ (env); |
1304 |
rxvt_set_locale (locale); |
1305 |
} |
1306 |
|
1307 |
#if USE_XIM |
1308 |
rxvt_xim *input_method; |
1309 |
XIC Input_Context; |
1310 |
XIMStyle input_style; |
1311 |
XPoint spot; // most recently sent spot position |
1312 |
|
1313 |
void im_destroy (); |
1314 |
void im_cb (); im_watcher im_ev; |
1315 |
void im_set_size (XRectangle &size); |
1316 |
void im_set_position (XPoint &pos) noexcept; |
1317 |
void im_set_color (unsigned long &fg, unsigned long &bg); |
1318 |
void im_set_preedit_area (XRectangle &preedit_rect, XRectangle &status_rect, const XRectangle &needed_rect); |
1319 |
|
1320 |
bool im_is_running (); |
1321 |
void im_send_spot (); |
1322 |
bool im_get_ic (const char *modifiers); |
1323 |
void im_set_position (); |
1324 |
#endif |
1325 |
|
1326 |
// command.C |
1327 |
void key_press (XKeyEvent &ev); |
1328 |
void key_release (XKeyEvent &ev); |
1329 |
|
1330 |
wchar_t next_char () noexcept; |
1331 |
wchar_t cmd_getc (); |
1332 |
uint32_t next_octet () noexcept; |
1333 |
uint32_t cmd_get8 (); |
1334 |
|
1335 |
void cmd_parse (); |
1336 |
void mouse_report (XButtonEvent &ev); |
1337 |
void button_press (XButtonEvent &ev); |
1338 |
void button_release (XButtonEvent &ev); |
1339 |
void focus_in (); |
1340 |
void focus_out (); |
1341 |
#if ENABLE_FRILLS |
1342 |
void set_urgency (bool enable); |
1343 |
#else |
1344 |
void set_urgency (bool enable) { } |
1345 |
#endif |
1346 |
void update_fade_color (unsigned int idx, bool first_time = false); |
1347 |
#ifdef PRINTPIPE |
1348 |
FILE *popen_printer (); |
1349 |
int pclose_printer (FILE *stream); |
1350 |
#endif |
1351 |
void process_print_pipe (); |
1352 |
void process_nonprinting (unicode_t ch); |
1353 |
void process_escape_vt52 (unicode_t ch); |
1354 |
void process_escape_seq (); |
1355 |
void process_csi_seq (); |
1356 |
void process_window_ops (const int *args, unsigned int nargs); |
1357 |
char *get_to_st (unicode_t &ends_how); |
1358 |
void process_dcs_seq (); |
1359 |
void process_osc_seq (); |
1360 |
void process_color_seq (int report, int color, const char *str, char resp); |
1361 |
void process_xterm_seq (int op, char *str, char resp); |
1362 |
unsigned int map_rgb24_color (unsigned int r, unsigned int g, unsigned int b, unsigned int a); |
1363 |
int privcases (int mode, unsigned long bit); |
1364 |
void process_terminal_mode (int mode, int priv, unsigned int nargs, const int *arg); |
1365 |
void process_sgr_mode (unsigned int nargs, const int *arg); |
1366 |
void set_cursor_style (int style); |
1367 |
// init.C |
1368 |
void init (stringvec *argv, stringvec *envv); |
1369 |
void init (int argc, const char *const *argv, const char *const *envv); |
1370 |
void init2 (int argc, const char *const *argv); |
1371 |
void init_vars (); |
1372 |
const char **init_resources (int argc, const char *const *argv); |
1373 |
void init_env (); |
1374 |
void set_locale (const char *locale); |
1375 |
void init_xlocale (); |
1376 |
void init_command (const char *const *argv); |
1377 |
void run_command (const char *const *argv); |
1378 |
int run_child (const char *const *argv); |
1379 |
void color_aliases (int idx); |
1380 |
void create_windows (int argc, const char *const *argv); |
1381 |
void get_colors (); |
1382 |
void get_ourmods (); |
1383 |
void set_icon (const char *file); |
1384 |
// main.C |
1385 |
void tt_winch (); |
1386 |
rxvt_term (); |
1387 |
~rxvt_term (); |
1388 |
void destroy (); |
1389 |
void emergency_cleanup (); |
1390 |
void recolor_cursor (); |
1391 |
void resize_all_windows (unsigned int newwidth, unsigned int newheight, int ignoreparent); |
1392 |
void window_calc (unsigned int newwidth, unsigned int newheight); |
1393 |
bool set_fonts (); |
1394 |
void set_string_property (Atom prop, const char *str, int len = -1); |
1395 |
void set_mbstring_property (Atom prop, const char *str, int len = -1); |
1396 |
void set_utf8_property (Atom prop, const char *str, int len = -1); |
1397 |
void set_title (const char *str); |
1398 |
void set_icon_name (const char *str); |
1399 |
void set_window_color (int idx, const char *color); |
1400 |
char *get_colorfgbg (); |
1401 |
bool set_color (rxvt_color &color, const char *name); |
1402 |
void alias_color (int dst, int src); |
1403 |
void set_widthheight (unsigned int newwidth, unsigned int newheight); |
1404 |
void get_window_origin (int &x, int &y); |
1405 |
|
1406 |
// screen.C |
1407 |
|
1408 |
bool option (uint8_t opt) const noexcept |
1409 |
{ |
1410 |
return options[opt >> 3] & (1 << (opt & 7)); |
1411 |
} |
1412 |
|
1413 |
void set_option (uint8_t opt, bool set = true) noexcept; |
1414 |
|
1415 |
int fgcolor_of (rend_t r) const noexcept |
1416 |
{ |
1417 |
int base = GET_BASEFG (r); |
1418 |
#ifndef NO_BRIGHTCOLOR |
1419 |
if (r & RS_Bold |
1420 |
# if ENABLE_STYLES |
1421 |
&& option (Opt_intensityStyles) |
1422 |
# endif |
1423 |
&& IN_RANGE_EXC (base, minCOLOR, minBrightCOLOR)) |
1424 |
base += minBrightCOLOR - minCOLOR; |
1425 |
#endif |
1426 |
return base; |
1427 |
} |
1428 |
|
1429 |
int bgcolor_of (rend_t r) const noexcept |
1430 |
{ |
1431 |
int base = GET_BASEBG (r); |
1432 |
#ifndef NO_BRIGHTCOLOR |
1433 |
if (r & RS_Blink |
1434 |
# if ENABLE_STYLES |
1435 |
&& option (Opt_intensityStyles) |
1436 |
# endif |
1437 |
&& IN_RANGE_EXC (base, minCOLOR, minBrightCOLOR)) |
1438 |
base += minBrightCOLOR - minCOLOR; |
1439 |
#endif |
1440 |
return base; |
1441 |
} |
1442 |
|
1443 |
// modifies first argument(!) |
1444 |
void tt_paste (char *data, unsigned int len) noexcept; |
1445 |
void paste (char *data, unsigned int len) noexcept; |
1446 |
void scr_alloc () noexcept; |
1447 |
void scr_blank_line (line_t &l, unsigned int col, unsigned int width, rend_t efs) const noexcept; |
1448 |
void scr_blank_screen_mem (line_t &l, rend_t efs) const noexcept; |
1449 |
void scr_kill_char (line_t &l, int col) const noexcept; |
1450 |
void scr_set_char_rend (line_t &l, int col, rend_t rend); |
1451 |
int scr_scroll_text (int row1, int row2, int count) noexcept; |
1452 |
void copy_line (line_t &dst, line_t &src); |
1453 |
void scr_reset (); |
1454 |
void scr_release () noexcept; |
1455 |
void scr_clear (bool really = false) noexcept; |
1456 |
void scr_refresh () noexcept; |
1457 |
bool scr_refresh_rend (rend_t mask, rend_t value) noexcept; |
1458 |
void scr_erase_screen (int mode) noexcept; |
1459 |
#if ENABLE_FRILLS |
1460 |
void scr_erase_savelines () noexcept; |
1461 |
void scr_backindex () noexcept; |
1462 |
void scr_forwardindex () noexcept; |
1463 |
#endif |
1464 |
void scr_touch (bool refresh) noexcept; |
1465 |
void scr_expose (int x, int y, int width, int height, bool refresh) noexcept; |
1466 |
void scr_recolor (bool refresh = true) noexcept; |
1467 |
void scr_remap_chars () noexcept; |
1468 |
void scr_remap_chars (line_t &l) noexcept; |
1469 |
|
1470 |
enum cursor_mode { SAVE, RESTORE }; |
1471 |
|
1472 |
void scr_poweron (); |
1473 |
void scr_soft_reset () noexcept; |
1474 |
void scr_cursor (cursor_mode mode) noexcept; |
1475 |
void scr_do_wrap () noexcept; |
1476 |
void scr_swap_screen () noexcept; |
1477 |
void scr_change_screen (int scrn); |
1478 |
void scr_color (unsigned int color, int fgbg) noexcept; |
1479 |
void scr_rendition (int set, int style) noexcept; |
1480 |
void scr_add_lines (const wchar_t *str, int len, int minlines = 0) noexcept; |
1481 |
void scr_backspace () noexcept; |
1482 |
void scr_tab (int count, bool ht = false) noexcept; |
1483 |
void scr_gotorc (int row, int col, int relative) noexcept; |
1484 |
void scr_index (enum page_dirn direction) noexcept; |
1485 |
void scr_erase_line (int mode) noexcept; |
1486 |
void scr_E () noexcept; |
1487 |
void scr_insdel_lines (int count, int insdel) noexcept; |
1488 |
void scr_insdel_chars (int count, int insdel) noexcept; |
1489 |
void scr_scroll_region (int top, int bot) noexcept; |
1490 |
void scr_cursor_visible (int mode) noexcept; |
1491 |
void scr_autowrap (int mode) noexcept; |
1492 |
void scr_relative_origin (int mode) noexcept; |
1493 |
void scr_insert_mode (int mode) noexcept; |
1494 |
void scr_set_tab (int mode) noexcept; |
1495 |
void scr_rvideo_mode (bool on) noexcept; |
1496 |
void scr_report_position () noexcept; |
1497 |
void set_font_style () noexcept; |
1498 |
void scr_charset_choose (int set) noexcept; |
1499 |
void scr_charset_set (int set, unsigned int ch) noexcept; |
1500 |
void scr_move_to (int y, int len) noexcept; |
1501 |
bool scr_page (int nlines) noexcept; |
1502 |
bool scr_page (enum page_dirn direction, int nlines) noexcept |
1503 |
{ |
1504 |
return scr_page (direction * nlines); |
1505 |
} |
1506 |
bool scr_changeview (int new_view_start) noexcept; |
1507 |
void scr_bell () noexcept; |
1508 |
void scr_printscreen (int fullhist) noexcept; |
1509 |
void scr_xor_rect (int beg_row, int beg_col, int end_row, int end_col, rend_t rstyle1, rend_t rstyle2) noexcept; |
1510 |
void scr_xor_span (int beg_row, int beg_col, int end_row, int end_col, rend_t rstyle) noexcept; |
1511 |
void scr_reverse_selection () noexcept; |
1512 |
void scr_dump (int fd) noexcept; |
1513 |
|
1514 |
void selection_check (int check_more) noexcept; |
1515 |
void selection_changed () noexcept; /* sets want_refresh, corrects coordinates */ |
1516 |
void selection_request (Time tm, int selnum = Sel_Primary) noexcept; |
1517 |
void selection_clear (bool clipboard = false) noexcept; |
1518 |
void selection_make (Time tm); |
1519 |
bool selection_grab (Time tm, bool clipboard = false) noexcept; |
1520 |
void selection_start_colrow (int col, int row) noexcept; |
1521 |
void selection_delimit_word (enum page_dirn dirn, const row_col_t *mark, row_col_t *ret) noexcept; |
1522 |
void selection_extend_colrow (int32_t col, int32_t row, int button3, int buttonpress, int clickchange) noexcept; |
1523 |
void selection_remove_trailing_spaces () noexcept; |
1524 |
void selection_send (const XSelectionRequestEvent &rq) noexcept; |
1525 |
void selection_click (int clicks, int x, int y) noexcept; |
1526 |
void selection_extend (int x, int y, int flag) noexcept; |
1527 |
void selection_rotate (int x, int y) noexcept; |
1528 |
|
1529 |
// xdefaults.C |
1530 |
void rxvt_usage (int type); |
1531 |
const char **get_options (int argc, const char *const *argv); |
1532 |
int parse_keysym (const char *str, unsigned int &state); |
1533 |
int bind_action (const char *str, const char *arg); |
1534 |
const char *x_resource (const char *name); |
1535 |
void extract_resources (); |
1536 |
void enumerate_resources (void (*cb)(rxvt_term *, const char *, const char *), const char *name_p = 0, const char *class_p = 0); |
1537 |
void enumerate_keysym_resources (void (*cb)(rxvt_term *, const char *, const char *)) |
1538 |
{ |
1539 |
enumerate_resources (cb, "keysym", "Keysym"); |
1540 |
} |
1541 |
void extract_keysym_resources (); |
1542 |
}; |
1543 |
|
1544 |
#endif /* _RXVT_H_ */ |
1545 |
|