Mercurial > emacs
annotate src/dosfns.c @ 79759:fc2bcd2a8aad
Add 2008 to copyright years.
| author | Glenn Morris <rgm@gnu.org> |
|---|---|
| date | Tue, 08 Jan 2008 04:30:25 +0000 |
| parents | 922696f363b0 |
| children | 606f2d163a64 |
| rev | line source |
|---|---|
| 5503 | 1 /* MS-DOS specific Lisp utilities. Coded by Manabu Higashida, 1991. |
| 2 Major changes May-July 1993 Morten Welinder (only 10% original code left) | |
|
64770
a0d1312ede66
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
64084
diff
changeset
|
3 Copyright (C) 1991, 1993, 1996, 1997, 1998, 2001, 2002, 2003, 2004, |
| 79759 | 4 2005, 2006, 2007, 2008 Free Software Foundation, Inc. |
| 5503 | 5 |
| 6 This file is part of GNU Emacs. | |
| 7 | |
| 8 GNU Emacs is free software; you can redistribute it and/or modify | |
| 9 it under the terms of the GNU General Public License as published by | |
|
78260
922696f363b0
Switch license to GPLv3 or later.
Glenn Morris <rgm@gnu.org>
parents:
75348
diff
changeset
|
10 the Free Software Foundation; either version 3, or (at your option) |
| 5503 | 11 any later version. |
| 12 | |
| 13 GNU Emacs is distributed in the hope that it will be useful, | |
| 14 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 16 GNU General Public License for more details. | |
| 17 | |
| 18 You should have received a copy of the GNU General Public License | |
| 19 along with GNU Emacs; see the file COPYING. If not, write to | |
| 64084 | 20 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| 21 Boston, MA 02110-1301, USA. */ | |
| 5503 | 22 |
| 5980 | 23 #include <config.h> |
| 5503 | 24 |
| 25 #ifdef MSDOS | |
| 26 /* The entire file is within this conditional */ | |
| 27 | |
| 28 #include <stdio.h> | |
|
25113
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
29 #include <string.h> |
| 5503 | 30 #include <dos.h> |
| 31 #include "lisp.h" | |
| 32 #include "buffer.h" | |
| 33 #include "termchar.h" | |
| 34 #include "termhooks.h" | |
| 35 #include "frame.h" | |
| 20034 | 36 #include "blockinput.h" |
| 37 #include "window.h" | |
| 5503 | 38 #include "dosfns.h" |
| 39 #include "msdos.h" | |
|
25113
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
40 #include "dispextern.h" |
|
34348
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
41 #include "charset.h" |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
42 #include "coding.h" |
| 20034 | 43 #include <dpmi.h> |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
44 #include <go32.h> |
|
15226
31a30cc1d61a
(init_dosfns) [DJGPP >= 2]: Make `opendir' preserve
Richard M. Stallman <rms@gnu.org>
parents:
15173
diff
changeset
|
45 #include <dirent.h> |
|
34348
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
46 #include <sys/vfs.h> |
| 5503 | 47 |
| 20034 | 48 #ifndef __DJGPP_MINOR__ |
| 49 # define __tb _go32_info_block.linear_address_of_transfer_buffer; | |
| 50 #endif | |
| 51 | |
| 5503 | 52 DEFUN ("int86", Fint86, Sint86, 2, 2, 0, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
53 doc: /* Call specific MSDOS interrupt number INTERRUPT with REGISTERS. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
54 Return the updated REGISTER vector. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
55 |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
56 INTERRUPT should be an integer in the range 0 to 255. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
57 REGISTERS should be a vector produced by `make-register' and |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
58 `set-register-value'. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
59 (interrupt, registers) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
60 Lisp_Object interrupt, registers; |
| 5503 | 61 { |
| 62 register int i; | |
| 63 int no; | |
| 64 union REGS inregs, outregs; | |
| 65 Lisp_Object val; | |
| 66 | |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
67 CHECK_NUMBER (interrupt); |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
68 no = (unsigned long) XINT (interrupt); |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
69 CHECK_VECTOR (registers); |
| 45331 | 70 if (no < 0 || no > 0xff || XVECTOR (registers)-> size != 8) |
| 5503 | 71 return Qnil; |
| 72 for (i = 0; i < 8; i++) | |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
73 CHECK_NUMBER (XVECTOR (registers)->contents[i]); |
| 5503 | 74 |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
75 inregs.x.ax = (unsigned long) XFASTINT (XVECTOR (registers)->contents[0]); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
76 inregs.x.bx = (unsigned long) XFASTINT (XVECTOR (registers)->contents[1]); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
77 inregs.x.cx = (unsigned long) XFASTINT (XVECTOR (registers)->contents[2]); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
78 inregs.x.dx = (unsigned long) XFASTINT (XVECTOR (registers)->contents[3]); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
79 inregs.x.si = (unsigned long) XFASTINT (XVECTOR (registers)->contents[4]); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
80 inregs.x.di = (unsigned long) XFASTINT (XVECTOR (registers)->contents[5]); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
81 inregs.x.cflag = (unsigned long) XFASTINT (XVECTOR (registers)->contents[6]); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
82 inregs.x.flags = (unsigned long) XFASTINT (XVECTOR (registers)->contents[7]); |
| 5503 | 83 |
| 84 int86 (no, &inregs, &outregs); | |
| 85 | |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
86 XVECTOR (registers)->contents[0] = make_number (outregs.x.ax); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
87 XVECTOR (registers)->contents[1] = make_number (outregs.x.bx); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
88 XVECTOR (registers)->contents[2] = make_number (outregs.x.cx); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
89 XVECTOR (registers)->contents[3] = make_number (outregs.x.dx); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
90 XVECTOR (registers)->contents[4] = make_number (outregs.x.si); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
91 XVECTOR (registers)->contents[5] = make_number (outregs.x.di); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
92 XVECTOR (registers)->contents[6] = make_number (outregs.x.cflag); |
|
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
93 XVECTOR (registers)->contents[7] = make_number (outregs.x.flags); |
| 5503 | 94 |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
95 return registers; |
| 5503 | 96 } |
| 97 | |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
98 DEFUN ("msdos-memget", Fdos_memget, Sdos_memget, 2, 2, 0, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
99 doc: /* Read DOS memory at offset ADDRESS into VECTOR. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
100 Return the updated VECTOR. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
101 (address, vector) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
102 Lisp_Object address, vector; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
103 { |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
104 register int i; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
105 int offs, len; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
106 char *buf; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
107 Lisp_Object val; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
108 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
109 CHECK_NUMBER (address); |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
110 offs = (unsigned long) XINT (address); |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
111 CHECK_VECTOR (vector); |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
112 len = XVECTOR (vector)-> size; |
|
58012
934f6fb6fd8a
* dosfns.c (Fdos_memget, Fdos_memput): Use integer variable offs in
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
52401
diff
changeset
|
113 if (len < 1 || len > 2048 || offs < 0 || offs > 0xfffff - len) |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
114 return Qnil; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
115 buf = alloca (len); |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
116 dosmemget (offs, len, buf); |
| 45331 | 117 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
118 for (i = 0; i < len; i++) |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
119 XVECTOR (vector)->contents[i] = make_number (buf[i]); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
120 |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
121 return vector; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
122 } |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
123 |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
124 DEFUN ("msdos-memput", Fdos_memput, Sdos_memput, 2, 2, 0, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
125 doc: /* Write DOS memory at offset ADDRESS from VECTOR. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
126 (address, vector) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
127 Lisp_Object address, vector; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
128 { |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
129 register int i; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
130 int offs, len; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
131 char *buf; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
132 Lisp_Object val; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
133 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
134 CHECK_NUMBER (address); |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
135 offs = (unsigned long) XINT (address); |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
136 CHECK_VECTOR (vector); |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
137 len = XVECTOR (vector)-> size; |
|
58012
934f6fb6fd8a
* dosfns.c (Fdos_memget, Fdos_memput): Use integer variable offs in
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
52401
diff
changeset
|
138 if (len < 1 || len > 2048 || offs < 0 || offs > 0xfffff - len) |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
139 return Qnil; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
140 buf = alloca (len); |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
141 |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
142 for (i = 0; i < len; i++) |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
143 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
144 CHECK_NUMBER (XVECTOR (vector)->contents[i]); |
|
14070
c74bb6ea72ab
(Fint86, Fdos_memget, Fdos_memput, Fmsdos_set_keyboard): Harmonize
Erik Naggum <erik@naggum.no>
parents:
13745
diff
changeset
|
145 buf[i] = (unsigned char) XFASTINT (XVECTOR (vector)->contents[i]) & 0xFF; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
146 } |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
147 |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
148 dosmemput (buf, len, offs); |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
149 return Qt; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
150 } |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
151 |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
152 DEFUN ("msdos-set-keyboard", Fmsdos_set_keyboard, Smsdos_set_keyboard, 1, 2, 0, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
153 doc: /* Set keyboard layout according to COUNTRY-CODE. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
154 If the optional argument ALLKEYS is non-nil, the keyboard is mapped for |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
155 all keys; otherwise it is only used when the ALT key is pressed. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
156 The current keyboard layout is available in dos-keyboard-code. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
157 (country_code, allkeys) |
|
58012
934f6fb6fd8a
* dosfns.c (Fdos_memget, Fdos_memput): Use integer variable offs in
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
52401
diff
changeset
|
158 Lisp_Object country_code, allkeys; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
159 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
160 CHECK_NUMBER (country_code); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
161 if (!dos_set_keyboard (XINT (country_code), !NILP (allkeys))) |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
162 return Qnil; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
163 return Qt; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
164 } |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
165 |
| 9572 | 166 #ifndef HAVE_X_WINDOWS |
| 167 /* Later we might want to control the mouse interface with this function, | |
| 168 e.g., with respect to non-80 column screen modes. */ | |
| 169 | |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
170 DEFUN ("msdos-mouse-p", Fmsdos_mouse_p, Smsdos_mouse_p, 0, 0, 0, |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
171 doc: /* Report whether a mouse is present. */) |
| 9572 | 172 () |
| 173 { | |
| 174 if (have_mouse) | |
| 175 return Qt; | |
| 176 else | |
| 177 return Qnil; | |
| 178 } | |
| 179 #endif | |
| 180 | |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
181 DEFUN ("msdos-mouse-init", Fmsdos_mouse_init, Smsdos_mouse_init, 0, 0, "", |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
182 doc: /* Initialize and enable mouse if available. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
183 () |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
184 { |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
185 if (have_mouse) |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
186 { |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
187 have_mouse = 1; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
188 mouse_init (); |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
189 return Qt; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
190 } |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
191 return Qnil; |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
192 } |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
193 |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
194 DEFUN ("msdos-mouse-enable", Fmsdos_mouse_enable, Smsdos_mouse_enable, 0, 0, "", |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
195 doc: /* Enable mouse if available. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
196 () |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
197 { |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
198 if (have_mouse) |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
199 { |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
200 have_mouse = 1; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
201 mouse_on (); |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
202 } |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
203 return have_mouse ? Qt : Qnil; |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
204 } |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
205 |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
206 DEFUN ("msdos-mouse-disable", Fmsdos_mouse_disable, Smsdos_mouse_disable, 0, 0, "", |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
207 doc: /* Disable mouse if available. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
208 () |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
209 { |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
210 mouse_off (); |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
211 if (have_mouse) have_mouse = -1; |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
212 return Qnil; |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
213 } |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
214 |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
215 DEFUN ("insert-startup-screen", Finsert_startup_screen, Sinsert_startup_screen, 0, 0, "", |
|
73685
f25200449e7b
(Finsert_startup_screen): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
68651
diff
changeset
|
216 doc: /* Insert copy of screen contents prior to starting Emacs. |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
217 Return nil if startup screen is not available. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
218 () |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
219 { |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
220 char *s; |
| 45331 | 221 int rows, cols, i, j; |
| 222 | |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
223 if (!dos_get_saved_screen (&s, &rows, &cols)) |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
224 return Qnil; |
| 45331 | 225 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
226 for (i = 0; i < rows; i++) |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
227 { |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
228 for (j = 0; j < cols; j++) |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
229 { |
|
19288
bdc4b7818976
(Finsert_startup_screen): Call `insert_char' with a single argument.
Richard M. Stallman <rms@gnu.org>
parents:
16335
diff
changeset
|
230 insert_char (*s); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
231 s += 2; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
232 } |
|
19288
bdc4b7818976
(Finsert_startup_screen): Call `insert_char' with a single argument.
Richard M. Stallman <rms@gnu.org>
parents:
16335
diff
changeset
|
233 insert_char ('\n'); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
234 } |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
235 |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
236 return Qt; |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
237 } |
| 9572 | 238 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
239 /* country info */ |
|
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
240 EMACS_INT dos_country_code; |
|
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
241 EMACS_INT dos_codepage; |
|
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
242 EMACS_INT dos_timezone_offset; |
|
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
243 EMACS_INT dos_decimal_point; |
|
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
244 EMACS_INT dos_keyboard_layout; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
245 unsigned char dos_country_info[DOS_COUNTRY_INFO]; |
|
19294
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
246 static unsigned char usa_country_info[DOS_COUNTRY_INFO] = { |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
247 0, 0, /* date format */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
248 '$', 0, 0, 0, 0, /* currency string */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
249 ',', 0, /* thousands separator */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
250 '.', 0, /* decimal separator */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
251 '/', 0, /* date separator */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
252 ':', 0, /* time separator */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
253 0, /* currency format */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
254 2, /* digits after decimal in currency */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
255 0, /* time format */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
256 0, 0, 0, 0, /* address of case map routine, GPF if used */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
257 ' ', 0, /* data-list separator (?) */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
258 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 /* reserved */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
259 }; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
260 |
|
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
261 EMACS_INT dos_hyper_key; |
|
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
262 EMACS_INT dos_super_key; |
|
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41914
diff
changeset
|
263 EMACS_INT dos_keypad_mode; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
264 |
| 5503 | 265 Lisp_Object Vdos_version; |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
266 Lisp_Object Vdos_display_scancodes; |
| 20034 | 267 |
| 268 #ifndef HAVE_X_WINDOWS | |
| 269 static unsigned dos_windows_version; | |
| 270 Lisp_Object Vdos_windows_version; | |
| 271 | |
| 272 char parent_vm_title[50]; /* Ralf Brown says 30 is enough */ | |
| 273 int w95_set_virtual_machine_title (const char *); | |
| 274 | |
| 275 void | |
| 276 restore_parent_vm_title (void) | |
| 277 { | |
| 278 if (NILP (Vdos_windows_version)) | |
| 279 return; | |
| 280 if ((dos_windows_version & 0xff) >= 4 && parent_vm_title[0]) | |
| 281 w95_set_virtual_machine_title (parent_vm_title); | |
| 282 delay (50); | |
| 283 } | |
| 284 #endif /* !HAVE_X_WINDOWS */ | |
| 45331 | 285 |
| 5503 | 286 void |
| 287 init_dosfns () | |
| 288 { | |
| 289 union REGS regs; | |
| 290 _go32_dpmi_registers dpmiregs; | |
|
19294
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
291 unsigned long xbuf = _go32_info_block.linear_address_of_transfer_buffer; |
| 5503 | 292 |
| 9572 | 293 #ifndef SYSTEM_MALLOC |
| 5503 | 294 get_lim_data (); /* why the hell isn't this called elsewhere? */ |
| 9572 | 295 #endif |
| 5503 | 296 |
| 297 regs.x.ax = 0x3000; | |
| 298 intdos (®s, ®s); | |
| 299 Vdos_version = Fcons (make_number (regs.h.al), make_number (regs.h.ah)); | |
| 300 | |
|
19294
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
301 /* Obtain the country code via DPMI, use DJGPP transfer buffer. */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
302 dpmiregs.x.ax = 0x3800; |
|
21430
b6b154ad6e22
(init_dosfns): Fix bug in passing segment address of the transfer buffer.
Eli Zaretskii <eliz@gnu.org>
parents:
20034
diff
changeset
|
303 dpmiregs.x.ds = xbuf >> 4; |
|
19294
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
304 dpmiregs.x.dx = 0; |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
305 dpmiregs.x.ss = dpmiregs.x.sp = dpmiregs.x.flags = 0; |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
306 _go32_dpmi_simulate_int (0x21, &dpmiregs); |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
307 if (dpmiregs.x.flags & 1) |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
308 { |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
309 dos_country_code = 1; /* assume USA if 213800 failed */ |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
310 memcpy (dos_country_info, usa_country_info, DOS_COUNTRY_INFO); |
|
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
311 } |
| 5503 | 312 else |
| 313 { | |
| 314 dos_country_code = dpmiregs.x.bx; | |
|
19294
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
315 dosmemget (xbuf, DOS_COUNTRY_INFO, dos_country_info); |
| 5503 | 316 } |
|
19294
1f8ca0c4836f
(init_dosfns): Avoid calling DOS memory-allocation
Richard M. Stallman <rms@gnu.org>
parents:
19288
diff
changeset
|
317 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
318 dos_set_keyboard (dos_country_code, 0); |
| 5503 | 319 |
| 320 regs.x.ax = 0x6601; | |
| 321 intdos (®s, ®s); | |
| 322 if (regs.x.cflag) | |
| 323 /* Estimate code page from country code */ | |
| 45331 | 324 switch (dos_country_code) |
| 5503 | 325 { |
| 326 case 45: /* Denmark */ | |
| 327 case 47: /* Norway */ | |
| 328 dos_codepage = 865; | |
| 329 break; | |
| 330 default: | |
| 331 /* US */ | |
| 332 dos_codepage = 437; | |
| 333 } | |
| 334 else | |
| 335 dos_codepage = regs.x.bx & 0xffff; | |
|
15226
31a30cc1d61a
(init_dosfns) [DJGPP >= 2]: Make `opendir' preserve
Richard M. Stallman <rms@gnu.org>
parents:
15173
diff
changeset
|
336 |
| 20034 | 337 #ifndef HAVE_X_WINDOWS |
| 338 parent_vm_title[0] = '\0'; | |
| 339 | |
| 340 /* If we are running from DOS box on MS-Windows, get Windows version. */ | |
| 341 dpmiregs.x.ax = 0x1600; /* enhanced mode installation check */ | |
| 342 dpmiregs.x.ss = dpmiregs.x.sp = dpmiregs.x.flags = 0; | |
| 343 _go32_dpmi_simulate_int (0x2f, &dpmiregs); | |
| 344 /* We only support Windows-specific features when we run on Windows 9X | |
| 345 or on Windows 3.X/enhanced mode. | |
| 346 | |
| 347 Int 2Fh/AX=1600h returns: | |
| 348 | |
| 349 AL = 00: no Windows at all; | |
| 350 AL = 01: Windows/386 2.x; | |
| 351 AL = 80h: Windows 3.x in mode other than enhanced; | |
| 352 AL = FFh: Windows/386 2.x | |
| 353 | |
| 354 We also check AH > 0 (Windows 3.1 or later), in case AL tricks us. */ | |
| 355 if (dpmiregs.h.al > 2 && dpmiregs.h.al != 0x80 && dpmiregs.h.al != 0xff | |
| 356 && (dpmiregs.h.al > 3 || dpmiregs.h.ah > 0)) | |
| 357 { | |
| 358 dos_windows_version = dpmiregs.x.ax; | |
| 359 Vdos_windows_version = | |
| 360 Fcons (make_number (dpmiregs.h.al), make_number (dpmiregs.h.ah)); | |
| 361 | |
| 362 /* Save the current title of this virtual machine, so we can restore | |
| 363 it before exiting. Otherwise, Windows 95 will continue to use | |
| 364 the title we set even after we are history, stupido... */ | |
| 365 if (dpmiregs.h.al >= 4) | |
| 366 { | |
| 367 dpmiregs.x.ax = 0x168e; | |
| 368 dpmiregs.x.dx = 3; /* get VM title */ | |
| 369 dpmiregs.x.cx = sizeof(parent_vm_title) - 1; | |
| 370 dpmiregs.x.es = __tb >> 4; | |
| 371 dpmiregs.x.di = __tb & 15; | |
| 372 dpmiregs.x.sp = dpmiregs.x.ss = dpmiregs.x.flags = 0; | |
| 373 _go32_dpmi_simulate_int (0x2f, &dpmiregs); | |
| 374 if (dpmiregs.x.ax == 1) | |
| 375 dosmemget (__tb, sizeof(parent_vm_title), parent_vm_title); | |
| 376 } | |
| 377 } | |
| 378 else | |
| 379 { | |
| 380 dos_windows_version = 0; | |
| 381 Vdos_windows_version = Qnil; | |
| 382 } | |
| 383 #endif /* !HAVE_X_WINDOWS */ | |
| 384 | |
|
15226
31a30cc1d61a
(init_dosfns) [DJGPP >= 2]: Make `opendir' preserve
Richard M. Stallman <rms@gnu.org>
parents:
15173
diff
changeset
|
385 #if __DJGPP__ >= 2 |
|
31a30cc1d61a
(init_dosfns) [DJGPP >= 2]: Make `opendir' preserve
Richard M. Stallman <rms@gnu.org>
parents:
15173
diff
changeset
|
386 |
|
16335
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
387 /* Without this, we never see hidden files. |
|
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
388 Don't OR it with the previous value, so the value recorded at dump |
|
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
389 time, possibly with `preserve-case' flags set, won't get through. */ |
|
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
390 __opendir_flags = __OPENDIR_FIND_HIDDEN; |
|
15226
31a30cc1d61a
(init_dosfns) [DJGPP >= 2]: Make `opendir' preserve
Richard M. Stallman <rms@gnu.org>
parents:
15173
diff
changeset
|
391 |
|
16335
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
392 #if __DJGPP_MINOR__ == 0 |
|
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
393 /* Under LFN, preserve the case of files as recorded in the directory |
|
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
394 (in DJGPP 2.01 and later this is automagically done by the library). */ |
|
15226
31a30cc1d61a
(init_dosfns) [DJGPP >= 2]: Make `opendir' preserve
Richard M. Stallman <rms@gnu.org>
parents:
15173
diff
changeset
|
395 if (!NILP (Fmsdos_long_file_names ())) |
|
31a30cc1d61a
(init_dosfns) [DJGPP >= 2]: Make `opendir' preserve
Richard M. Stallman <rms@gnu.org>
parents:
15173
diff
changeset
|
396 __opendir_flags |= __OPENDIR_PRESERVE_CASE; |
|
16335
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
397 #endif /* __DJGPP_MINOR__ == 0 */ |
|
6cf0a8b5c895
(init_dosfns): When setting `__opendir_flags' value,
Richard M. Stallman <rms@gnu.org>
parents:
15393
diff
changeset
|
398 #endif /* __DJGPP__ >= 2 */ |
| 5503 | 399 } |
| 400 | |
| 20034 | 401 #ifndef HAVE_X_WINDOWS |
|
25113
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
402 |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
403 /* Emulation of some X window features from xfns.c and xfaces.c. */ |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
404 |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
405 /* Standard VGA colors, in the order of their standard numbering |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
406 in the default VGA palette. */ |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
407 static char *vga_colors[16] = { |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
408 "black", "blue", "green", "cyan", "red", "magenta", "brown", |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
409 "lightgray", "darkgray", "lightblue", "lightgreen", "lightcyan", |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
410 "lightred", "lightmagenta", "yellow", "white" |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
411 }; |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
412 |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
413 /* Given a color name, return its index, or -1 if not found. Note |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
414 that this only performs case-insensitive comparison against the |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
415 standard names. For anything more sophisticated, like matching |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
416 "gray" with "grey" or translating X color names into their MSDOS |
|
26729
f5dded41adcc
Changes for automatic remapping of X colors on terminal frames:
Eli Zaretskii <eliz@gnu.org>
parents:
25212
diff
changeset
|
417 equivalents, call the Lisp function Qtty_color_desc (defined |
|
f5dded41adcc
Changes for automatic remapping of X colors on terminal frames:
Eli Zaretskii <eliz@gnu.org>
parents:
25212
diff
changeset
|
418 on lisp/term/tty-colors.el). */ |
|
25113
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
419 int |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
420 msdos_stdcolor_idx (const char *name) |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
421 { |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
422 int i; |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
423 |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
424 for (i = 0; i < sizeof (vga_colors) / sizeof (vga_colors[0]); i++) |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
425 if (strcasecmp (name, vga_colors[i]) == 0) |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
426 return i; |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
427 |
|
26902
264b83a3a688
Changes for separate unspecified foreground and background colors
Eli Zaretskii <eliz@gnu.org>
parents:
26729
diff
changeset
|
428 return |
|
27115
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
429 strcmp (name, unspecified_fg) == 0 ? FACE_TTY_DEFAULT_FG_COLOR |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
430 : strcmp (name, unspecified_bg) == 0 ? FACE_TTY_DEFAULT_BG_COLOR |
|
26902
264b83a3a688
Changes for separate unspecified foreground and background colors
Eli Zaretskii <eliz@gnu.org>
parents:
26729
diff
changeset
|
431 : FACE_TTY_DEFAULT_COLOR; |
|
25113
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
432 } |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
433 |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
434 /* Given a color index, return its standard name. */ |
|
26729
f5dded41adcc
Changes for automatic remapping of X colors on terminal frames:
Eli Zaretskii <eliz@gnu.org>
parents:
25212
diff
changeset
|
435 Lisp_Object |
|
25113
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
436 msdos_stdcolor_name (int idx) |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
437 { |
|
27115
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
438 extern Lisp_Object Qunspecified; |
|
26729
f5dded41adcc
Changes for automatic remapping of X colors on terminal frames:
Eli Zaretskii <eliz@gnu.org>
parents:
25212
diff
changeset
|
439 |
|
27115
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
440 if (idx == FACE_TTY_DEFAULT_FG_COLOR) |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
441 return build_string (unspecified_fg); |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
442 else if (idx == FACE_TTY_DEFAULT_BG_COLOR) |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
443 return build_string (unspecified_bg); |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
444 else if (idx >= 0 && idx < sizeof (vga_colors) / sizeof (vga_colors[0])) |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
445 return build_string (vga_colors[idx]); |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
446 else |
|
13a2c64e6ade
(unspecified_colors): Remove.
Eli Zaretskii <eliz@gnu.org>
parents:
26902
diff
changeset
|
447 return Qunspecified; /* meaning the default */ |
|
25113
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
448 } |
|
73c54061f4bb
(msdos_stdcolor_name, msdos_stdcolor_idx): New
Eli Zaretskii <eliz@gnu.org>
parents:
23814
diff
changeset
|
449 |
| 20034 | 450 /* Support for features that are available when we run in a DOS box |
| 451 on MS-Windows. */ | |
| 452 int | |
| 453 ms_windows_version (void) | |
| 454 { | |
| 455 return dos_windows_version; | |
| 456 } | |
| 457 | |
| 458 /* Set the title of the current virtual machine, to appear on | |
| 459 the caption bar of that machine's window. */ | |
| 460 | |
| 461 int | |
| 462 w95_set_virtual_machine_title (const char *title_string) | |
| 463 { | |
| 464 /* Only Windows 9X (version 4 and higher) support this function. */ | |
| 465 if (!NILP (Vdos_windows_version) | |
| 466 && (dos_windows_version & 0xff) >= 4) | |
| 467 { | |
| 468 _go32_dpmi_registers regs; | |
| 469 dosmemput (title_string, strlen (title_string) + 1, __tb); | |
| 470 regs.x.ax = 0x168e; | |
| 471 regs.x.dx = 1; | |
| 472 regs.x.es = __tb >> 4; | |
| 473 regs.x.di = __tb & 15; | |
| 474 regs.x.sp = regs.x.ss = regs.x.flags = 0; | |
| 475 _go32_dpmi_simulate_int (0x2f, ®s); | |
| 476 return regs.x.ax == 1; | |
| 477 } | |
| 478 return 0; | |
| 479 } | |
| 480 | |
| 481 /* Change the title of frame F to NAME. | |
| 482 If NAME is nil, use the frame name as the title. | |
| 483 | |
| 484 If Emacs is not run from a DOS box on Windows 9X, this only | |
| 485 sets the name in the frame struct, but has no other effects. */ | |
| 486 | |
| 487 void | |
| 488 x_set_title (f, name) | |
| 489 struct frame *f; | |
| 490 Lisp_Object name; | |
| 491 { | |
| 492 /* Don't change the title if it's already NAME. */ | |
| 493 if (EQ (name, f->title)) | |
| 494 return; | |
| 495 | |
| 496 update_mode_lines = 1; | |
| 497 | |
| 498 f->title = name; | |
| 499 | |
| 500 if (NILP (name)) | |
| 501 name = f->name; | |
| 502 | |
| 503 if (FRAME_MSDOS_P (f)) | |
| 504 { | |
| 505 BLOCK_INPUT; | |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
45331
diff
changeset
|
506 w95_set_virtual_machine_title (SDATA (name)); |
| 20034 | 507 UNBLOCK_INPUT; |
| 508 } | |
| 509 } | |
| 510 #endif /* !HAVE_X_WINDOWS */ | |
| 511 | |
|
34348
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
512 DEFUN ("file-system-info", Ffile_system_info, Sfile_system_info, 1, 1, 0, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
513 doc: /* Return storage information about the file system FILENAME is on. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
514 Value is a list of floats (TOTAL FREE AVAIL), where TOTAL is the total |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
515 storage of the file system, FREE is the free storage, and AVAIL is the |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
516 storage available to a non-superuser. All 3 numbers are in bytes. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
517 If the underlying system call fails, value is nil. */) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
518 (filename) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
519 Lisp_Object filename; |
|
34348
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
520 { |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
521 struct statfs stfs; |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
522 Lisp_Object encoded, value; |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
523 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
38319
diff
changeset
|
524 CHECK_STRING (filename); |
|
34348
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
525 filename = Fexpand_file_name (filename, Qnil); |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
526 encoded = ENCODE_FILE (filename); |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
527 |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
45331
diff
changeset
|
528 if (statfs (SDATA (encoded), &stfs)) |
|
34348
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
529 value = Qnil; |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
530 else |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
531 value = list3 (make_float ((double) stfs.f_bsize * stfs.f_blocks), |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
532 make_float ((double) stfs.f_bsize * stfs.f_bfree), |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
533 make_float ((double) stfs.f_bsize * stfs.f_bavail)); |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
534 |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
535 return value; |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
536 } |
|
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
537 |
| 20034 | 538 void |
| 539 dos_cleanup (void) | |
| 540 { | |
| 541 #ifndef HAVE_X_WINDOWS | |
| 542 restore_parent_vm_title (); | |
| 543 #endif | |
|
23814
3229c65a13c5
(dos_cleanup): Flush and fsync the termscript stream.
Eli Zaretskii <eliz@gnu.org>
parents:
21430
diff
changeset
|
544 /* Make sure the termscript file is committed, in case we are |
|
3229c65a13c5
(dos_cleanup): Flush and fsync the termscript stream.
Eli Zaretskii <eliz@gnu.org>
parents:
21430
diff
changeset
|
545 crashing and some vital info was written there. */ |
|
3229c65a13c5
(dos_cleanup): Flush and fsync the termscript stream.
Eli Zaretskii <eliz@gnu.org>
parents:
21430
diff
changeset
|
546 if (termscript) |
|
3229c65a13c5
(dos_cleanup): Flush and fsync the termscript stream.
Eli Zaretskii <eliz@gnu.org>
parents:
21430
diff
changeset
|
547 { |
|
3229c65a13c5
(dos_cleanup): Flush and fsync the termscript stream.
Eli Zaretskii <eliz@gnu.org>
parents:
21430
diff
changeset
|
548 fflush (termscript); |
|
3229c65a13c5
(dos_cleanup): Flush and fsync the termscript stream.
Eli Zaretskii <eliz@gnu.org>
parents:
21430
diff
changeset
|
549 fsync (fileno (termscript)); |
|
3229c65a13c5
(dos_cleanup): Flush and fsync the termscript stream.
Eli Zaretskii <eliz@gnu.org>
parents:
21430
diff
changeset
|
550 } |
| 20034 | 551 } |
| 552 | |
| 5503 | 553 /* |
| 554 * Define everything | |
| 555 */ | |
| 556 syms_of_dosfns () | |
| 557 { | |
| 558 defsubr (&Sint86); | |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
559 defsubr (&Sdos_memget); |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
560 defsubr (&Sdos_memput); |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
561 defsubr (&Smsdos_mouse_init); |
|
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
562 defsubr (&Smsdos_mouse_enable); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
563 defsubr (&Smsdos_set_keyboard); |
|
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
564 defsubr (&Sinsert_startup_screen); |
|
12990
93cc41315528
(Fmsdos_mouse_enable, Fmsdos_mouse_disable)
Richard M. Stallman <rms@gnu.org>
parents:
10504
diff
changeset
|
565 defsubr (&Smsdos_mouse_disable); |
|
34348
5cd770204501
(Ffile_system_info): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
32544
diff
changeset
|
566 defsubr (&Sfile_system_info); |
| 9572 | 567 #ifndef HAVE_X_WINDOWS |
| 568 defsubr (&Smsdos_mouse_p); | |
| 569 #endif | |
| 5503 | 570 |
| 571 DEFVAR_INT ("dos-country-code", &dos_country_code, | |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
572 doc: /* The country code returned by Dos when Emacs was started. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
573 Usually this is the international telephone prefix. */); |
| 5503 | 574 |
| 575 DEFVAR_INT ("dos-codepage", &dos_codepage, | |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
576 doc: /* The codepage active when Emacs was started. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
577 The following are known: |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
578 437 United States |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
579 850 Multilingual (Latin I) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
580 852 Slavic (Latin II) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
581 857 Turkish |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
582 860 Portugal |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
583 861 Iceland |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
584 863 Canada (French) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
585 865 Norway/Denmark */); |
| 5503 | 586 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
587 DEFVAR_INT ("dos-timezone-offset", &dos_timezone_offset, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
588 doc: /* The current timezone offset to UTC in minutes. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
589 Implicitly modified when the TZ variable is changed. */); |
| 45331 | 590 |
| 5503 | 591 DEFVAR_LISP ("dos-version", &Vdos_version, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
592 doc: /* The (MAJOR . MINOR) Dos version (subject to modification with setver). */); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
593 |
| 20034 | 594 #ifndef HAVE_X_WINDOWS |
| 595 DEFVAR_LISP ("dos-windows-version", &Vdos_windows_version, | |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
596 doc: /* The (MAJOR . MINOR) Windows version for DOS session on MS-Windows. */); |
| 20034 | 597 #endif |
| 598 | |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
599 DEFVAR_LISP ("dos-display-scancodes", &Vdos_display_scancodes, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
600 doc: /* *Controls whether DOS raw keyboard events are displayed as you type. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
601 When non-nil, the keyboard scan-codes are displayed at the bottom right |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
602 corner of the display (typically at the end of the mode line). |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
603 The output format is: scan code:char code*modifiers. */); |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
604 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
605 Vdos_display_scancodes = Qnil; |
| 45331 | 606 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
607 DEFVAR_INT ("dos-hyper-key", &dos_hyper_key, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
608 doc: /* *If set to 1, use right ALT key as hyper key. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
609 If set to 2, use right CTRL key as hyper key. */); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
610 dos_hyper_key = 0; |
| 45331 | 611 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
612 DEFVAR_INT ("dos-super-key", &dos_super_key, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
613 doc: /* *If set to 1, use right ALT key as super key. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
614 If set to 2, use right CTRL key as super key. */); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
615 dos_super_key = 0; |
| 45331 | 616 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
617 DEFVAR_INT ("dos-keypad-mode", &dos_keypad_mode, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
618 doc: /* *Controls what key code is returned by a key in the numeric keypad. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
619 The `numlock ON' action is only taken if no modifier keys are pressed. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
620 The value is an integer constructed by adding the following bits together: |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
621 |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
622 0x00 Digit key returns digit (if numlock ON) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
623 0x01 Digit key returns kp-digit (if numlock ON) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
624 0x02 Digit key returns M-digit (if numlock ON) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
625 0x03 Digit key returns edit key (if numlock ON) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
626 |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
627 0x00 Grey key returns char (if numlock ON) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
628 0x04 Grey key returns kp-key (if numlock ON) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
629 |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
630 0x00 Digit key returns digit (if numlock OFF) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
631 0x10 Digit key returns kp-digit (if numlock OFF) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
632 0x20 Digit key returns M-digit (if numlock OFF) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
633 0x30 Digit key returns edit key (if numlock OFF) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
634 |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
635 0x00 Grey key returns char (if numlock OFF) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
636 0x40 Grey key returns kp-key (if numlock OFF) |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
637 |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
638 0x200 ALT-0..ALT-9 in top-row produces shifted codes. */); |
|
13612
342d919f52b2
(syms_of_dosfns): Use 0x75 for dos_keypad_mode.
Richard M. Stallman <rms@gnu.org>
parents:
13180
diff
changeset
|
639 dos_keypad_mode = 0x75; |
| 45331 | 640 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
641 DEFVAR_INT ("dos-keyboard-layout", &dos_keyboard_layout, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
642 doc: /* Contains the country code for the current keyboard layout. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
643 Use msdos-set-keyboard to select another keyboard layout. */); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
644 dos_keyboard_layout = 1; /* US */ |
| 45331 | 645 |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
646 DEFVAR_INT ("dos-decimal-point", &dos_decimal_point, |
|
41914
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
647 doc: /* The character to produce when kp-decimal key is pressed. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
648 If non-zero, this variable contains the character to be returned when the |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
649 decimal point key in the numeric keypad is pressed when Num Lock is on. |
|
ee8ae85f22ae
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
41912
diff
changeset
|
650 If zero, the decimal point key returns the country code specific value. */); |
|
13180
59663cba4b02
(insert-startup-screen): New function.
Kim F. Storm <storm@cua.dk>
parents:
12990
diff
changeset
|
651 dos_decimal_point = 0; |
| 5503 | 652 } |
| 653 #endif /* MSDOS */ | |
| 52401 | 654 |
| 655 /* arch-tag: f5ea8847-a014-42c9-83f5-7738ad640b17 | |
| 656 (do not change this comment) */ |
