… | |
… | |
20 | @include_sys_strredir_h@ |
20 | @include_sys_strredir_h@ |
21 | |
21 | |
22 | #include <sys/wait.h> |
22 | #include <sys/wait.h> |
23 | #include <sys/stat.h> |
23 | #include <sys/stat.h> |
24 | |
24 | |
|
|
25 | #if HAVE_CWCHAR |
25 | #include <cwchar> |
26 | # include <cwchar> |
|
|
27 | #elif HAVE_WCHAR_H |
|
|
28 | # include <wchar.h> |
|
|
29 | #else |
|
|
30 | // stdlib.h might provide it |
|
|
31 | #endif |
26 | |
32 | |
27 | #include "ptytty.h" |
33 | #include "ptytty.h" |
28 | |
34 | |
29 | extern "C" { |
35 | extern "C" { |
30 | #include <X11/Intrinsic.h> /* Xlib, Xutil, Xresource, Xfuncproto */ |
36 | #include <X11/Intrinsic.h> /* Xlib, Xutil, Xresource, Xfuncproto */ |
… | |
… | |
54 | |
60 | |
55 | typedef struct rxvt_term *rxvt_t; |
61 | typedef struct rxvt_term *rxvt_t; |
56 | |
62 | |
57 | extern rxvt_t rxvt_current_term; |
63 | extern rxvt_t rxvt_current_term; |
58 | |
64 | |
59 | # define SET_R(r) rxvt_current_term = (r) |
65 | #define SET_R(r) rxvt_current_term = (r) |
60 | # define GET_R rxvt_current_term |
66 | #define GET_R rxvt_current_term |
61 | |
67 | |
62 | #define scrollbar_visible() scrollBar.state |
68 | #define scrollbar_visible() scrollBar.state |
63 | #define menubar_visible() menuBar.state |
69 | #define menubar_visible() menuBar.state |
64 | |
70 | |
65 | typedef struct { |
71 | typedef struct { |
66 | int32_t row; |
72 | int row; |
67 | int32_t col; |
73 | int col; |
68 | } row_col_t; |
74 | } row_col_t; |
69 | |
75 | |
70 | #if UNICODE_3 |
76 | #if UNICODE_3 |
71 | typedef uint32_t text_t; |
77 | typedef uint32_t text_t; |
72 | #else |
78 | #else |
73 | typedef uint16_t text_t; // saves lots of memory |
79 | typedef uint16_t text_t; // saves lots of memory |
74 | #endif |
80 | #endif |
75 | typedef uint32_t rend_t; |
81 | typedef uint32_t rend_t; |
|
|
82 | typedef int16_t tlen_t; |
|
|
83 | |
|
|
84 | #define LINE_CONT -1 |
|
|
85 | |
|
|
86 | struct line_t { |
|
|
87 | text_t *t; // terminal the text |
|
|
88 | rend_t *r; // rendition, uses RS_ flags |
|
|
89 | tlen_t l; // length of each text line, LINE_CONT == continued on next line |
|
|
90 | |
|
|
91 | bool is_longer () |
|
|
92 | { |
|
|
93 | return l < 0; |
|
|
94 | } |
|
|
95 | |
|
|
96 | void set_is_longer () |
|
|
97 | { |
|
|
98 | l = LINE_CONT; |
|
|
99 | } |
|
|
100 | |
|
|
101 | void clear () |
|
|
102 | { |
|
|
103 | t = 0; |
|
|
104 | r = 0; |
|
|
105 | l = 0; |
|
|
106 | } |
|
|
107 | }; |
76 | |
108 | |
77 | /* |
109 | /* |
78 | * TermWin elements limits |
110 | * TermWin elements limits |
79 | * width : 1 <= width |
111 | * width : 1 <= width |
80 | * height : 1 <= height |
112 | * height : 1 <= height |
81 | * ncol : 1 <= ncol <= MAX(int16_t) |
113 | * ncol : 1 <= ncol <= MAX(int16_t) |
82 | * nrow : 1 <= nrow <= MAX(int16_t) |
114 | * nrow : 1 <= nrow <= MAX(int16_t) |
83 | * saveLines : 0 <= saveLines <= MAX(int16_t) |
115 | * saveLines : 0 <= saveLines <= MAX(int16_t) |
|
|
116 | * nlines : nrow + saveLines |
84 | * nscrolled : 0 <= nscrolled <= saveLines |
117 | * nsaved : 0 <= nsaved <= saveLines |
|
|
118 | * term_start: 0 <= term_start < saveLines |
85 | * view_start: 0 <= view_start <= nscrolled |
119 | * view_start: 0 <= view_start < saveLines |
86 | */ |
120 | */ |
87 | |
121 | |
88 | typedef struct { |
122 | struct TermWin_t { |
89 | uint16_t width; /* window width [pixels] */ |
123 | int width; /* window width [pixels] */ |
90 | uint16_t height; /* window height [pixels] */ |
124 | int height; /* window height [pixels] */ |
91 | uint16_t fwidth; /* font width [pixels] */ |
125 | int fwidth; /* font width [pixels] */ |
92 | uint16_t fheight; /* font height [pixels] */ |
126 | int fheight; /* font height [pixels] */ |
|
|
127 | int fweight, fslant; |
93 | uint16_t fbase; /* font ascent (baseline) [pixels] */ |
128 | int fbase; /* font ascent (baseline) [pixels] */ |
94 | uint16_t propfont; /* font proportional flags */ |
|
|
95 | uint16_t ncol; /* window columns [characters] */ |
129 | int ncol; /* window columns [characters] */ |
96 | uint16_t nrow; /* window rows [characters] */ |
130 | int nrow; /* window rows [characters] */ |
97 | uint16_t focus; /* window has focus */ |
131 | int focus; /* window has focus */ |
98 | uint16_t mapped; /* window state mapped? */ |
132 | int mapped; /* window state mapped? */ |
99 | uint16_t int_bwidth; /* internal border width */ |
133 | int int_bwidth; /* internal border width */ |
100 | uint16_t ext_bwidth; /* external border width */ |
134 | int ext_bwidth; /* external border width */ |
101 | uint16_t lineSpace; /* number of extra pixels between rows */ |
135 | int lineSpace; /* number of extra pixels between rows */ |
102 | uint16_t saveLines; /* number of lines that fit in scrollback */ |
136 | int saveLines; /* number of lines that fit in scrollback */ |
103 | uint16_t nscrolled; /* number of line actually scrolled */ |
137 | int total_rows; /* total number of rows in this terminal */ |
|
|
138 | int nsaved; /* number of rows saved to scrollback */ |
|
|
139 | int term_start; /* term lines start here */ |
104 | uint16_t view_start; /* scrollback view starts here */ |
140 | int view_start; /* scrollback view starts here */ |
105 | Window parent[6]; /* parent identifiers - we're parent[0] */ |
141 | Window parent[6]; /* parent identifiers - we're parent[0] */ |
106 | Window vt; /* vt100 window */ |
142 | Window vt; /* vt100 window */ |
107 | GC gc; /* GC for drawing */ |
143 | GC gc; /* GC for drawing */ |
108 | Pixmap pixmap; |
144 | Pixmap pixmap; |
109 | rxvt_fontset *fontset; |
|
|
110 | rxvt_drawable *drawable; |
145 | rxvt_drawable *drawable; |
111 | uint16_t ascii_map[0x7f - 0x20]; // map ascii chars to fonts for speed |
146 | rxvt_fontset *fontset[4]; |
112 | } TermWin_t; |
147 | }; |
113 | |
148 | |
114 | /* |
149 | /* |
115 | * screen accounting: |
150 | * screen accounting: |
116 | * screen_t elements |
151 | * screen_t elements |
117 | * text: Contains all text information including the scrollback buffer. |
152 | * text: Contains all text information including the scrollback buffer. |
118 | * Each line is length TermWin.ncol |
153 | * Each line is length ncol |
119 | * tlen: The length of the line or -1 for wrapped lines. |
154 | * tlen: The length of the line or -1 for wrapped lines. |
120 | * rend: Contains rendition information: font, bold, colour, etc. |
155 | * rend: Contains rendition information: font, bold, colour, etc. |
121 | * * Note: Each line for both text and rend are only allocated on demand, and |
156 | * * Note: Each line for both text and rend are only allocated on demand, and |
122 | * text[x] is allocated <=> rend[x] is allocated for all x. |
157 | * text[x] is allocated <=> rend[x] is allocated for all x. |
123 | * row: Cursor row position : 0 <= row < TermWin.nrow |
158 | * row: Cursor row position : 0 <= row < nrow |
124 | * col: Cursor column position : 0 <= col < TermWin.ncol |
159 | * col: Cursor column position : 0 <= col < ncol |
125 | * tscroll: Scrolling region top row inclusive : 0 <= row < TermWin.nrow |
160 | * tscroll: Scrolling region top row inclusive : 0 <= row < nrow |
126 | * bscroll: Scrolling region bottom row inclusive : 0 <= row < TermWin.nrow |
161 | * bscroll: Scrolling region bottom row inclusive : 0 <= row < nrow |
127 | * |
162 | * |
128 | * selection_t elements |
163 | * selection_t elements |
129 | * clicks: 1, 2 or 3 clicks - 4 indicates a special condition of 1 where |
164 | * clicks: 1, 2 or 3 clicks - 4 indicates a special condition of 1 where |
130 | * nothing is selected |
165 | * nothing is selected |
131 | * beg: row/column of beginning of selection : never past mark |
166 | * beg: row/column of beginning of selection : never past mark |
132 | * mark: row/column of initial click : never past end |
167 | * mark: row/column of initial click : never past end |
133 | * end: row/column of one character past end of selection |
168 | * end: row/column of one character past end of selection |
134 | * * Note: -TermWin.nscrolled <= beg.row <= mark.row <= end.row < TermWin.nrow |
169 | * * Note: -nsaved <= beg.row <= mark.row <= end.row < nrow |
135 | * * Note: col == -1 ==> we're left of screen |
170 | * * Note: col == -1 ==> we're left of screen |
136 | * |
171 | * |
137 | * Layout of text/rend information in the screen_t text/rend structures: |
172 | * Layout of text/rend information in the screen_t text/rend structures: |
138 | * Rows [0] ... [TermWin.saveLines - 1] |
173 | * Rows [0] ... [saveLines - 1] |
139 | * scrollback region : we're only here if TermWin.view_start != 0 |
174 | * scrollback region : we're only here if view_start != 0 |
140 | * Rows [TermWin.saveLines] ... [TermWin.saveLines + TermWin.nrow - 1] |
175 | * Rows [saveLines] ... [saveLines + nrow - 1] |
141 | * normal `unscrolled' screen region |
176 | * normal `unsaved' screen region |
142 | */ |
177 | */ |
143 | typedef struct { |
178 | typedef struct { |
144 | int16_t *tlen; /* length of each text line */ |
179 | line_t **line; |
145 | text_t **text; /* _all_ the text */ |
180 | |
146 | rend_t **rend; /* rendition, uses RS_ flags */ |
|
|
147 | row_col_t cur; /* cursor position on the screen */ |
181 | row_col_t cur; /* cursor position on the screen */ |
148 | uint16_t tscroll; /* top of settable scroll region */ |
182 | unsigned int tscroll; /* top of settable scroll region */ |
149 | uint16_t bscroll; /* bottom of settable scroll region */ |
183 | unsigned int bscroll; /* bottom of settable scroll region */ |
150 | uint16_t charset; /* character set number [0..3] */ |
184 | unsigned int charset; /* character set number [0..3] */ |
151 | unsigned int flags; /* see below */ |
185 | unsigned int flags; /* see below */ |
152 | row_col_t s_cur; /* saved cursor position */ |
186 | row_col_t s_cur; /* saved cursor position */ |
153 | uint16_t s_charset; /* saved character set number [0..3] */ |
187 | unsigned int s_charset; /* saved character set number [0..3] */ |
154 | char s_charset_char; |
188 | char s_charset_char; |
155 | rend_t s_rstyle; /* saved rendition style */ |
189 | rend_t s_rstyle; /* saved rendition style */ |
156 | } screen_t; |
190 | } screen_t; |
157 | |
191 | |
158 | enum selection_op_t { |
192 | enum selection_op_t { |
… | |
… | |
162 | SELECTION_CONT, /* continued selection */ |
196 | SELECTION_CONT, /* continued selection */ |
163 | SELECTION_DONE /* selection put in CUT_BUFFER0 */ |
197 | SELECTION_DONE /* selection put in CUT_BUFFER0 */ |
164 | }; |
198 | }; |
165 | |
199 | |
166 | typedef struct { |
200 | typedef struct { |
167 | wchar_t *text; /* selected text */ |
201 | wchar_t *text; /* selected text */ |
168 | uint32_t len; /* length of selected text */ |
202 | unsigned int len; /* length of selected text */ |
169 | short screen; /* screen being used */ |
203 | unsigned int screen; /* screen being used */ |
170 | short clicks; /* number of clicks */ |
204 | unsigned int clicks; /* number of clicks */ |
171 | selection_op_t op; /* current operation */ |
205 | selection_op_t op; /* current operation */ |
|
|
206 | bool rect; /* rectangluar selection? */ |
172 | row_col_t beg; /* beginning of selection <= mark */ |
207 | row_col_t beg; /* beginning of selection <= mark */ |
173 | row_col_t mark; /* point of initial click <= end */ |
208 | row_col_t mark; /* point of initial click <= end */ |
174 | row_col_t end; /* one character past end point */ |
209 | row_col_t end; /* one character past end point */ |
175 | } selection_t; |
210 | } selection_t; |
176 | |
211 | |
177 | /* ------------------------------------------------------------------------- */ |
212 | /* ------------------------------------------------------------------------- */ |
178 | |
213 | |
179 | /* screen_t flags */ |
214 | /* screen_t flags */ |
180 | #define Screen_Relative (1<<0) /* relative origin mode flag */ |
215 | #define Screen_Relative (1<<0) /* relative origin mode flag */ |
181 | #define Screen_VisibleCursor (1<<1) /* cursor visible? */ |
216 | #define Screen_VisibleCursor (1<<1) /* cursor visible? */ |
182 | #define Screen_Autowrap (1<<2) /* auto-wrap flag */ |
217 | #define Screen_Autowrap (1<<2) /* auto-wrap flag */ |
183 | #define Screen_Insert (1<<3) /* insert mode (vs. overstrike) */ |
218 | #define Screen_Insert (1<<3) /* insert mode (vs. overstrike) */ |
184 | #define Screen_WrapNext (1<<4) /* need to wrap for next char? */ |
219 | #define Screen_WrapNext (1<<4) /* need to wrap for next char? */ |
185 | #define Screen_DefaultFlags (Screen_VisibleCursor|Screen_Autowrap) |
220 | #define Screen_DefaultFlags (Screen_VisibleCursor | Screen_Autowrap) |
186 | |
221 | |
187 | /* rxvt_vars.options */ |
222 | /* rxvt_vars.options */ |
188 | #define Opt_console (1UL<<0) |
223 | #define Opt_console (1UL<<0) |
189 | #define Opt_loginShell (1UL<<1) |
224 | #define Opt_loginShell (1UL<<1) |
190 | #define Opt_iconic (1UL<<2) |
225 | #define Opt_iconic (1UL<<2) |
191 | #define Opt_visualBell (1UL<<3) |
226 | #define Opt_visualBell (1UL<<3) |
192 | #define Opt_mapAlert (1UL<<4) |
227 | #define Opt_mapAlert (1UL<<4) |
193 | #define Opt_reverseVideo (1UL<<5) |
228 | #define Opt_reverseVideo (1UL<<5) |
194 | #define Opt_utmpInhibit (1UL<<6) |
229 | #define Opt_utmpInhibit (1UL<<6) |
195 | #define Opt_scrollBar (1UL<<7) |
230 | #define Opt_scrollBar (1UL<<7) |
196 | #define Opt_scrollBar_right (1UL<<8) |
231 | #define Opt_scrollBar_right (1UL<<8) |
197 | #define Opt_scrollBar_floating (1UL<<9) |
232 | #define Opt_scrollBar_floating (1UL<<9) |
198 | #define Opt_meta8 (1UL<<10) |
233 | #define Opt_meta8 (1UL<<10) |
199 | #define Opt_scrollTtyOutput (1UL<<11) |
234 | #define Opt_scrollTtyOutput (1UL<<11) |
200 | #define Opt_scrollTtyKeypress (1UL<<12) |
235 | #define Opt_scrollTtyKeypress (1UL<<12) |
201 | #define Opt_transparent (1UL<<13) |
236 | #define Opt_transparent (1UL<<13) |
202 | #define Opt_transparent_all (1UL<<14) |
|
|
203 | #define Opt_realBold (1UL<<15) |
|
|
204 | #define Opt_tripleclickwords (1UL<<16) |
237 | #define Opt_tripleclickwords (1UL<<14) |
205 | #define Opt_scrollWithBuffer (1UL<<17) |
238 | #define Opt_scrollWithBuffer (1UL<<15) |
206 | #define Opt_jumpScroll (1UL<<18) |
239 | #define Opt_jumpScroll (1UL<<16) |
207 | #define Opt_mouseWheelScrollPage (1UL<<19) |
240 | #define Opt_mouseWheelScrollPage (1UL<<17) |
208 | #define Opt_pointerBlank (1UL<<20) |
241 | #define Opt_pointerBlank (1UL<<18) |
209 | #define Opt_cursorBlink (1UL<<21) |
242 | #define Opt_cursorBlink (1UL<<19) |
210 | #define Opt_secondaryScreen (1UL<<22) |
243 | #define Opt_secondaryScreen (1UL<<20) |
211 | #define Opt_secondaryScroll (1UL<<23) |
244 | #define Opt_secondaryScroll (1UL<<21) |
|
|
245 | #define Opt_pastableTabs (1UL<<22) |
|
|
246 | #define Opt_cursorUnderline (1UL<<23) |
212 | #if ENABLE_FRILLS |
247 | #if ENABLE_FRILLS |
213 | # define Opt_insecure (1UL<<24) // insecure esc sequences |
248 | # define Opt_insecure (1UL<<24) // insecure esc sequences |
214 | # define Opt_borderLess (1UL<<25) // mem borderless hints |
249 | # define Opt_borderLess (1UL<<25) // mem borderless hints |
215 | #else |
250 | #else |
216 | # define Opt_insecure 0 |
251 | # define Opt_insecure 0 |
217 | # define Opt_borderLess 0 |
252 | # define Opt_borderLess 0 |
218 | #endif |
253 | #endif |
219 | /* place holder used for parsing command-line options */ |
254 | /* place holder used for parsing command-line options */ |
220 | #define Opt_Reverse (1UL<<30) |
255 | #define Opt_Reverse (1UL<<30) |
221 | #define Opt_Boolean (1UL<<31) |
256 | #define Opt_Boolean (1UL<<31) |
222 | |
257 | |
223 | #define DEFAULT_OPTIONS (Opt_scrollBar | Opt_scrollTtyOutput | \ |
258 | #define DEFAULT_OPTIONS (Opt_scrollBar | Opt_scrollTtyOutput \ |
224 | Opt_jumpScroll | Opt_secondaryScreen) |
259 | | Opt_jumpScroll | Opt_secondaryScreen \ |
|
|
260 | | Opt_pastableTabs) |
225 | |
261 | |
226 | /* ------------------------------------------------------------------------- */ |
262 | /* ------------------------------------------------------------------------- */ |
227 | |
263 | |
228 | typedef struct { |
264 | typedef struct { |
229 | short state; |
265 | short state; |
… | |
… | |
232 | } menuBar_t; |
268 | } menuBar_t; |
233 | |
269 | |
234 | typedef struct { |
270 | typedef struct { |
235 | char state; /* scrollbar state */ |
271 | char state; /* scrollbar state */ |
236 | char init; /* scrollbar has been initialised */ |
272 | char init; /* scrollbar has been initialised */ |
237 | short beg; /* slider sub-window begin height */ |
273 | unsigned int beg; /* slider sub-window begin height */ |
238 | short end; /* slider sub-window end height */ |
274 | unsigned int end; /* slider sub-window end height */ |
239 | short top; /* slider top position */ |
275 | unsigned int top; /* slider top position */ |
240 | short bot; /* slider bottom position */ |
276 | unsigned int bot; /* slider bottom position */ |
241 | short style; /* style: rxvt, xterm, next */ |
277 | unsigned int style; /* style: rxvt, xterm, next */ |
242 | short width; /* scrollbar width */ |
278 | unsigned int width; /* scrollbar width */ |
243 | Window win; |
279 | Window win; |
244 | int (rxvt_term::*update)(int, int, int, int); |
280 | int (rxvt_term::*update)(int, int, int, int); |
245 | |
281 | |
246 | void setIdle() { state = 1 ; } |
282 | void setIdle() { state = 1 ; } |
247 | void setMotion() { state = 'm'; } |
283 | void setMotion() { state = 'm'; } |
248 | void setUp() { state = 'U'; } |
284 | void setUp() { state = 'U'; } |
249 | void setDn() { state = 'D'; } |
285 | void setDn() { state = 'D'; } |
250 | } scrollBar_t; |
286 | } scrollBar_t; |
251 | |
287 | |
252 | struct rxvt_vars { |
288 | struct rxvt_vars : TermWin_t { |
253 | TermWin_t TermWin; |
|
|
254 | scrollBar_t scrollBar; |
289 | scrollBar_t scrollBar; |
255 | menuBar_t menuBar; |
290 | menuBar_t menuBar; |
256 | unsigned long options; |
291 | unsigned long options; |
257 | XSizeHints szHint; |
292 | XSizeHints szHint; |
258 | rxvt_display *display; |
293 | rxvt_display *display; |
… | |
… | |
264 | short numpix_colors; |
299 | short numpix_colors; |
265 | Cursor TermWin_cursor; /* cursor for vt window */ |
300 | Cursor TermWin_cursor; /* cursor for vt window */ |
266 | int sb_shadow; /* scrollbar shadow width */ |
301 | int sb_shadow; /* scrollbar shadow width */ |
267 | rxvt_ptytty pty; |
302 | rxvt_ptytty pty; |
268 | int numlock_state; |
303 | int numlock_state; |
269 | text_t **drawn_text; /* text drawn on screen (characters) */ |
304 | line_t *save; // all lines, scorllback + terminal, circular |
270 | rend_t **drawn_rend; /* text drawn on screen (rendition) */ |
305 | line_t *drawn; // text on screen |
271 | text_t **buf_text; |
306 | line_t *buf; // temporary buffer |
272 | rend_t **buf_rend; |
307 | line_t *swap_save; // lines for swap buffer |
273 | char *tabs; /* per location: 1 == tab-stop */ |
308 | char *tabs; /* per location: 1 == tab-stop */ |
274 | screen_t screen; |
309 | screen_t screen; |
275 | screen_t swap; |
310 | screen_t swap; |
276 | selection_t selection; |
311 | selection_t selection; |
277 | }; |
312 | }; |