First-stage support for Unicode combining characters. The `chars'
[sgt/putty] / terminal.h
1 /*
2 * Internals of the Terminal structure, for those other modules
3 * which need to look inside it. It would be nice if this could be
4 * folded back into terminal.c in future, with an abstraction layer
5 * to handle everything that other modules need to know about it;
6 * but for the moment, this will do.
7 */
8
9 #ifndef PUTTY_TERMINAL_H
10 #define PUTTY_TERMINAL_H
11
12 #include "tree234.h"
13
14 struct beeptime {
15 struct beeptime *next;
16 unsigned long ticks;
17 };
18
19 typedef struct {
20 int y, x;
21 } pos;
22
23 #ifdef OPTIMISE_SCROLL
24 struct scrollregion {
25 struct scrollregion *next;
26 int topline; /* Top line of scroll region. */
27 int botline; /* Bottom line of scroll region. */
28 int lines; /* Number of lines to scroll by - +ve is forwards. */
29 };
30 #endif /* OPTIMISE_SCROLL */
31
32 typedef struct termchar termchar;
33 typedef struct termline termline;
34
35 struct termchar {
36 /*
37 * Any code in terminal.c which definitely needs to be changed
38 * when extra fields are added here is labelled with a comment
39 * saying FULL-TERMCHAR.
40 */
41 unsigned long chr;
42 unsigned long attr;
43
44 /*
45 * The cc_next field is used to link multiple termchars
46 * together into a list, so as to fit more than one character
47 * into a character cell (Unicode combining characters).
48 *
49 * cc_next is a relative offset into the current array of
50 * termchars. I.e. to advance to the next character in a list,
51 * one does `tc += tc->next'.
52 *
53 * Zero means end of list.
54 */
55 int cc_next;
56 };
57
58 struct termline {
59 unsigned short lattr;
60 int cols; /* number of real columns on the line */
61 int size; /* number of allocated termchars
62 * (cc-lists may make this > cols) */
63 int temporary; /* TRUE if decompressed from scrollback */
64 int cc_free; /* offset to first cc in free list */
65 struct termchar *chars;
66 };
67
68 struct terminal_tag {
69
70 int compatibility_level;
71
72 tree234 *scrollback; /* lines scrolled off top of screen */
73 tree234 *screen; /* lines on primary screen */
74 tree234 *alt_screen; /* lines on alternate screen */
75 int disptop; /* distance scrolled back (0 or -ve) */
76 int tempsblines; /* number of lines in temporary
77 scrollback */
78
79 termline **disptext; /* buffer of text on real screen */
80 int dispcursx, dispcursy; /* location of cursor on real screen */
81 int curstype; /* type of cursor on real screen */
82
83 #define VBELL_TIMEOUT (TICKSPERSEC/10) /* visual bell lasts 1/10 sec */
84
85 struct beeptime *beephead, *beeptail;
86 int nbeeps;
87 int beep_overloaded;
88 long lastbeep;
89
90 #define TTYPE termchar
91 #define TSIZE (sizeof(TTYPE))
92
93 #ifdef OPTIMISE_SCROLL
94 struct scrollregion *scrollhead, *scrolltail;
95 #endif /* OPTIMISE_SCROLL */
96
97 int default_attr, curr_attr, save_attr;
98 termchar basic_erase_char, erase_char;
99
100 bufchain inbuf; /* terminal input buffer */
101 pos curs; /* cursor */
102 pos savecurs; /* saved cursor position */
103 int marg_t, marg_b; /* scroll margins */
104 int dec_om; /* DEC origin mode flag */
105 int wrap, wrapnext; /* wrap flags */
106 int insert; /* insert-mode flag */
107 int cset; /* 0 or 1: which char set */
108 int save_cset, save_csattr; /* saved with cursor position */
109 int save_utf, save_wnext; /* saved with cursor position */
110 int rvideo; /* global reverse video flag */
111 unsigned long rvbell_startpoint; /* for ESC[?5hESC[?5l vbell */
112 int cursor_on; /* cursor enabled flag */
113 int reset_132; /* Flag ESC c resets to 80 cols */
114 int use_bce; /* Use Background coloured erase */
115 int blinker; /* When blinking is the cursor on ? */
116 int tblinker; /* When the blinking text is on */
117 int blink_is_real; /* Actually blink blinking text */
118 int term_echoing; /* Does terminal want local echo? */
119 int term_editing; /* Does terminal want local edit? */
120 int sco_acs, save_sco_acs; /* CSI 10,11,12m -> OEM charset */
121 int vt52_bold; /* Force bold on non-bold colours */
122 int utf; /* Are we in toggleable UTF-8 mode? */
123 int utf_state; /* Is there a pending UTF-8 character */
124 int utf_char; /* and what is it so far. */
125 int utf_size; /* The size of the UTF character. */
126 int printing, only_printing; /* Are we doing ANSI printing? */
127 int print_state; /* state of print-end-sequence scan */
128 bufchain printer_buf; /* buffered data for printer */
129 printer_job *print_job;
130
131 int rows, cols, savelines;
132 int has_focus;
133 int in_vbell;
134 unsigned long vbell_startpoint;
135 int app_cursor_keys, app_keypad_keys, vt52_mode;
136 int repeat_off, cr_lf_return;
137 int seen_disp_event;
138 int big_cursor;
139
140 long last_blink; /* used for real blinking control */
141 long last_tblink;
142
143 int xterm_mouse; /* send mouse messages to app */
144 int mouse_is_down; /* used while tracking mouse buttons */
145
146 int cset_attr[2];
147
148 /*
149 * Saved settings on the alternate screen.
150 */
151 int alt_x, alt_y, alt_om, alt_wrap, alt_wnext, alt_ins;
152 int alt_cset, alt_sco_acs, alt_utf;
153 int alt_t, alt_b;
154 int alt_which;
155 int alt_sblines; /* # of lines on alternate screen that should be used for scrollback. */
156
157 #define ARGS_MAX 32 /* max # of esc sequence arguments */
158 #define ARG_DEFAULT 0 /* if an arg isn't specified */
159 #define def(a,d) ( (a) == ARG_DEFAULT ? (d) : (a) )
160 int esc_args[ARGS_MAX];
161 int esc_nargs;
162 int esc_query;
163 #define ANSI(x,y) ((x)+((y)<<8))
164 #define ANSI_QUE(x) ANSI(x,TRUE)
165
166 #define OSC_STR_MAX 2048
167 int osc_strlen;
168 char osc_string[OSC_STR_MAX + 1];
169 int osc_w;
170
171 char id_string[1024];
172
173 unsigned char *tabs;
174
175 enum {
176 TOPLEVEL,
177 SEEN_ESC,
178 SEEN_CSI,
179 SEEN_OSC,
180 SEEN_OSC_W,
181
182 DO_CTRLS,
183
184 SEEN_OSC_P,
185 OSC_STRING, OSC_MAYBE_ST,
186 VT52_ESC,
187 VT52_Y1,
188 VT52_Y2,
189 VT52_FG,
190 VT52_BG
191 } termstate;
192
193 enum {
194 NO_SELECTION, ABOUT_TO, DRAGGING, SELECTED
195 } selstate;
196 enum {
197 LEXICOGRAPHIC, RECTANGULAR
198 } seltype;
199 enum {
200 SM_CHAR, SM_WORD, SM_LINE
201 } selmode;
202 pos selstart, selend, selanchor;
203
204 short wordness[256];
205
206 /* Mask of attributes to pay attention to when painting. */
207 int attr_mask;
208
209 wchar_t *paste_buffer;
210 int paste_len, paste_pos, paste_hold;
211 long last_paste;
212
213 void (*resize_fn)(void *, int, int);
214 void *resize_ctx;
215
216 void *ldisc;
217
218 void *frontend;
219
220 void *logctx;
221
222 struct unicode_data *ucsdata;
223
224 /*
225 * We maintain a full _copy_ of a Config structure here, not
226 * merely a pointer to it. That way, when we're passed a new
227 * one for reconfiguration, we can check the differences and
228 * adjust the _current_ setting of (e.g.) auto wrap mode rather
229 * than only the default.
230 */
231 Config cfg;
232
233 /*
234 * from_backend calls term_out, but it can also be called from
235 * the ldisc if the ldisc is called _within_ term_out. So we
236 * have to guard against re-entrancy - if from_backend is
237 * called recursively like this, it will simply add data to the
238 * end of the buffer term_out is in the process of working
239 * through.
240 */
241 int in_term_out;
242
243 /*
244 * These are buffers used by the bidi and Arabic shaping code.
245 */
246 termchar *ltemp;
247 int ltemp_size;
248 bidi_char *wcFrom, *wcTo;
249 int wcFromTo_size;
250 termchar **pre_bidi_cache, **post_bidi_cache;
251 int bidi_cache_size;
252 };
253
254 #define in_utf(term) ((term)->utf || (term)->ucsdata->line_codepage==CP_UTF8)
255
256 #endif