Mercurial > emacs
annotate src/msdos.c @ 13033:216edf9576ea
(dired-up-directory): Add optional argument `other-window' to obviate
the need to redefine it in dired-x.el.
author | Erik Naggum <erik@naggum.no> |
---|---|
date | Tue, 12 Sep 1995 23:20:42 +0000 |
parents | a656ccd43989 |
children | 169d50e2ee4c |
rev | line source |
---|---|
7666
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
1 /* MS-DOS specific C utilities. |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
2 Copyright (C) 1993, 1994 Free Software Foundation, Inc. |
5503 | 3 |
4 This file is part of GNU Emacs. | |
5 | |
6 GNU Emacs is free software; you can redistribute it and/or modify | |
7 it under the terms of the GNU General Public License as published by | |
10504 | 8 the Free Software Foundation; either version 2, or (at your option) |
5503 | 9 any later version. |
10 | |
11 GNU Emacs is distributed in the hope that it will be useful, | |
12 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 GNU General Public License for more details. | |
15 | |
16 You should have received a copy of the GNU General Public License | |
17 along with GNU Emacs; see the file COPYING. If not, write to | |
18 the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ | |
19 | |
7666
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
20 /* Contributed by Morten Welinder */ |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
21 |
5503 | 22 /* Note: some of the stuff here was taken from end of sysdep.c in demacs. */ |
23 | |
5980 | 24 #include <config.h> |
5503 | 25 |
26 #ifdef MSDOS | |
27 #include "lisp.h" | |
28 #include <stdio.h> | |
29 #include <stdlib.h> | |
30 #include <sys/param.h> | |
31 #include <sys/time.h> | |
32 #include <dos.h> | |
33 #include "dosfns.h" | |
34 #include "msdos.h" | |
35 #include "systime.h" | |
36 #include "termhooks.h" | |
9572 | 37 #include "dispextern.h" |
38 #include "termopts.h" | |
5503 | 39 #include "frame.h" |
9572 | 40 #include "window.h" |
5503 | 41 #include <go32.h> |
42 #include <pc.h> | |
43 #include <ctype.h> | |
44 /* #include <process.h> */ | |
45 /* Damn that local process.h! Instead we can define P_WAIT ourselves. */ | |
46 #define P_WAIT 1 | |
47 | |
48 static int break_stat; /* BREAK check mode status. */ | |
49 static int stdin_stat; /* stdin IOCTL status. */ | |
50 static int extended_kbd; /* 101 (102) keyboard present. */ | |
51 | |
52 int have_mouse; /* Mouse present? */ | |
53 static int mouse_last_x; | |
54 static int mouse_last_y; | |
55 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
56 #define DO_TERMSCRIPT /* define if you want open-termscript to work on msdos */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
57 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
58 /* Standard putchar may call _flsbuf which doesn't go through |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
59 fflush's overlayed internal_flush routine. */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
60 #undef putchar |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
61 #define putchar(x) \ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
62 (--(stdout)->_cnt>=0? \ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
63 ((int)((unsigned char)((*(stdout)->_ptr++=(unsigned)(x))))): \ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
64 (internal_flush (stdout), --(stdout)->_cnt, *(stdout)->_ptr++=(unsigned)(x))) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
65 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
66 static void |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
67 mouse_get_xy (int *x, int *y); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
68 |
5503 | 69 /* Turn off Dos' Ctrl-C checking and inhibit interpretation of control chars |
70 by Dos. Determine the keyboard type. */ | |
71 int | |
72 dos_ttraw () | |
73 { | |
74 union REGS inregs, outregs; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
75 static int only_once = 1; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
76 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
77 if (only_once) { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
78 inregs.h.ah = 0xc0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
79 int86 (0x15, &inregs, &outregs); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
80 extended_kbd = (!outregs.x.cflag) && (outregs.h.ah == 0); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
81 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
82 |
5503 | 83 break_stat = getcbrk (); |
84 setcbrk (0); | |
85 install_ctrl_break_check (); | |
86 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
87 if (only_once) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
88 have_mouse = mouse_init1 (); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
89 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
90 inregs.x.ax = 0x4400; /* Get IOCTL status. */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
91 inregs.x.bx = 0x00; /* 0 = stdin. */ |
5503 | 92 intdos (&inregs, &outregs); |
93 stdin_stat = outregs.h.dl; | |
94 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
95 only_once = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
96 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
97 inregs.x.dx = stdin_stat | 0x0020; /* raw mode */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
98 inregs.x.ax = 0x4401; /* Set IOCTL status */ |
5503 | 99 intdos (&inregs, &outregs); |
100 return !outregs.x.cflag; | |
101 } | |
102 | |
103 /* Restore status of standard input and Ctrl-C checking. */ | |
104 int | |
105 dos_ttcooked () | |
106 { | |
107 union REGS inregs, outregs; | |
108 | |
109 setcbrk (break_stat); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
110 mouse_off (); |
5503 | 111 |
112 inregs.x.ax = 0x4401; /* Set IOCTL status. */ | |
113 inregs.x.bx = 0x00; /* 0 = stdin. */ | |
114 inregs.x.dx = stdin_stat; | |
115 intdos (&inregs, &outregs); | |
116 return !outregs.x.cflag; | |
117 } | |
118 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
119 /* generate a reliable event timestamp, KFS 1995-07-06 */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
120 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
121 static unsigned long |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
122 event_timestamp () |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
123 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
124 struct time t; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
125 unsigned long s; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
126 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
127 gettime (&t); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
128 s = t.ti_min; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
129 s *= 60; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
130 s += t.ti_sec; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
131 s *= 1000; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
132 s += t.ti_hund * 10; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
133 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
134 return s; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
135 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
136 |
5503 | 137 static unsigned short |
138 ibmpc_translate_map[] = | |
139 { | |
140 /* --------------- 00 to 0f --------------- */ | |
141 0, /* Ctrl Break */ | |
142 0xff1b, /* Escape */ | |
143 0xffb1, /* Keypad 1 */ | |
144 0xffb2, /* Keypad 2 */ | |
145 0xffb3, /* Keypad 3 */ | |
146 0xffb4, /* Keypad 4 */ | |
147 0xffb5, /* Keypad 5 */ | |
148 0xffb6, /* Keypad 6 */ | |
149 0xffb7, /* Keypad 7 */ | |
150 0xffb8, /* Keypad 8 */ | |
151 0xffb9, /* Keypad 9 */ | |
152 0xffb0, /* Keypad 0 */ | |
153 '-', '=', | |
154 0xff08, /* Backspace */ | |
155 0xff74, /* (Shift) Tab [Tab doesn't use this table] */ | |
156 | |
157 /* --------------- 10 to 1f --------------- */ | |
158 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']', | |
159 0xff8d, /* Keypad Enter */ | |
160 0, /* Ctrl */ | |
161 'a', 's', | |
162 | |
163 /* --------------- 20 to 2f --------------- */ | |
164 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', '\'', '`', | |
165 0, /* Left shift */ | |
166 '\\', 'z', 'x', 'c', 'v', | |
167 | |
168 /* --------------- 30 to 3f --------------- */ | |
169 'b', 'n', 'm', ',', '.', | |
170 0xffaf, /* Grey / */ | |
171 0, /* Right shift */ | |
172 0xffaa, /* Grey * */ | |
173 0, /* Alt */ | |
174 ' ', | |
175 0, /* Caps Lock */ | |
176 0xffbe, /* F1 */ | |
177 0xffbf, /* F2 */ | |
178 0xffc0, /* F3 */ | |
179 0xffc1, /* F4 */ | |
180 0xffc2, /* F5 */ | |
181 | |
182 /* --------------- 40 to 4f --------------- */ | |
183 0xffc3, /* F6 */ | |
184 0xffc4, /* F7 */ | |
185 0xffc5, /* F8 */ | |
186 0xffc6, /* F9 */ | |
187 0xffc7, /* F10 */ | |
188 0, /* Num Lock */ | |
189 0, /* Scroll Lock */ | |
190 0xff50, /* Home */ | |
191 0xff52, /* Up */ | |
192 0xff55, /* Page Up */ | |
193 0xffad, /* Grey - */ | |
194 0xff51, /* Left */ | |
195 0xffb5, /* Keypad 5 */ | |
196 0xff53, /* Right */ | |
197 0xffab, /* Grey + */ | |
198 0xff57, /* End */ | |
199 | |
200 /* --------------- 50 to 5f --------------- */ | |
201 0xff54, /* Down */ | |
202 0xff56, /* Page Down */ | |
203 0xff63, /* Insert */ | |
204 0xffff, /* Delete */ | |
205 0xffbe, /* (Shift) F1 */ | |
206 0xffbf, /* (Shift) F2 */ | |
207 0xffc0, /* (Shift) F3 */ | |
208 0xffc1, /* (Shift) F4 */ | |
209 0xffc2, /* (Shift) F5 */ | |
210 0xffc3, /* (Shift) F6 */ | |
211 0xffc4, /* (Shift) F7 */ | |
212 0xffc5, /* (Shift) F8 */ | |
213 0xffc6, /* (Shift) F9 */ | |
214 0xffc7, /* (Shift) F10 */ | |
215 0xffbe, /* (Ctrl) F1 */ | |
216 0xffbf, /* (Ctrl) F2 */ | |
217 | |
218 /* --------------- 60 to 6f --------------- */ | |
219 0xffc0, /* (Ctrl) F3 */ | |
220 0xffc1, /* (Ctrl) F4 */ | |
221 0xffc2, /* (Ctrl) F5 */ | |
222 0xffc3, /* (Ctrl) F6 */ | |
223 0xffc4, /* (Ctrl) F7 */ | |
224 0xffc5, /* (Ctrl) F8 */ | |
225 0xffc6, /* (Ctrl) F9 */ | |
226 0xffc7, /* (Ctrl) F10 */ | |
227 0xffbe, /* (Alt) F1 */ | |
228 0xffbf, /* (Alt) F2 */ | |
229 0xffc0, /* (Alt) F3 */ | |
230 0xffc1, /* (Alt) F4 */ | |
231 0xffc2, /* (Alt) F5 */ | |
232 0xffc3, /* (Alt) F6 */ | |
233 0xffc4, /* (Alt) F7 */ | |
234 0xffc5, /* (Alt) F8 */ | |
235 | |
236 /* --------------- 70 to 7f --------------- */ | |
237 0xffc6, /* (Alt) F9 */ | |
238 0xffc7, /* (Alt) F10 */ | |
239 0xff6d, /* (Ctrl) Sys Rq */ | |
240 0xff51, /* (Ctrl) Left */ | |
241 0xff53, /* (Ctrl) Right */ | |
242 0xff57, /* (Ctrl) End */ | |
243 0xff56, /* (Ctrl) Page Down */ | |
244 0xff50, /* (Ctrl) Home */ | |
245 '1', '2', '3', '4', '5', '6', '7', '8', /* (Alt) */ | |
246 | |
247 /* --------------- 80 to 8f --------------- */ | |
248 '9', '0', '-', '=', /* (Alt) */ | |
249 0xff55, /* (Ctrl) Page Up */ | |
250 0xffc8, /* F11 */ | |
251 0xffc9, /* F12 */ | |
252 0xffc8, /* (Shift) F11 */ | |
253 0xffc9, /* (Shift) F12 */ | |
254 0xffc8, /* (Ctrl) F11 */ | |
255 0xffc9, /* (Ctrl) F12 */ | |
256 0xffc8, /* (Alt) F11 */ | |
257 0xffc9, /* (Alt) F12 */ | |
258 0xff52, /* (Ctrl) Up */ | |
259 0xffae, /* (Ctrl) Grey - */ | |
260 0xffb5, /* (Ctrl) Keypad 5 */ | |
261 | |
262 /* --------------- 90 to 9f --------------- */ | |
263 0xffab, /* (Ctrl) Grey + */ | |
264 0xff54, /* (Ctrl) Down */ | |
265 0xff63, /* (Ctrl) Insert */ | |
266 0xffff, /* (Ctrl) Delete */ | |
267 0xff09, /* (Ctrl) Tab */ | |
268 0xffaf, /* (Ctrl) Grey / */ | |
269 0xffaa, /* (Ctrl) Grey * */ | |
270 0xff50, /* (Alt) Home */ | |
271 0xff52, /* (Alt) Up */ | |
272 0xff55, /* (Alt) Page Up */ | |
273 0, /* NO KEY */ | |
274 0xff51, /* (Alt) Left */ | |
275 0, /* NO KEY */ | |
276 0xff53, /* (Alt) Right */ | |
277 0, /* NO KEY */ | |
278 0xff57, /* (Alt) End */ | |
279 | |
280 /* --------------- a0 to af --------------- */ | |
281 0xff54, /* (Alt) Down */ | |
282 0xff56, /* (Alt) Page Down */ | |
283 0xff63, /* (Alt) Insert */ | |
284 0xffff, /* (Alt) Delete */ | |
285 0xffaf, /* (Alt) Grey / */ | |
286 0xff09, /* (Alt) Tab */ | |
287 0xff0d /* (Alt) Enter */ | |
288 }; | |
289 | |
290 /* Get a char from keyboard. Function keys are put into the event queue. */ | |
291 static int | |
292 dos_rawgetc () | |
293 { | |
294 struct input_event event; | |
295 union REGS regs; | |
296 int ctrl_p, alt_p, shift_p; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
297 |
5503 | 298 /* Calculate modifier bits */ |
299 regs.h.ah = extended_kbd ? 0x12 : 0x02; | |
300 int86 (0x16, ®s, ®s); | |
301 ctrl_p = ((regs.h.al & 4) != 0); | |
302 shift_p = ((regs.h.al & 3) != 0); | |
7666
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
303 /* Please be very careful here not to break international keyboard support. |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
304 When Keyb.Com is loaded, the key marked `Alt Gr' is used for accessing |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
305 characters like { and } if their positions are overlaid. */ |
5503 | 306 alt_p = ((extended_kbd ? (regs.h.ah & 2) : (regs.h.al & 8)) != 0); |
307 | |
8194
b11f71df59d9
(dos_rawgetc): Use bios, not kbhit ().
Richard M. Stallman <rms@gnu.org>
parents:
8183
diff
changeset
|
308 /* The following condition is equivalent to `kbhit ()', except that |
b11f71df59d9
(dos_rawgetc): Use bios, not kbhit ().
Richard M. Stallman <rms@gnu.org>
parents:
8183
diff
changeset
|
309 it uses the bios to do its job. This pleases DESQview/X. */ |
b11f71df59d9
(dos_rawgetc): Use bios, not kbhit ().
Richard M. Stallman <rms@gnu.org>
parents:
8183
diff
changeset
|
310 while ((regs.h.ah = extended_kbd ? 0x11 : 0x01), |
b11f71df59d9
(dos_rawgetc): Use bios, not kbhit ().
Richard M. Stallman <rms@gnu.org>
parents:
8183
diff
changeset
|
311 int86 (0x16, ®s, ®s), |
b11f71df59d9
(dos_rawgetc): Use bios, not kbhit ().
Richard M. Stallman <rms@gnu.org>
parents:
8183
diff
changeset
|
312 (regs.x.flags & 0x40) == 0) |
5503 | 313 { |
314 union REGS regs; | |
315 register unsigned char c; | |
316 int sc, code; | |
317 | |
318 regs.h.ah = extended_kbd ? 0x10 : 0x00; | |
319 int86 (0x16, ®s, ®s); | |
320 c = regs.h.al; | |
321 sc = regs.h.ah; | |
322 | |
323 /* Determine from the scan code if a keypad key was pressed. */ | |
324 if (c >= '0' && c <= '9' && sc > 0xb) | |
325 sc = (c == '0') ? 0xb : (c - '0' + 1), c = 0; | |
7666
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
326 else if (sc == 0x53 && c != 0xe0) |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
327 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
328 code = 0xffae; /* Keypad decimal point/comma. */ |
7666
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
329 goto nonascii; |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
330 } |
5503 | 331 else if (sc == 0xe0) |
332 { | |
333 switch (c) | |
334 { | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
335 case 10: /* Ctrl Enter */ |
5503 | 336 case 13: |
337 sc = 0x1c; | |
338 break; | |
339 case '/': | |
340 sc = 0x35; | |
341 break; | |
342 default: | |
343 sc = 0; | |
344 }; | |
345 c = 0; | |
346 } | |
347 | |
348 if (c == 0 | |
349 || c == ' ' | |
350 || alt_p | |
351 || (ctrl_p && shift_p) | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
352 || (c == 0xe0 && sc != 0) /* Pseudo-key */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
353 || sc == 0x37 /* Grey * */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
354 || sc == 0x4a /* Grey - */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
355 || sc == 0x4e /* Grey + */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
356 || sc == 0x0e) /* Back space *key*, not Ctrl-h */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
357 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
358 if (sc >= (sizeof (ibmpc_translate_map) / sizeof (short))) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
359 code = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
360 else |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
361 code = ibmpc_translate_map[sc]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
362 if (code != 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
363 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
364 if (code >= 0x100) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
365 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
366 nonascii: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
367 event.kind = non_ascii_keystroke; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
368 event.code = (code & 0xff) + 0xff00; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
369 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
370 else |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
371 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
372 /* Don't return S- if we don't have to. `shifted' is |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
373 supposed to be the shifted versions of the characters |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
374 in `unshifted'. Unfortunately, this is only true for |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
375 US keyboard layout. If anyone knows how to do this |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
376 right, please tell us. */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
377 static char *unshifted |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
378 = "abcdefghijklmnopqrstuvwxyz,./=;[\\]'-`0123456789"; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
379 static char *shifted |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
380 = "ABCDEFGHIJKLMNOPQRSTUVWXYZ<>?+:{|}\"_~)!@#$%^&*("; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
381 char *pos; |
7666
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
382 |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
383 if (shift_p && (pos = strchr (unshifted, code))) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
384 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
385 c = shifted[pos - unshifted]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
386 shift_p = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
387 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
388 else |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
389 if (c == 0) c = code; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
390 event.kind = ascii_keystroke; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
391 event.code = c; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
392 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
393 event.modifiers |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
394 = (shift_p ? shift_modifier : 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
395 + (ctrl_p ? ctrl_modifier : 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
396 + (alt_p ? meta_modifier : 0); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
397 /* EMACS == Enter Meta Alt Control Shift */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
398 XSETFRAME (event.frame_or_window, selected_frame); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
399 event.timestamp = event_timestamp (); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
400 kbd_buffer_store_event (&event); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
401 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
402 } else |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
403 return c; |
5503 | 404 } |
405 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
406 if (have_mouse > 0) |
5503 | 407 { |
408 int but, press, x, y, ok; | |
409 | |
410 /* Check for mouse movement *before* buttons. */ | |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
411 mouse_check_moved (); |
5503 | 412 |
413 for (but = 0; but < NUM_MOUSE_BUTTONS; but++) | |
414 for (press = 0; press < 2; press++) | |
415 { | |
416 if (press) | |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
417 ok = mouse_pressed (but, &x, &y); |
5503 | 418 else |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
419 ok = mouse_released (but, &x, &y); |
5503 | 420 if (ok) |
421 { | |
422 event.kind = mouse_click; | |
423 event.code = but; | |
424 event.modifiers | |
7666
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
425 = (shift_p ? shift_modifier : 0) |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
426 + (ctrl_p ? ctrl_modifier : 0) |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
427 + (alt_p ? meta_modifier : 0) |
13a977e6777a
(dos_rawgetc): Doc fix. Make C-, S-, and M- modifiers
Richard M. Stallman <rms@gnu.org>
parents:
7523
diff
changeset
|
428 + (press ? down_modifier : up_modifier); |
5503 | 429 event.x = x; |
430 event.y = y; | |
9572 | 431 XSETFRAME (event.frame_or_window, selected_frame); |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
432 event.timestamp = event_timestamp (); |
5503 | 433 kbd_buffer_store_event (&event); |
434 } | |
435 } | |
436 } | |
437 | |
438 return -1; | |
439 } | |
440 | |
441 static int prev_get_char = -1; | |
442 | |
443 /* Return 1 if a key is ready to be read without suspending execution. */ | |
444 dos_keysns () | |
445 { | |
446 if (prev_get_char != -1) | |
447 return 1; | |
448 else | |
449 return ((prev_get_char = dos_rawgetc ()) != -1); | |
450 } | |
451 | |
452 /* Read a key. Return -1 if no key is ready. */ | |
453 dos_keyread () | |
454 { | |
455 if (prev_get_char != -1) | |
456 { | |
457 int c = prev_get_char; | |
458 prev_get_char = -1; | |
459 return c; | |
460 } | |
461 else | |
462 return dos_rawgetc (); | |
463 } | |
464 | |
465 /* Hostnames for a pc are not really funny, but they are used in change log | |
466 so we emulate the best we can. */ | |
467 gethostname (p, size) | |
468 char *p; | |
469 int size; | |
470 { | |
471 char *q = egetenv ("HOSTNAME"); | |
472 | |
473 if (!q) q = "pc"; | |
474 strcpy (p, q); | |
475 return 0; | |
476 } | |
477 | |
478 /* Destructively turn backslashes into slashes. */ | |
479 void | |
480 dostounix_filename (p) | |
481 register char *p; | |
482 { | |
483 while (*p) | |
484 { | |
485 if (*p == '\\') | |
486 *p = '/'; | |
487 p++; | |
488 } | |
489 } | |
490 | |
491 /* Destructively turn slashes into backslashes. */ | |
492 void | |
493 unixtodos_filename (p) | |
494 register char *p; | |
495 { | |
496 while (*p) | |
497 { | |
498 if (*p == '/') | |
499 *p = '\\'; | |
500 p++; | |
501 } | |
502 } | |
503 | |
504 /* Get the default directory for a given drive. 0=def, 1=A, 2=B, ... */ | |
505 int | |
506 getdefdir (drive, dst) | |
507 int drive; | |
508 char *dst; | |
509 { | |
510 union REGS regs; | |
511 | |
512 *dst++ = '/'; | |
513 regs.h.dl = drive; | |
514 regs.x.si = (int) dst; | |
515 regs.h.ah = 0x47; | |
516 intdos (®s, ®s); | |
517 return !regs.x.cflag; | |
518 } | |
519 | |
520 /* Remove all CR's that are followed by a LF. */ | |
521 int | |
522 crlf_to_lf (n, buf) | |
523 register int n; | |
524 register unsigned char *buf; | |
525 { | |
526 unsigned char *np = buf; | |
527 unsigned char *startp = buf; | |
528 unsigned char *endp = buf + n; | |
529 unsigned char c; | |
530 | |
531 if (n == 0) | |
532 return n; | |
7507
b393834bab2a
(crlf_to_lf): Fix off-by-one condition.
Richard M. Stallman <rms@gnu.org>
parents:
7273
diff
changeset
|
533 while (buf < endp - 1) |
5503 | 534 { |
535 if (*buf == 0x0d) | |
536 { | |
537 if (*(++buf) != 0x0a) | |
538 *np++ = 0x0d; | |
539 } | |
540 else | |
541 *np++ = *buf++; | |
542 } | |
7507
b393834bab2a
(crlf_to_lf): Fix off-by-one condition.
Richard M. Stallman <rms@gnu.org>
parents:
7273
diff
changeset
|
543 if (buf < endp) |
b393834bab2a
(crlf_to_lf): Fix off-by-one condition.
Richard M. Stallman <rms@gnu.org>
parents:
7273
diff
changeset
|
544 *np++ = *buf++; |
5503 | 545 return np - startp; |
546 } | |
547 | |
548 | |
549 /* Run command as specified by ARGV in directory DIR. | |
550 The command is run with input from TEMPIN and output to file TEMPOUT. */ | |
551 int | |
552 run_msdos_command (argv, dir, tempin, tempout) | |
553 unsigned char **argv; | |
554 Lisp_Object dir; | |
555 int tempin, tempout; | |
556 { | |
557 char *saveargv1, *saveargv2, **envv; | |
558 char oldwd[MAXPATHLEN + 1]; /* Fixed size is safe on MSDOS. */ | |
559 int msshell, result = -1; | |
560 int in, out, inbak, outbak, errbak; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
561 int x, y; |
5503 | 562 Lisp_Object cmd; |
563 | |
564 /* Get current directory as MSDOS cwd is not per-process. */ | |
565 getwd (oldwd); | |
566 | |
567 cmd = Ffile_name_nondirectory (build_string (argv[0])); | |
568 msshell = !NILP (Fmember (cmd, Fsymbol_value (intern ("msdos-shells")))) | |
569 && !strcmp ("-c", argv[1]); | |
570 if (msshell) | |
571 { | |
572 saveargv1 = argv[1]; | |
7774
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
573 saveargv2 = argv[2]; |
5503 | 574 argv[1] = "/c"; |
575 if (argv[2]) | |
576 { | |
7774
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
577 char *p = alloca (strlen (argv[2]) + 1); |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
578 |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
579 strcpy (argv[2] = p, saveargv2); |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
580 while (*p && isspace (*p)) |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
581 p++; |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
582 while (*p && !isspace (*p)) |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
583 if (*p == '/') |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
584 *p++ = '\\'; |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
585 else |
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
586 p++; |
5503 | 587 } |
588 } | |
589 | |
590 /* Build the environment array. */ | |
591 { | |
592 extern Lisp_Object Vprocess_environment; | |
6505
ce4fbb055f87
(run_msdos_command): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6056
diff
changeset
|
593 Lisp_Object tmp, lst; |
ce4fbb055f87
(run_msdos_command): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6056
diff
changeset
|
594 int i, len; |
ce4fbb055f87
(run_msdos_command): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6056
diff
changeset
|
595 |
ce4fbb055f87
(run_msdos_command): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6056
diff
changeset
|
596 lst = Vprocess_environment; |
ce4fbb055f87
(run_msdos_command): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6056
diff
changeset
|
597 len = XFASTINT (Flength (lst)); |
5503 | 598 |
599 envv = alloca ((len + 1) * sizeof (char *)); | |
600 for (i = 0; i < len; i++) | |
601 { | |
602 tmp = Fcar (lst); | |
603 lst = Fcdr (lst); | |
604 CHECK_STRING (tmp, 0); | |
605 envv[i] = alloca (XSTRING (tmp)->size + 1); | |
606 strcpy (envv[i], XSTRING (tmp)->data); | |
607 } | |
608 envv[len] = (char *) 0; | |
609 } | |
610 | |
9118
3c4437496ebc
(run_msdos_command): Use type test macros.
Karl Heuer <kwzh@gnu.org>
parents:
8246
diff
changeset
|
611 if (STRINGP (dir)) |
5503 | 612 chdir (XSTRING (dir)->data); |
613 inbak = dup (0); | |
614 outbak = dup (1); | |
615 errbak = dup (2); | |
616 if (inbak < 0 || outbak < 0 || errbak < 0) | |
617 goto done; /* Allocation might fail due to lack of descriptors. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
618 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
619 if (have_mouse > 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
620 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
621 mouse_get_xy (&x, &y); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
622 mouse_off (); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
623 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
624 dos_ttcooked(); /* do it here while 0 = stdin */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
625 |
5503 | 626 dup2 (tempin, 0); |
627 dup2 (tempout, 1); | |
628 dup2 (tempout, 2); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
629 |
5503 | 630 result = spawnve (P_WAIT, argv[0], argv, envv); |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
631 |
5503 | 632 dup2 (inbak, 0); |
633 dup2 (outbak, 1); | |
634 dup2 (errbak, 2); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
635 close (inbak); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
636 close (outbak); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
637 close (errbak); |
5503 | 638 |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
639 dos_ttraw(); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
640 if (have_mouse > 0) { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
641 mouse_init (); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
642 mouse_moveto (x, y); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
643 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
644 |
5503 | 645 done: |
646 chdir (oldwd); | |
647 if (msshell) | |
648 { | |
649 argv[1] = saveargv1; | |
7774
f9cde3320987
(run_msdos_command): Make local copy of argv[2] on stack, not on heap.
Karl Heuer <kwzh@gnu.org>
parents:
7744
diff
changeset
|
650 argv[2] = saveargv2; |
5503 | 651 } |
652 return result; | |
653 } | |
654 | |
655 | |
656 croak (badfunc) | |
657 char *badfunc; | |
658 { | |
659 fprintf (stderr, "%s not yet implemented\r\n", badfunc); | |
660 reset_sys_modes (); | |
661 exit (1); | |
662 } | |
663 | |
664 /* A list of unimplemented functions that we silently ignore. */ | |
665 unsigned alarm (s) unsigned s; {} | |
666 fork () { return 0; } | |
667 int kill (x, y) int x, y; { return -1; } | |
668 nice (p) int p; {} | |
669 void volatile pause () {} | |
670 request_sigio () {} | |
671 setpgrp () {return 0; } | |
672 setpriority (x,y,z) int x,y,z; { return 0; } | |
673 sigsetmask (x) int x; { return 0; } | |
674 unrequest_sigio () {} | |
675 | |
676 #ifdef chdir | |
677 #undef chdir | |
678 #endif | |
679 | |
680 int | |
681 sys_chdir (path) | |
682 const char* path; | |
683 { | |
684 int len = strlen (path); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
685 char *tmp = (char *)path; |
5503 | 686 /* Gotta do this extern here due to the corresponding #define: */ |
687 extern int chdir (); | |
688 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
689 if (*tmp && tmp[1] == ':') |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
690 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
691 if (getdisk () != tolower (tmp[0]) - 'a') |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
692 setdisk (tolower (tmp[0]) - 'a'); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
693 tmp += 2; /* strip drive: KFS 1995-07-06 */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
694 len -= 2; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
695 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
696 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
697 if (len > 1 && (tmp[len - 1] == '/')) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
698 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
699 char *tmp1 = (char *) alloca (len + 1); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
700 strcpy (tmp1, tmp); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
701 tmp1[len - 1] = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
702 tmp = tmp1; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
703 } |
5503 | 704 return chdir (tmp); |
705 } | |
706 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
707 #ifndef HAVE_SELECT |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
708 #include "sysselect.h" |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
709 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
710 /* Only event queue is checked. */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
711 int |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
712 sys_select (nfds, rfds, wfds, efds, timeout) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
713 int nfds; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
714 SELECT_TYPE *rfds, *wfds, *efds; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
715 EMACS_TIME *timeout; |
5503 | 716 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
717 SELECT_TYPE orfds; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
718 long timeoutval, clnow, cllast; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
719 struct time t; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
720 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
721 FD_ZERO (&orfds); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
722 if (rfds) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
723 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
724 orfds = *rfds; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
725 FD_ZERO (rfds); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
726 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
727 if (wfds) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
728 FD_ZERO (wfds); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
729 if (efds) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
730 FD_ZERO (efds); |
5503 | 731 |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
732 if (nfds != 1 || !FD_ISSET (0, &orfds)) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
733 abort (); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
734 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
735 /* If we are looking only for the terminal, with no timeout, |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
736 just read it and wait -- that's more efficient. */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
737 if (!timeout) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
738 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
739 while (! detect_input_pending ()); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
740 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
741 else |
5503 | 742 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
743 timeoutval = EMACS_SECS (*timeout) * 100 + EMACS_USECS (*timeout) / 10000; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
744 gettime (&t); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
745 cllast = t.ti_sec * 100 + t.ti_hund; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
746 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
747 while (!detect_input_pending ()) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
748 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
749 gettime (&t); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
750 clnow = t.ti_sec * 100 + t.ti_hund; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
751 if (clnow < cllast) /* time wrap */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
752 timeoutval -= clnow + 6000 - cllast; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
753 else |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
754 timeoutval -= clnow - cllast; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
755 if (timeoutval <= 0) /* Stop on timer being cleared */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
756 return 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
757 cllast = clnow; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
758 } |
5503 | 759 } |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
760 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
761 FD_SET (0, rfds); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
762 return 1; |
5503 | 763 } |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
764 #endif |
5503 | 765 |
7821
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
766 /* The Emacs root directory as determined by init_environment. */ |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
767 static char emacsroot[MAXPATHLEN]; |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
768 |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
769 char * |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
770 rootrelativepath (rel) |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
771 char *rel; |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
772 { |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
773 static char result[MAXPATHLEN + 10]; |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
774 |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
775 strcpy (result, emacsroot); |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
776 strcat (result, "/"); |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
777 strcat (result, rel); |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
778 return result; |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
779 } |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
780 |
5503 | 781 /* Define a lot of environment variables if not already defined. Don't |
782 remove anything unless you know what you're doing -- lots of code will | |
783 break if one or more of these are missing. */ | |
784 void | |
785 init_environment (argc, argv, skip_args) | |
786 int argc; | |
787 char **argv; | |
788 int skip_args; | |
789 { | |
7821
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
790 char *s, *t, *root; |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
791 int len; |
5503 | 792 |
7821
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
793 /* Find our root from argv[0]. Assuming argv[0] is, say, |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
794 "c:/emacs/bin/emacs.exe" our root will be "c:/emacs". */ |
12614
1415c961bea6
(init_environment): Move alloca call out of function arg.
Richard M. Stallman <rms@gnu.org>
parents:
12573
diff
changeset
|
795 root = alloca (MAXPATHLEN + 20); |
1415c961bea6
(init_environment): Move alloca call out of function arg.
Richard M. Stallman <rms@gnu.org>
parents:
12573
diff
changeset
|
796 _fixpath (argv[0], root); |
9572 | 797 strlwr (root); |
798 len = strlen (root); | |
7821
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
799 while (len > 0 && root[len] != '/' && root[len] != ':') |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
800 len--; |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
801 root[len] = '\0'; |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
802 if (len > 4 && strcmp (root + len - 4, "/bin") == 0) |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
803 root[len - 4] = '\0'; |
5503 | 804 else |
7821
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
805 strcpy (root, "c:/emacs"); /* Only under debuggers, I think. */ |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
806 len = strlen (root); |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
807 strcpy (emacsroot, root); |
5503 | 808 |
7821
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
809 /* We default HOME to our root. */ |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
810 setenv ("HOME", root, 0); |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
811 |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
812 /* We default EMACSPATH to root + "/bin". */ |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
813 strcpy (root + len, "/bin"); |
f96225d8c3eb
(init_environment): Clean up code and make the default
Richard M. Stallman <rms@gnu.org>
parents:
7774
diff
changeset
|
814 setenv ("EMACSPATH", root, 0); |
5503 | 815 |
816 /* I don't expect anybody to ever use other terminals so the internal | |
817 terminal is the default. */ | |
818 setenv ("TERM", "internal", 0); | |
819 | |
9572 | 820 #ifdef HAVE_X_WINDOWS |
821 /* Emacs expects DISPLAY to be set. */ | |
822 setenv ("DISPLAY", "unix:0.0", 0); | |
823 #endif | |
824 | |
5503 | 825 /* SHELL is a bit tricky -- COMSPEC is the closest we come, but we must |
826 downcase it and mirror the backslashes. */ | |
827 s = getenv ("COMSPEC"); | |
828 if (!s) s = "c:/command.com"; | |
829 t = alloca (strlen (s) + 1); | |
830 strcpy (t, s); | |
831 strlwr (t); | |
832 dostounix_filename (t); | |
833 setenv ("SHELL", t, 0); | |
834 | |
835 /* PATH is also downcased and backslashes mirrored. */ | |
836 s = getenv ("PATH"); | |
837 if (!s) s = ""; | |
838 t = alloca (strlen (s) + 3); | |
839 /* Current directory is always considered part of MsDos's path but it is | |
840 not normally mentioned. Now it is. */ | |
841 strcat (strcpy (t, ".;"), s); | |
842 strlwr (t); | |
843 dostounix_filename (t); /* Not a single file name, but this should work. */ | |
844 setenv ("PATH", t, 1); | |
845 | |
846 /* In some sense all dos users have root privileges, so... */ | |
847 setenv ("USER", "root", 0); | |
848 setenv ("NAME", getenv ("USER"), 0); | |
849 | |
850 /* Time zone determined from country code. To make this possible, the | |
851 country code may not span more than one time zone. In other words, | |
852 in the USA, you lose. */ | |
853 switch (dos_country_code) | |
854 { | |
855 case 31: /* Belgium */ | |
856 case 32: /* The Netherlands */ | |
857 case 33: /* France */ | |
858 case 34: /* Spain */ | |
859 case 36: /* Hungary */ | |
860 case 38: /* Yugoslavia (or what's left of it?) */ | |
861 case 39: /* Italy */ | |
862 case 41: /* Switzerland */ | |
863 case 42: /* Tjekia */ | |
864 case 45: /* Denmark */ | |
865 case 46: /* Sweden */ | |
866 case 47: /* Norway */ | |
867 case 48: /* Poland */ | |
868 case 49: /* Germany */ | |
869 /* Daylight saving from last Sunday in March to last Sunday in | |
870 September, both at 2AM. */ | |
871 setenv ("TZ", "MET-01METDST-02,M3.5.0/02:00,M9.5.0/02:00", 0); | |
872 break; | |
873 case 44: /* United Kingdom */ | |
874 case 351: /* Portugal */ | |
875 case 354: /* Iceland */ | |
876 setenv ("TZ", "GMT+00", 0); | |
877 break; | |
878 case 81: /* Japan */ | |
879 case 82: /* Korea */ | |
880 setenv ("TZ", "???-09", 0); | |
881 break; | |
882 case 90: /* Turkey */ | |
883 case 358: /* Finland */ | |
884 case 972: /* Israel */ | |
885 setenv ("TZ", "EET-02", 0); | |
886 break; | |
887 } | |
888 } | |
889 | |
890 /* Flash the screen as a substitute for BEEPs. */ | |
891 | |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
892 static void |
7667
bae9c0fa1c2f
(do_visible_bell): Renamed from visible_bell to avoid
Richard M. Stallman <rms@gnu.org>
parents:
7666
diff
changeset
|
893 do_visible_bell (xorattr) |
5503 | 894 unsigned char xorattr; |
895 { | |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
896 asm volatile |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
897 (" movb $1,%%dl |
5503 | 898 visible_bell_0: |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
899 movl _ScreenPrimary,%%eax |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
900 call dosmemsetup |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
901 movl %%eax,%%ebx |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
902 movl %1,%%ecx |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
903 movb %0,%%al |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
904 incl %%ebx |
5503 | 905 visible_bell_1: |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
906 xorb %%al,%%gs:(%%ebx) |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
907 addl $2,%%ebx |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
908 decl %%ecx |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
909 jne visible_bell_1 |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
910 decb %%dl |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
911 jne visible_bell_3 |
5503 | 912 visible_bell_2: |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
913 movzwl %%ax,%%eax |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
914 movzwl %%ax,%%eax |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
915 movzwl %%ax,%%eax |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
916 movzwl %%ax,%%eax |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
917 decw %%cx |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
918 jne visible_bell_2 |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
919 jmp visible_bell_0 |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
920 visible_bell_3:" |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
921 : /* no output */ |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
922 : "m" (xorattr), "g" (ScreenCols () * ScreenRows ()) |
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
923 : "%eax", "%ebx", /* "%gs",*/ "%ecx", "%edx"); |
5503 | 924 } |
925 | |
7744
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
926 /* At screen position (X,Y), output C characters from string S with |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
927 attribute A. Do it fast! */ |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
928 |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
929 static void |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
930 output_string (x, y, s, c, a) |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
931 int x, y, c; |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
932 unsigned char *s; |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
933 unsigned char a; |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
934 { |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
935 char *t = (char *)ScreenPrimary + 2 * (x + ScreenCols () * y); |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
936 #ifdef DO_TERMSCRIPT |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
937 if (termscript) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
938 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
939 fprintf (termscript, "<%d@%dx%d>", c, x, y); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
940 fwrite (s, sizeof (unsigned char), c, termscript); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
941 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
942 #endif |
7744
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
943 asm volatile |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
944 (" movl %1,%%eax |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
945 call dosmemsetup |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
946 movl %%eax,%%edi |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
947 movb %0,%%ah |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
948 movl %2,%%ecx |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
949 movl %3,%%esi |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
950 output_string1: |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
951 movb (%%esi),%%al |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
952 movw %%ax,%%gs:(%%edi) |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
953 addl $2,%%edi |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
954 incl %%esi |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
955 decl %%ecx |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
956 jne output_string1" |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
957 : /* no output */ |
7744
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
958 : "m" (a), "g" (t), "g" (c), "g" (s) |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
959 : "%eax", "%ecx", /* "%gs",*/ "%esi", "%edi"); |
7744
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
960 } |
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
961 |
5503 | 962 static int internal_terminal = 0; |
9572 | 963 static int highlight; |
964 | |
5503 | 965 #undef fflush |
966 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
967 static int /* number of characters used by escape; -1 if incomplete */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
968 flush_escape (resume, cp, count, xp, yp) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
969 int resume; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
970 unsigned char *cp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
971 int count; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
972 int *xp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
973 int *yp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
974 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
975 static char spaces[] = " "; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
976 static unsigned char esc_cmd[8]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
977 static int esc_count = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
978 int esc_needed; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
979 int i, j, used = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
980 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
981 if (!resume) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
982 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
983 esc_cmd[0] = '\e'; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
984 esc_count = 1; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
985 used++; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
986 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
987 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
988 while (esc_count < 2) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
989 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
990 if (used == count) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
991 return -1; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
992 esc_cmd[esc_count++] = *cp++; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
993 used++; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
994 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
995 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
996 switch (esc_cmd[1]) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
997 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
998 case '@': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
999 esc_needed = 4; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1000 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1001 case 'A': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1002 case 'B': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1003 case 'X': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1004 esc_needed = 3; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1005 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1006 default: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1007 esc_needed = 2; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1008 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1009 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1010 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1011 while (esc_count < esc_needed) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1012 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1013 if (used == count) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1014 return -1; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1015 esc_cmd[esc_count++] = *cp++; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1016 used++; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1017 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1018 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1019 switch (esc_cmd[1]) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1020 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1021 case '@': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1022 *yp = esc_cmd[2]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1023 *xp = esc_cmd[3]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1024 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1025 case 'A': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1026 ScreenAttrib = esc_cmd[2]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1027 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1028 case 'B': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1029 do_visible_bell (esc_cmd[2]); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1030 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1031 case 'C': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1032 ScreenClear (); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1033 *xp = *yp = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1034 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1035 case 'E': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1036 i = ScreenCols () - *xp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1037 j = *xp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1038 while (i >= sizeof spaces) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1039 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1040 output_string (j, *yp, spaces, sizeof spaces, ScreenAttrib); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1041 j += sizeof spaces; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1042 i -= sizeof spaces; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1043 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1044 if (i > 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1045 output_string (j, *yp, spaces, i, ScreenAttrib); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1046 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1047 case 'R': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1048 ++*xp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1049 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1050 case 'U': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1051 --*yp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1052 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1053 case 'X': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1054 ScreenAttrib ^= esc_cmd[2]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1055 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1056 case '\e': |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1057 output_string (*xp, *yp, &esc_cmd[1], 1, ScreenAttrib); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1058 ++*xp; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1059 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1060 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1061 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1062 esc_count = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1063 return used; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1064 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1065 |
5503 | 1066 int |
1067 internal_flush (f) | |
1068 FILE *f; | |
1069 { | |
1070 static int x; | |
1071 static int y; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1072 static int resume_esc = 0; |
7744
da18793f532d
(output_string): New function.
Richard M. Stallman <rms@gnu.org>
parents:
7667
diff
changeset
|
1073 unsigned char *cp, *cp0; |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1074 int count, i; |
5503 | 1075 |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1076 if (!internal_terminal || f != stdout) |
5503 | 1077 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1078 /* This is a call to the original fflush. */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1079 fflush (f); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1080 return; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1081 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1082 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1083 mouse_off (); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1084 cp = stdout->_base; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1085 count = stdout->_ptr - stdout->_base; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1086 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1087 #ifdef DO_TERMSCRIPT |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1088 if (termscript) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1089 fprintf (termscript, "\n<FLUSH%s %d>\n", resume_esc ? " RESUME" : "", count); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1090 #endif |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1091 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1092 if (resume_esc) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1093 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1094 i = flush_escape (1, cp, count, &x, &y); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1095 if (i < 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1096 count = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1097 else |
5503 | 1098 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1099 resume_esc = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1100 count -= i; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1101 cp += i; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1102 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1103 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1104 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1105 while (count > 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1106 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1107 switch (*cp++) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1108 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1109 case 27: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1110 i = flush_escape (0, cp, count, &x, &y); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1111 if (i < 0) |
5503 | 1112 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1113 resume_esc = 1; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1114 count = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1115 } |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1116 else |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1117 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1118 count -= i; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1119 cp += i - 1; |
5503 | 1120 } |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1121 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1122 case 7: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1123 write (1, "\007", 1); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1124 count--; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1125 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1126 case 8: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1127 x--; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1128 count--; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1129 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1130 case 13: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1131 x = 0; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1132 count--; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1133 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1134 case 10: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1135 y++; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1136 count--; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1137 break; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1138 default: |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1139 cp0 = cp - 1; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1140 count--; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1141 while (count > 0 && *cp >= ' ') |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1142 cp++, count--; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1143 output_string (x, y, cp0, cp - cp0, ScreenAttrib); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1144 x += (cp - cp0); |
5503 | 1145 } |
1146 } | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1147 fpurge (stdout); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1148 ScreenSetCursor (y, x); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1149 mouse_on (); |
5503 | 1150 } |
1151 | |
9572 | 1152 #ifndef HAVE_X_WINDOWS |
1153 static void | |
1154 rien_du_tout () | |
1155 { | |
1156 /* Rien du tout, cela va sans dire! */ | |
1157 } | |
1158 | |
1159 static | |
1160 IT_ring_bell () | |
1161 { | |
1162 if (visible_bell) | |
1163 { | |
1164 /* This creates an xor-mask that will swap the default fore- and | |
1165 background colors. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1166 mouse_off (); |
9572 | 1167 do_visible_bell (((the_only_x_display.foreground_pixel |
1168 ^ the_only_x_display.background_pixel) | |
1169 * 0x11) & 0x7f); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1170 mouse_on (); |
9572 | 1171 } |
1172 else | |
1173 /* Write it directly to ms-dos -- don't let it go through our terminal | |
1174 emulator. This way the mouse cursor won't blink. */ | |
1175 write (1, "\007", 1); | |
1176 } | |
1177 | |
1178 static void | |
1179 IT_set_face (int face) | |
1180 { | |
1181 struct face *fp; | |
1182 extern struct face *intern_face (/* FRAME_PTR, struct face * */); | |
1183 | |
1184 if (face == 1 || (face == 0 && highlight)) | |
1185 fp = FRAME_MODE_LINE_FACE (foo); | |
1186 else if (face <= 0 || face >= FRAME_N_COMPUTED_FACES (foo)) | |
1187 fp = FRAME_DEFAULT_FACE (foo); | |
1188 else | |
1189 fp = intern_face (selected_frame, FRAME_COMPUTED_FACES (foo)[face]); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1190 #ifdef DO_TERMSCRIPT |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1191 if (termscript) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1192 fprintf (termscript, "<FACE:%d:%d>", FACE_FOREGROUND (fp), FACE_BACKGROUND (fp)); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1193 #endif |
9572 | 1194 putchar ('\e'); |
1195 putchar ('A'); | |
1196 putchar ((FACE_BACKGROUND (fp) << 4) | FACE_FOREGROUND (fp)); | |
1197 } | |
1198 | |
1199 static | |
1200 IT_write_glyphs (GLYPH *str, int len) | |
1201 { | |
1202 int face = -1; | |
1203 int newface; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1204 int ch; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1205 |
9572 | 1206 while (len > 0) |
1207 { | |
1208 newface = FAST_GLYPH_FACE (*str); | |
1209 if (newface != face) | |
1210 IT_set_face ((face = newface)); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1211 ch = FAST_GLYPH_CHAR (*str); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1212 #ifdef DO_TERMSCRIPT |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1213 if (termscript) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1214 fputc (ch, termscript); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1215 #endif |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1216 if (ch == '\e') putchar (ch); /* allow esc to be printed */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1217 putchar (ch); |
9572 | 1218 str++, len--; |
1219 } | |
1220 } | |
1221 | |
1222 static | |
1223 IT_clear_end_of_line (first_unused) | |
1224 { | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1225 IT_set_face (0); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1226 #ifdef DO_TERMSCRIPT |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1227 if (termscript) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1228 fprintf (termscript, "<CLR:EOL>"); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1229 #endif |
9572 | 1230 putchar ('\e'); |
1231 putchar ('E'); | |
1232 } | |
1233 | |
1234 static | |
1235 IT_cursor_to (int y, int x) | |
1236 { | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1237 #ifdef DO_TERMSCRIPT |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1238 if (termscript) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1239 fprintf (termscript, "\n<XY=%dx%d>", x, y); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1240 #endif |
9572 | 1241 putchar ('\e'); |
1242 putchar ('@'); | |
1243 putchar (y); | |
1244 putchar (x); | |
1245 } | |
1246 | |
1247 IT_reassert_line_highlight (new, vpos) | |
1248 int new, vpos; | |
1249 { | |
1250 highlight = new; | |
1251 IT_set_face (0); /* To possibly clear the highlighting. */ | |
1252 } | |
1253 | |
1254 static | |
1255 IT_change_line_highlight (new_highlight, vpos, first_unused_hpos) | |
1256 { | |
1257 highlight = new_highlight; | |
1258 IT_set_face (0); /* To possibly clear the highlighting. */ | |
1259 IT_cursor_to (vpos, 0); | |
1260 IT_clear_end_of_line (first_unused_hpos); | |
1261 } | |
1262 | |
1263 static | |
1264 IT_update_begin () | |
1265 { | |
1266 highlight = 0; | |
1267 IT_set_face (0); /* To possibly clear the highlighting. */ | |
1268 } | |
1269 | |
1270 /* This was more or less copied from xterm.c */ | |
1271 static void | |
1272 IT_set_menu_bar_lines (window, n) | |
1273 Lisp_Object window; | |
1274 int n; | |
1275 { | |
1276 struct window *w = XWINDOW (window); | |
1277 | |
1278 XSETFASTINT (w->top, XFASTINT (w->top) + n); | |
1279 XSETFASTINT (w->height, XFASTINT (w->height) - n); | |
1280 | |
1281 /* Handle just the top child in a vertical split. */ | |
1282 if (!NILP (w->vchild)) | |
1283 IT_set_menu_bar_lines (w->vchild, n); | |
1284 | |
1285 /* Adjust all children in a horizontal split. */ | |
1286 for (window = w->hchild; !NILP (window); window = w->next) | |
1287 { | |
1288 w = XWINDOW (window); | |
1289 IT_set_menu_bar_lines (window, n); | |
1290 } | |
1291 } | |
1292 | |
1293 void | |
1294 IT_set_frame_parameters (frame, alist) | |
1295 FRAME_PTR frame; | |
1296 Lisp_Object alist; | |
1297 { | |
1298 Lisp_Object tail; | |
1299 int redraw; | |
1300 extern unsigned long load_color (); | |
1301 FRAME_PTR f = (FRAME_PTR) &the_only_frame; | |
1302 | |
1303 redraw = 0; | |
1304 for (tail = alist; CONSP (tail); tail = Fcdr (tail)) | |
1305 { | |
1306 Lisp_Object elt, prop, val; | |
1307 | |
1308 elt = Fcar (tail); | |
1309 prop = Fcar (elt); | |
1310 val = Fcdr (elt); | |
1311 CHECK_SYMBOL (prop, 1); | |
1312 | |
1313 if (EQ (prop, intern ("foreground-color"))) | |
1314 { | |
1315 unsigned long new_color = load_color (f, val); | |
1316 if (new_color != ~0) | |
1317 { | |
1318 FRAME_FOREGROUND_PIXEL (f) = new_color; | |
1319 redraw = 1; | |
1320 } | |
1321 } | |
1322 else if (EQ (prop, intern ("background-color"))) | |
1323 { | |
1324 unsigned long new_color = load_color (f, val); | |
1325 if (new_color != ~0) | |
1326 { | |
1327 FRAME_BACKGROUND_PIXEL (f) = new_color & ~8; | |
1328 redraw = 1; | |
1329 } | |
1330 } | |
1331 else if (EQ (prop, intern ("menu-bar-lines"))) | |
1332 { | |
1333 int new; | |
1334 int old = FRAME_MENU_BAR_LINES (the_only_frame); | |
1335 | |
1336 if (INTEGERP (val)) | |
1337 new = XINT (val); | |
1338 else | |
1339 new = 0; | |
1340 FRAME_MENU_BAR_LINES (f) = new; | |
1341 IT_set_menu_bar_lines (the_only_frame.root_window, new - old); | |
1342 } | |
1343 } | |
1344 | |
1345 if (redraw) | |
1346 { | |
1347 recompute_basic_faces (f); | |
1348 Fredraw_frame (Fselected_frame ()); | |
1349 } | |
1350 } | |
1351 | |
1352 /* Similar to the_only_frame. */ | |
1353 struct x_display the_only_x_display; | |
1354 | |
1355 /* This is never dereferenced. */ | |
1356 Display *x_current_display; | |
1357 | |
1358 #endif /* !HAVE_X_WINDOWS */ | |
1359 | |
5503 | 1360 /* Do we need the internal terminal? */ |
1361 void | |
1362 internal_terminal_init () | |
1363 { | |
1364 char *term = getenv ("TERM"); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1365 char *colors; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1366 |
9572 | 1367 #ifdef HAVE_X_WINDOWS |
1368 if (!inhibit_window_system) | |
1369 return; | |
1370 #endif | |
1371 | |
5503 | 1372 internal_terminal |
1373 = (!noninteractive) && term && !strcmp (term, "internal"); | |
9572 | 1374 |
1375 #ifndef HAVE_X_WINDOWS | |
1376 if (internal_terminal && !inhibit_window_system) | |
1377 { | |
1378 Vwindow_system = intern ("pc"); | |
1379 Vwindow_system_version = make_number (1); | |
1380 | |
1381 bzero (&the_only_x_display, sizeof the_only_x_display); | |
1382 the_only_x_display.background_pixel = 7; /* White */ | |
1383 the_only_x_display.foreground_pixel = 0; /* Black */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1384 colors = getenv ("EMACSCOLORS"); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1385 if (colors && strlen (colors) >=2) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1386 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1387 the_only_x_display.foreground_pixel = colors[0] & 0x07; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1388 the_only_x_display.background_pixel = colors[1] & 0x07; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1389 } |
9572 | 1390 the_only_x_display.line_height = 1; |
1391 the_only_frame.display.x = &the_only_x_display; | |
1392 the_only_frame.output_method = output_msdos_raw; | |
1393 | |
1394 init_frame_faces ((FRAME_PTR) &the_only_frame); | |
1395 | |
1396 ring_bell_hook = IT_ring_bell; | |
1397 write_glyphs_hook = IT_write_glyphs; | |
1398 cursor_to_hook = raw_cursor_to_hook = IT_cursor_to; | |
1399 clear_end_of_line_hook = IT_clear_end_of_line; | |
1400 change_line_highlight_hook = IT_change_line_highlight; | |
1401 update_begin_hook = IT_update_begin; | |
1402 reassert_line_highlight_hook = IT_reassert_line_highlight; | |
1403 | |
1404 /* These hooks are called by term.c without being checked. */ | |
1405 set_terminal_modes_hook | |
1406 = reset_terminal_modes_hook | |
1407 = update_end_hook | |
1408 = set_terminal_window_hook | |
1409 = (void *)rien_du_tout; | |
1410 } | |
1411 else | |
1412 the_only_frame.output_method = output_termcap; | |
1413 #endif | |
5503 | 1414 } |
7523
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1415 |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1416 /* When time zones are set from Ms-Dos too may C-libraries are playing |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1417 tricks with time values. We solve this by defining our own version |
13020
a656ccd43989
(gettimeofday): Don't bother setting time zone,
Richard M. Stallman <rms@gnu.org>
parents:
12995
diff
changeset
|
1418 of `gettimeofday' bypassing GO32. */ |
7523
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1419 |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1420 int |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1421 gettimeofday (struct timeval *tp, struct timezone *tzp) |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1422 { |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1423 if (tp) |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1424 { |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1425 struct time t; |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1426 |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1427 gettime (&t); |
13020
a656ccd43989
(gettimeofday): Don't bother setting time zone,
Richard M. Stallman <rms@gnu.org>
parents:
12995
diff
changeset
|
1428 tp->tv_sec = time (NULL); |
a656ccd43989
(gettimeofday): Don't bother setting time zone,
Richard M. Stallman <rms@gnu.org>
parents:
12995
diff
changeset
|
1429 /* If tp->tv_sec%60 != t.ti_sec, the seconds counter turned over |
a656ccd43989
(gettimeofday): Don't bother setting time zone,
Richard M. Stallman <rms@gnu.org>
parents:
12995
diff
changeset
|
1430 between the call to `gettime' and the call to `time'. */ |
a656ccd43989
(gettimeofday): Don't bother setting time zone,
Richard M. Stallman <rms@gnu.org>
parents:
12995
diff
changeset
|
1431 tp->tv_usec = tp->tv_sec%60 != t.ti_sec ? 0 : t.ti_hund * (1000000/100); |
7523
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1432 } |
13020
a656ccd43989
(gettimeofday): Don't bother setting time zone,
Richard M. Stallman <rms@gnu.org>
parents:
12995
diff
changeset
|
1433 /* Ignore tzp; it's obsolescent. */ |
7523
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1434 return 0; |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1435 } |
8994727ff976
(gettimeofday): New function substituting the library
Richard M. Stallman <rms@gnu.org>
parents:
7507
diff
changeset
|
1436 |
5503 | 1437 /* These must be global. */ |
1438 static _go32_dpmi_seginfo ctrl_break_vector; | |
1439 static _go32_dpmi_registers ctrl_break_regs; | |
1440 static int ctrlbreakinstalled = 0; | |
1441 | |
1442 /* Interrupt level detection of Ctrl-Break. Don't do anything fancy here! */ | |
1443 void | |
1444 ctrl_break_func (regs) | |
1445 _go32_dpmi_registers *regs; | |
1446 { | |
1447 Vquit_flag = Qt; | |
1448 } | |
1449 | |
1450 void | |
1451 install_ctrl_break_check () | |
1452 { | |
1453 if (!ctrlbreakinstalled) | |
1454 { | |
1455 /* Don't press Ctrl-Break if you don't have either DPMI or Emacs | |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
1456 was compiler with Djgpp 1.11 maintenance level 5 or later! */ |
5503 | 1457 ctrlbreakinstalled = 1; |
1458 ctrl_break_vector.pm_offset = (int) ctrl_break_func; | |
1459 _go32_dpmi_allocate_real_mode_callback_iret (&ctrl_break_vector, | |
1460 &ctrl_break_regs); | |
1461 _go32_dpmi_set_real_mode_interrupt_vector (0x1b, &ctrl_break_vector); | |
1462 } | |
1463 } | |
1464 | |
9572 | 1465 /* Mouse routines follow. Coordinates are in screen positions and zero |
1466 based. Mouse buttons are numbered from left to right and also zero | |
1467 based. */ | |
5503 | 1468 |
1469 static int mouse_button_translate[NUM_MOUSE_BUTTONS]; | |
1470 static int mouse_button_count; | |
1471 | |
1472 void | |
1473 mouse_init () | |
1474 { | |
1475 union REGS regs; | |
1476 | |
1477 regs.x.ax = 0x0007; | |
1478 regs.x.cx = 0; | |
1479 regs.x.dx = 8 * (ScreenCols () - 1); | |
1480 int86 (0x33, ®s, ®s); | |
1481 | |
1482 regs.x.ax = 0x0008; | |
1483 regs.x.cx = 0; | |
1484 regs.x.dx = 8 * (ScreenRows () - 1); | |
1485 int86 (0x33, ®s, ®s); | |
1486 | |
1487 mouse_moveto (ScreenCols () - 1, ScreenRows () - 1); | |
1488 mouse_on (); | |
1489 } | |
1490 | |
1491 void | |
1492 mouse_on () | |
1493 { | |
1494 union REGS regs; | |
1495 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1496 if (have_mouse > 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1497 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1498 regs.x.ax = 0x0001; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1499 int86 (0x33, ®s, ®s); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1500 } |
5503 | 1501 } |
1502 | |
1503 void | |
1504 mouse_off () | |
1505 { | |
1506 union REGS regs; | |
1507 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1508 if (have_mouse > 0) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1509 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1510 regs.x.ax = 0x0002; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1511 int86 (0x33, ®s, ®s); |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1512 } |
5503 | 1513 } |
1514 | |
1515 void | |
1516 mouse_moveto (x, y) | |
1517 int x, y; | |
1518 { | |
1519 union REGS regs; | |
1520 | |
1521 regs.x.ax = 0x0004; | |
1522 mouse_last_x = regs.x.cx = x * 8; | |
1523 mouse_last_y = regs.x.dx = y * 8; | |
1524 int86 (0x33, ®s, ®s); | |
1525 } | |
1526 | |
1527 int | |
1528 mouse_pressed (b, xp, yp) | |
1529 int b, *xp, *yp; | |
1530 { | |
1531 union REGS regs; | |
1532 | |
1533 if (b >= mouse_button_count) | |
1534 return 0; | |
1535 regs.x.ax = 0x0005; | |
1536 regs.x.bx = mouse_button_translate[b]; | |
1537 int86 (0x33, ®s, ®s); | |
1538 if (regs.x.bx) | |
8183
d35fd7fd0ef8
(install_ctrl_break_check): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7821
diff
changeset
|
1539 *xp = regs.x.cx / 8, *yp = regs.x.dx / 8; |
5503 | 1540 return (regs.x.bx != 0); |
1541 } | |
1542 | |
1543 int | |
1544 mouse_released (b, xp, yp) | |
1545 int b, *xp, *yp; | |
1546 { | |
1547 union REGS regs; | |
1548 | |
1549 if (b >= mouse_button_count) | |
1550 return 0; | |
1551 regs.x.ax = 0x0006; | |
1552 regs.x.bx = mouse_button_translate[b]; | |
1553 int86 (0x33, ®s, ®s); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1554 #if 0 |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1555 if (regs.x.ax & (1 << mouse_button_translate[b])) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1556 regs.x.bx = 0; /* if mouse is still pressed, ignore release */ |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1557 #endif |
5503 | 1558 if (regs.x.bx) |
1559 *xp = regs.x.cx / 8, *yp = regs.x.dx / 8; | |
1560 return (regs.x.bx != 0); | |
1561 } | |
1562 | |
9572 | 1563 static void |
1564 mouse_get_xy (int *x, int *y) | |
1565 { | |
1566 union REGS regs; | |
1567 | |
1568 regs.x.ax = 0x0003; | |
1569 int86 (0x33, ®s, ®s); | |
1570 *x = regs.x.cx / 8; | |
1571 *y = regs.x.dx / 8; | |
1572 } | |
1573 | |
5503 | 1574 void |
11124
020042ee37cd
(mouse_get_pos): New arg `insist'.
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
1575 mouse_get_pos (f, insist, bar_window, part, x, y, time) |
5503 | 1576 FRAME_PTR *f; |
11124
020042ee37cd
(mouse_get_pos): New arg `insist'.
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
1577 int insist; |
5503 | 1578 Lisp_Object *bar_window, *x, *y; |
1579 enum scroll_bar_part *part; | |
1580 unsigned long *time; | |
1581 { | |
9572 | 1582 int ix, iy; |
5503 | 1583 union REGS regs; |
1584 | |
1585 regs.x.ax = 0x0003; | |
1586 int86 (0x33, ®s, ®s); | |
1587 *f = selected_frame; | |
1588 *bar_window = Qnil; | |
9572 | 1589 mouse_get_xy (&ix, &iy); |
12573
f8193b0f95ed
(mouse_get_pos, mouse_check_moved, XMenuActivate):
Karl Heuer <kwzh@gnu.org>
parents:
11124
diff
changeset
|
1590 selected_frame->mouse_moved = 0; |
9572 | 1591 *x = make_number (ix); |
1592 *y = make_number (iy); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1593 *time = event_timestamp (); |
5503 | 1594 } |
1595 | |
1596 void | |
1597 mouse_check_moved () | |
1598 { | |
9572 | 1599 int x, y; |
5503 | 1600 |
9572 | 1601 mouse_get_xy (&x, &y); |
12573
f8193b0f95ed
(mouse_get_pos, mouse_check_moved, XMenuActivate):
Karl Heuer <kwzh@gnu.org>
parents:
11124
diff
changeset
|
1602 selected_frame->mouse_moved |= (x != mouse_last_x || y != mouse_last_y); |
9572 | 1603 mouse_last_x = x; |
1604 mouse_last_y = y; | |
5503 | 1605 } |
1606 | |
1607 int | |
1608 mouse_init1 () | |
1609 { | |
1610 union REGS regs; | |
1611 int present; | |
1612 | |
9572 | 1613 #ifdef HAVE_X_WINDOWS |
1614 if (!inhibit_window_system) | |
1615 return 0; | |
1616 #endif | |
8246
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1617 if (!internal_terminal) |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1618 return 0; |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1619 |
5503 | 1620 regs.x.ax = 0x0021; |
1621 int86 (0x33, ®s, ®s); | |
8246
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1622 present = (regs.x.ax & 0xffff) == 0xffff; |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1623 if (!present) |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1624 { |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1625 /* Reportedly, the above doesn't work for some mouse drivers. There |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1626 is an additional detection method that should work, but might be |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1627 a little slower. Use that as an alternative. */ |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1628 regs.x.ax = 0x0000; |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1629 int86 (0x33, ®s, ®s); |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1630 present = (regs.x.ax & 0xffff) == 0xffff; |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1631 } |
d48c2b01fba5
(mouse_init1): Use alternate mouse detection for old mouse drivers.
Richard M. Stallman <rms@gnu.org>
parents:
8194
diff
changeset
|
1632 |
5503 | 1633 if (present) |
1634 { | |
1635 if (regs.x.bx == 3) | |
1636 { | |
1637 mouse_button_count = 3; | |
1638 mouse_button_translate[0] = 0; /* Left */ | |
1639 mouse_button_translate[1] = 2; /* Middle */ | |
1640 mouse_button_translate[2] = 1; /* Right */ | |
1641 } | |
1642 else | |
1643 { | |
1644 mouse_button_count = 2; | |
1645 mouse_button_translate[0] = 0; | |
1646 mouse_button_translate[1] = 1; | |
1647 } | |
1648 mouse_position_hook = &mouse_get_pos; | |
1649 mouse_init (); | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1650 } |
5503 | 1651 return present; |
1652 } | |
1653 | |
9572 | 1654 #ifndef HAVE_X_WINDOWS |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1655 /* See xterm.c for more info. */ |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1656 void |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1657 pixel_to_glyph_coords (f, pix_x, pix_y, x, y, bounds, noclip) |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1658 FRAME_PTR f; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1659 register int pix_x, pix_y; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1660 register int *x, *y; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1661 void /* XRectangle */ *bounds; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1662 int noclip; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1663 { |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1664 if (bounds) abort (); |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1665 |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1666 /* Ignore clipping. */ |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1667 |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1668 *x = pix_x; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1669 *y = pix_y; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1670 } |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1671 |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1672 void |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1673 glyph_to_pixel_coords (f, x, y, pix_x, pix_y) |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1674 FRAME_PTR f; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1675 register int x, y; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1676 register int *pix_x, *pix_y; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1677 { |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1678 *pix_x = x; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1679 *pix_y = y; |
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
1680 } |
9572 | 1681 |
1682 /* Simulation of X's menus. Nothing too fancy here -- just make it work | |
1683 for now. | |
1684 | |
1685 Actually, I don't know the meaning of all the parameters of the functions | |
1686 here -- I only know how they are called by xmenu.c. I could of course | |
1687 grab the nearest Xlib manual (down the hall, second-to-last door on the | |
1688 left), but I don't think it's worth the effort. */ | |
1689 | |
1690 static XMenu * | |
1691 IT_menu_create () | |
1692 { | |
1693 XMenu *menu; | |
1694 | |
1695 menu = (XMenu *) xmalloc (sizeof (XMenu)); | |
1696 menu->allocated = menu->count = menu->panecount = menu->width = 0; | |
1697 return menu; | |
1698 } | |
1699 | |
1700 /* Allocate some (more) memory for MENU ensuring that there is room for one | |
1701 for item. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1702 |
9572 | 1703 static void |
1704 IT_menu_make_room (XMenu *menu) | |
1705 { | |
1706 if (menu->allocated == 0) | |
1707 { | |
1708 int count = menu->allocated = 10; | |
1709 menu->text = (char **) xmalloc (count * sizeof (char *)); | |
1710 menu->submenu = (XMenu **) xmalloc (count * sizeof (XMenu *)); | |
1711 menu->panenumber = (int *) xmalloc (count * sizeof (int)); | |
1712 } | |
1713 else if (menu->allocated == menu->count) | |
1714 { | |
1715 int count = menu->allocated = menu->allocated + 10; | |
1716 menu->text | |
1717 = (char **) xrealloc (menu->text, count * sizeof (char *)); | |
1718 menu->submenu | |
1719 = (XMenu **) xrealloc (menu->submenu, count * sizeof (XMenu *)); | |
1720 menu->panenumber | |
1721 = (int *) xrealloc (menu->panenumber, count * sizeof (int)); | |
1722 } | |
1723 } | |
1724 | |
1725 /* Search the given menu structure for a given pane number. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1726 |
9572 | 1727 static XMenu * |
1728 IT_menu_search_pane (XMenu *menu, int pane) | |
1729 { | |
1730 int i; | |
1731 XMenu *try; | |
1732 | |
1733 for (i = 0; i < menu->count; i++) | |
1734 if (menu->submenu[i]) | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1735 { |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1736 if (pane == menu->panenumber[i]) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1737 return menu->submenu[i]; |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1738 else if ((try = IT_menu_search_pane (menu->submenu[i], pane))) |
9572 | 1739 return try; |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1740 } |
9572 | 1741 return (XMenu *) 0; |
1742 } | |
1743 | |
1744 /* Determine how much screen space a given menu needs. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1745 |
9572 | 1746 static void |
1747 IT_menu_calc_size (XMenu *menu, int *width, int *height) | |
1748 { | |
1749 int i, h2, w2, maxsubwidth, maxheight; | |
1750 | |
1751 maxsubwidth = 0; | |
1752 maxheight = menu->count; | |
1753 for (i = 0; i < menu->count; i++) | |
1754 { | |
1755 if (menu->submenu[i]) | |
1756 { | |
1757 IT_menu_calc_size (menu->submenu[i], &w2, &h2); | |
1758 if (w2 > maxsubwidth) maxsubwidth = w2; | |
1759 if (i + h2 > maxheight) maxheight = i + h2; | |
1760 } | |
1761 } | |
1762 *width = menu->width + maxsubwidth; | |
1763 *height = maxheight; | |
1764 } | |
1765 | |
1766 /* Display MENU at (X,Y) using FACES. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1767 |
9572 | 1768 static void |
1769 IT_menu_display (XMenu *menu, int y, int x, int *faces) | |
1770 { | |
1771 int i, j, face, width; | |
1772 GLYPH *text, *p; | |
1773 char *q; | |
1774 int mx, my; | |
1775 int enabled, mousehere; | |
1776 int row, col; | |
1777 | |
1778 width = menu->width; | |
1779 text = (GLYPH *) xmalloc ((width + 2) * sizeof (GLYPH)); | |
1780 ScreenGetCursor (&row, &col); | |
1781 mouse_get_xy (&mx, &my); | |
1782 mouse_off (); | |
1783 (*update_begin_hook) (); | |
1784 for (i = 0; i < menu->count; i++) | |
1785 { | |
1786 (*cursor_to_hook) (y + i, x); | |
1787 enabled | |
1788 = (!menu->submenu[i] && menu->panenumber[i]) || (menu->submenu[i]); | |
1789 mousehere = (y + i == my && x <= mx && mx < x + width + 2); | |
1790 face = faces[enabled + mousehere * 2]; | |
1791 p = text; | |
1792 *p++ = FAST_MAKE_GLYPH (' ', face); | |
1793 for (j = 0, q = menu->text[i]; *q; j++) | |
1794 *p++ = FAST_MAKE_GLYPH (*q++, face); | |
1795 for (; j < width; j++) | |
1796 *p++ = FAST_MAKE_GLYPH (' ', face); | |
1797 *p++ = FAST_MAKE_GLYPH (menu->submenu[i] ? 16 : ' ', face); | |
1798 (*write_glyphs_hook) (text, width + 2); | |
1799 } | |
1800 internal_flush (stdout); | |
1801 (*update_end_hook) (); | |
1802 mouse_on (); | |
1803 ScreenSetCursor (row, col); | |
1804 xfree (text); | |
1805 } | |
1806 | |
1807 /* Create a brand new menu structure. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1808 |
9572 | 1809 XMenu * |
10501
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
1810 XMenuCreate (Display *foo1, Window foo2, char *foo3) |
9572 | 1811 { |
1812 return IT_menu_create (); | |
1813 } | |
1814 | |
1815 /* Create a new pane and place it on the outer-most level. It is not | |
1816 clear that it should be placed out there, but I don't know what else | |
1817 to do. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1818 |
9572 | 1819 int |
10501
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
1820 XMenuAddPane (Display *foo, XMenu *menu, char *txt, int enable) |
9572 | 1821 { |
1822 int len; | |
1823 | |
1824 if (!enable) | |
1825 abort (); | |
1826 | |
1827 IT_menu_make_room (menu); | |
1828 menu->submenu[menu->count] = IT_menu_create (); | |
1829 menu->text[menu->count] = txt; | |
1830 menu->panenumber[menu->count] = ++menu->panecount; | |
1831 menu->count++; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1832 if ((len = strlen (txt)) > menu->width) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1833 menu->width = len; |
9572 | 1834 return menu->panecount; |
1835 } | |
1836 | |
1837 /* Create a new item in a menu pane. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1838 |
9572 | 1839 int |
10501
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
1840 XMenuAddSelection (Display *bar, XMenu *menu, int pane, |
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
1841 int foo, char *txt, int enable) |
9572 | 1842 { |
1843 int len; | |
1844 | |
1845 if (pane) | |
1846 if (!(menu = IT_menu_search_pane (menu, pane))) | |
1847 return XM_FAILURE; | |
1848 IT_menu_make_room (menu); | |
1849 menu->submenu[menu->count] = (XMenu *) 0; | |
1850 menu->text[menu->count] = txt; | |
1851 menu->panenumber[menu->count] = enable; | |
1852 menu->count++; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1853 if ((len = strlen (txt)) > menu->width) |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1854 menu->width = len; |
9572 | 1855 return XM_SUCCESS; |
1856 } | |
1857 | |
1858 /* Decide where the menu would be placed if requested at (X,Y). */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1859 |
10501
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
1860 void |
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
1861 XMenuLocate (Display *foo0, XMenu *menu, int foo1, int foo2, int x, int y, |
9572 | 1862 int *ulx, int *uly, int *width, int *height) |
1863 { | |
1864 if (menu->count == 1 && menu->submenu[0]) | |
1865 /* Special case: the menu consists of only one pane. */ | |
1866 IT_menu_calc_size (menu->submenu[0], width, height); | |
1867 else | |
1868 IT_menu_calc_size (menu, width, height); | |
1869 *ulx = x + 1; | |
1870 *uly = y; | |
1871 *width += 2; | |
1872 } | |
1873 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1874 struct IT_menu_state |
9572 | 1875 { |
1876 void *screen_behind; | |
1877 XMenu *menu; | |
1878 int pane; | |
1879 int x, y; | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1880 }; |
9572 | 1881 |
1882 | |
1883 /* Display menu, wait for user's response, and return that response. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1884 |
9572 | 1885 int |
10501
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
1886 XMenuActivate (Display *foo, XMenu *menu, int *pane, int *selidx, |
9572 | 1887 int x0, int y0, unsigned ButtonMask, char **txt) |
1888 { | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1889 struct IT_menu_state *state; |
9572 | 1890 int statecount; |
1891 int x, y, i, b; | |
1892 int screensize; | |
1893 int faces[4], selectface; | |
1894 int leave, result, onepane; | |
1895 | |
1896 /* Just in case we got here without a mouse present... */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1897 if (have_mouse <= 0) |
9572 | 1898 return XM_IA_SELECT; |
1899 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
1900 state = alloca (menu->panecount * sizeof (struct IT_menu_state)); |
9572 | 1901 screensize = ScreenRows () * ScreenCols () * 2; |
1902 faces[0] | |
1903 = compute_glyph_face (&the_only_frame, | |
1904 face_name_id_number | |
1905 (&the_only_frame, | |
1906 intern ("msdos-menu-passive-face")), | |
1907 0); | |
1908 faces[1] | |
1909 = compute_glyph_face (&the_only_frame, | |
1910 face_name_id_number | |
1911 (&the_only_frame, | |
1912 intern ("msdos-menu-active-face")), | |
1913 0); | |
1914 selectface | |
1915 = face_name_id_number (&the_only_frame, intern ("msdos-menu-select-face")); | |
1916 faces[2] = compute_glyph_face (&the_only_frame, selectface, faces[0]); | |
1917 faces[3] = compute_glyph_face (&the_only_frame, selectface, faces[1]); | |
1918 | |
1919 statecount = 1; | |
1920 state[0].menu = menu; | |
1921 mouse_off (); | |
1922 ScreenRetrieve (state[0].screen_behind = xmalloc (screensize)); | |
1923 mouse_on (); | |
1924 if ((onepane = menu->count == 1 && menu->submenu[0])) | |
1925 { | |
1926 menu->width = menu->submenu[0]->width; | |
1927 state[0].menu = menu->submenu[0]; | |
1928 } | |
1929 else | |
1930 { | |
1931 state[0].menu = menu; | |
1932 } | |
1933 state[0].x = x0 - 1; | |
1934 state[0].y = y0; | |
1935 state[0].pane = onepane; | |
1936 | |
1937 mouse_last_x = -1; /* A hack that forces display. */ | |
1938 leave = 0; | |
1939 while (!leave) | |
1940 { | |
1941 mouse_check_moved (); | |
12573
f8193b0f95ed
(mouse_get_pos, mouse_check_moved, XMenuActivate):
Karl Heuer <kwzh@gnu.org>
parents:
11124
diff
changeset
|
1942 if (selected_frame->mouse_moved) |
9572 | 1943 { |
12573
f8193b0f95ed
(mouse_get_pos, mouse_check_moved, XMenuActivate):
Karl Heuer <kwzh@gnu.org>
parents:
11124
diff
changeset
|
1944 selected_frame->mouse_moved = 0; |
9572 | 1945 result = XM_IA_SELECT; |
1946 mouse_get_xy (&x, &y); | |
1947 for (i = 0; i < statecount; i++) | |
1948 if (state[i].x <= x && x < state[i].x + state[i].menu->width + 2) | |
1949 { | |
1950 int dy = y - state[i].y; | |
1951 if (0 <= dy && dy < state[i].menu->count) | |
1952 { | |
1953 if (!state[i].menu->submenu[dy]) | |
1954 if (state[i].menu->panenumber[dy]) | |
1955 result = XM_SUCCESS; | |
1956 else | |
1957 result = XM_IA_SELECT; | |
1958 *pane = state[i].pane - 1; | |
1959 *selidx = dy; | |
1960 /* We hit some part of a menu, so drop extra menues that | |
1961 have been opened. That does not include an open and | |
1962 active submenu. */ | |
1963 if (i != statecount - 2 | |
1964 || state[i].menu->submenu[dy] != state[i+1].menu) | |
1965 while (i != statecount - 1) | |
1966 { | |
1967 statecount--; | |
1968 mouse_off (); | |
1969 ScreenUpdate (state[statecount].screen_behind); | |
1970 mouse_on (); | |
1971 xfree (state[statecount].screen_behind); | |
1972 } | |
1973 if (i == statecount - 1 && state[i].menu->submenu[dy]) | |
1974 { | |
1975 IT_menu_display (state[i].menu, | |
1976 state[i].y, | |
1977 state[i].x, | |
1978 faces); | |
1979 state[statecount].menu = state[i].menu->submenu[dy]; | |
1980 state[statecount].pane = state[i].menu->panenumber[dy]; | |
1981 mouse_off (); | |
1982 ScreenRetrieve (state[statecount].screen_behind | |
1983 = xmalloc (screensize)); | |
1984 mouse_on (); | |
1985 state[statecount].x | |
1986 = state[i].x + state[i].menu->width + 2; | |
1987 state[statecount].y = y; | |
1988 statecount++; | |
1989 } | |
1990 } | |
1991 } | |
1992 IT_menu_display (state[statecount - 1].menu, | |
1993 state[statecount - 1].y, | |
1994 state[statecount - 1].x, | |
1995 faces); | |
1996 } | |
1997 for (b = 0; b < mouse_button_count; b++) | |
1998 { | |
1999 (void) mouse_pressed (b, &x, &y); | |
2000 if (mouse_released (b, &x, &y)) | |
2001 leave = 1; | |
2002 } | |
2003 } | |
2004 | |
2005 mouse_off (); | |
2006 ScreenUpdate (state[0].screen_behind); | |
2007 mouse_on (); | |
2008 while (statecount--) | |
2009 xfree (state[statecount].screen_behind); | |
2010 return result; | |
2011 } | |
2012 | |
2013 /* Dispose of a menu. */ | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
2014 |
10501
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
2015 void |
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
2016 XMenuDestroy (Display *foo, XMenu *menu) |
9572 | 2017 { |
2018 int i; | |
2019 if (menu->allocated) | |
2020 { | |
2021 for (i = 0; i < menu->count; i++) | |
2022 if (menu->submenu[i]) | |
10501
19c4a9ef23e5
(XMenuCreate, XMenuAddPane, XMenuAddSelection, XMenuLocate,
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
2023 XMenuDestroy (foo, menu->submenu[i]); |
9572 | 2024 xfree (menu->text); |
2025 xfree (menu->submenu); | |
2026 xfree (menu->panenumber); | |
2027 } | |
2028 xfree (menu); | |
2029 } | |
2030 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
2031 int |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
2032 x_pixel_width (struct frame *f) |
9572 | 2033 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
2034 return FRAME_WIDTH (f); |
9572 | 2035 } |
2036 | |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
2037 int |
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
2038 x_pixel_height (struct frame *f) |
9572 | 2039 { |
12995
a3620c5ffad7
(putchar): Call internal_flush instead of _flsbuf.
Richard M. Stallman <rms@gnu.org>
parents:
12614
diff
changeset
|
2040 return FRAME_HEIGHT (f); |
9572 | 2041 } |
2042 #endif /* !HAVE_X_WINDOWS */ | |
7273
24426d7e14eb
Finish downcasing mouse_init1, mouse_off,
Richard M. Stallman <rms@gnu.org>
parents:
6505
diff
changeset
|
2043 |
5503 | 2044 #endif /* MSDOS */ |