annotate src/dosfns.c @ 51151:fe11e703042b

Summary: MIME support added for e-mail processing that skips encoded regions. Allow user to skip saving Fcc messages with large attachments. Fixed region skipping bug with multi-line comments - e.g. tex $ regions spanning multiple lines. Added support for postscript and uuencoded regions. Redundant dictionary file names purged. Dictionary definition field name changed from "Character Set" to "Coding System". Fixed bug in reloading dictionaries. Modified headers to reflect new version. XEmacs menu now adds customize item. (ispell-check-version): No longer an aliased function. Returns library path if not called interactively. Variable `temporary-file-directory' protected if not loaded. (check-ispell-version): Now the alias for `ispell-check-version'. (ispell-message-fcc-skip): New variable that determines if and when to query about saving Fcc copy of message if an attachment is large. (ispell-skip-html): Declared buffer-local. (ispell-local-dictionary-alist): Docstring expanded. Tag name changed from "Character Set" to "Coding System". (ispell-dictionary-alist-1): Removed redundant command-line option to load brasileiro, british, and castellano dictionary files. (ispell-dictionary-alist-2): Removed redundant command-line option to load czech dictionary file. (ispell-dictionary-alist-3): Moved francais-tex here. (ispell-dictionary-alist-4): Removed german and german8 dictionaries. The deutsch ones are the correct definitions. `nederlands' and `nederlands8' dictionaries moved here. (ispell-dictionary-alist-5): `polish' and `portugues' dictionaries moved here. Removed redundant command-line option to `norsk' and `portugues'. (ispell-dictionary-alist-6): Removed redundant command-line option to load `russian' and `slovak' dictionary files. (ispell-dictionary-alist): Tag name changed from "Character Set" to "Coding System". (ispell-version): Updated to 3.6. (ispell-library-directory): Calls non-deprecated function. (ispell-valid-dictionary-list): New function returning all valid dictionaries on machine. (ispell-checking-message): Documentation string improved. (ispell-skip-region-alist): Added uuencoded and postscript region skipping. Improved http/e-mail/file regexp to not match `/.\w'. (ispell-html-skip-alists): New variable for html region support. (ispell-send-string): Removed redundant xemacs check. (ispell-word): Fix spelling error in documentation string, added extent information to support highlighting in ispell-minor-mode. (ispell-command-loop): Disable horizontal scrollbar in XEmacs choices buffer. (ispell-show-choices): Directly select `choices-window'. (ispell-help): Use default buffer size for electric help. (ispell-adjusted-window-height): Correct for xemacs detection. (ispell-start-process): Don't double specify dictionary file name. (ispell-init-process): Set `ispell-library-path' each call. (ispell-change-dictionary): Now only completes valid dictionaries. (ispell-region): Add support for MIME region skipping and Fcc message query for large attachments. (ispell-begin-skip-region-regexp): Add documentation string. Added message support and cleaned up code for generic and html regions. (ispell-begin-skip-region): Function is now requires alist argument. (ispell-begin-tex-skip-regexp): Added comments and support improved html and message regions. (ispell-skip-region-list): New function for MIME and region skipping. (ispell-tex-arg-end): Add documentation string. (ispell-ignore-fcc): New function to query saving Fcc message. (ispell-skip-region): Calculate alist for key match dynamically, html skipping pushed to alists. (ispell-get-line): Add support for multi-line comment regions. (ispell): Check that variables to continue spelling are bound. (ispell-message-text-end): Postscript and uuencoded regions now supported as MIME regions, rather than as end-of-message region. (ispell-mime-multipartp): New function supporting MIME. (ispell-mime-skip-part): New function supporting MIME. (ispell-message): Add MIME support. (ispell-buffer-local-parsing): Variable `ispell-skip-html' now local. (ispell-buffer-local-dict): Fixed bug for detecting and reloading new dictionary.
author Stefan Monnier <monnier@iro.umontreal.ca>
date Thu, 22 May 2003 21:34:00 +0000
parents 40db0673e6f0
children 695cf19ef79e d7ddb3e565de
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1 /* MS-DOS specific Lisp utilities. Coded by Manabu Higashida, 1991.
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2 Major changes May-July 1993 Morten Welinder (only 10% original code left)
36513
f022afc9cdcb Update copyright notice.
Eli Zaretskii <eliz@gnu.org>
parents: 34348
diff changeset
3 Copyright (C) 1991, 1993, 1996, 1997, 1998, 2001
f022afc9cdcb Update copyright notice.
Eli Zaretskii <eliz@gnu.org>
parents: 34348
diff changeset
4 Free Software Foundation, Inc.
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6 This file is part of GNU Emacs.
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
7
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
8 GNU Emacs is free software; you can redistribute it and/or modify
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
9 it under the terms of the GNU General Public License as published by
10504
8a1bd0598b49 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 9572
diff changeset
10 the Free Software Foundation; either version 2, or (at your option)
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11 any later version.
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
12
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
13 GNU Emacs is distributed in the hope that it will be useful,
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
16 GNU General Public License for more details.
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
17
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
19 along with GNU Emacs; see the file COPYING. If not, write to
14186
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 14070
diff changeset
20 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 14070
diff changeset
21 Boston, MA 02111-1307, USA. */
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22
5980
a203b7c30300 Use <...> for config.h.
Richard M. Stallman <rms@gnu.org>
parents: 5503
diff changeset
23 #include <config.h>
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
24
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25 #ifdef MSDOS
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
26 /* The entire file is within this conditional */
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
27
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30 #include <dos.h>
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
31 #include "lisp.h"
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32 #include "buffer.h"
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
33 #include "termchar.h"
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
34 #include "termhooks.h"
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35 #include "frame.h"
20034
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
36 #include "blockinput.h"
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
37 #include "window.h"
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
38 #include "dosfns.h"
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47
20034
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
48 #ifndef __DJGPP_MINOR__
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
49 # define __tb _go32_info_block.linear_address_of_transfer_buffer;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
50 #endif
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
51
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
61 {
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
62 register int i;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
63 int no;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
64 union REGS inregs, outregs;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
65 Lisp_Object val;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
70 if (no < 0 || no > 0xff || XVECTOR (registers)-> size != 8)
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
71 return Qnil;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
83
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84 int86 (no, &inregs, &outregs);
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
96 }
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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;
45331
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
113 if (len < 1 || len > 2048 || address < 0 || address > 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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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;
45331
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
138 if (len < 1 || len > 2048 || address < 0 || address > 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)
ee8ae85f22ae Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 41912
diff changeset
158 Lisp_Object country_code;
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
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
166 #ifndef HAVE_X_WINDOWS
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
167 /* Later we might want to control the mouse interface with this function,
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
168 e.g., with respect to non-80 column screen modes. */
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
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
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
172 ()
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
173 {
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
174 if (have_mouse)
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
175 return Qt;
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
176 else
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
177 return Qnil;
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
178 }
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
179 #endif
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
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, "",
ee8ae85f22ae Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 41912
diff changeset
216 doc: /* Insert copy of screen contents prior to starting emacs.
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
221 int rows, cols, i, j;
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
267
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
268 #ifndef HAVE_X_WINDOWS
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
269 static unsigned dos_windows_version;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
270 Lisp_Object Vdos_windows_version;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
271
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
272 char parent_vm_title[50]; /* Ralf Brown says 30 is enough */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
273 int w95_set_virtual_machine_title (const char *);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
274
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
275 void
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
276 restore_parent_vm_title (void)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
277 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
278 if (NILP (Vdos_windows_version))
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
279 return;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
280 if ((dos_windows_version & 0xff) >= 4 && parent_vm_title[0])
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
281 w95_set_virtual_machine_title (parent_vm_title);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
282 delay (50);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
283 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
284 #endif /* !HAVE_X_WINDOWS */
45331
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
285
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
286 void
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
287 init_dosfns ()
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
288 {
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
289 union REGS regs;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
292
9572
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
293 #ifndef SYSTEM_MALLOC
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
294 get_lim_data (); /* why the hell isn't this called elsewhere? */
9572
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
295 #endif
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
296
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
297 regs.x.ax = 0x3000;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
298 intdos (&regs, &regs);
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
299 Vdos_version = Fcons (make_number (regs.h.al), make_number (regs.h.ah));
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
312 else
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
313 {
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
319
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
320 regs.x.ax = 0x6601;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
321 intdos (&regs, &regs);
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
322 if (regs.x.cflag)
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
323 /* Estimate code page from country code */
45331
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
324 switch (dos_country_code)
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
325 {
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
326 case 45: /* Denmark */
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
327 case 47: /* Norway */
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
328 dos_codepage = 865;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
329 break;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
330 default:
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
331 /* US */
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
332 dos_codepage = 437;
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
333 }
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
334 else
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
337 #ifndef HAVE_X_WINDOWS
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
338 parent_vm_title[0] = '\0';
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
339
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
340 /* If we are running from DOS box on MS-Windows, get Windows version. */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
341 dpmiregs.x.ax = 0x1600; /* enhanced mode installation check */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
342 dpmiregs.x.ss = dpmiregs.x.sp = dpmiregs.x.flags = 0;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
343 _go32_dpmi_simulate_int (0x2f, &dpmiregs);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
344 /* We only support Windows-specific features when we run on Windows 9X
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
345 or on Windows 3.X/enhanced mode.
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
346
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
347 Int 2Fh/AX=1600h returns:
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
348
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
349 AL = 00: no Windows at all;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
350 AL = 01: Windows/386 2.x;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
351 AL = 80h: Windows 3.x in mode other than enhanced;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
352 AL = FFh: Windows/386 2.x
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
353
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
354 We also check AH > 0 (Windows 3.1 or later), in case AL tricks us. */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
355 if (dpmiregs.h.al > 2 && dpmiregs.h.al != 0x80 && dpmiregs.h.al != 0xff
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
356 && (dpmiregs.h.al > 3 || dpmiregs.h.ah > 0))
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
357 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
358 dos_windows_version = dpmiregs.x.ax;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
359 Vdos_windows_version =
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
360 Fcons (make_number (dpmiregs.h.al), make_number (dpmiregs.h.ah));
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
361
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
362 /* Save the current title of this virtual machine, so we can restore
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
363 it before exiting. Otherwise, Windows 95 will continue to use
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
364 the title we set even after we are history, stupido... */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
365 if (dpmiregs.h.al >= 4)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
366 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
367 dpmiregs.x.ax = 0x168e;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
368 dpmiregs.x.dx = 3; /* get VM title */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
369 dpmiregs.x.cx = sizeof(parent_vm_title) - 1;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
370 dpmiregs.x.es = __tb >> 4;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
371 dpmiregs.x.di = __tb & 15;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
372 dpmiregs.x.sp = dpmiregs.x.ss = dpmiregs.x.flags = 0;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
373 _go32_dpmi_simulate_int (0x2f, &dpmiregs);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
374 if (dpmiregs.x.ax == 1)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
375 dosmemget (__tb, sizeof(parent_vm_title), parent_vm_title);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
376 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
377 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
378 else
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
379 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
380 dos_windows_version = 0;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
381 Vdos_windows_version = Qnil;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
382 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
383 #endif /* !HAVE_X_WINDOWS */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
399 }
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
400
20034
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
450 /* Support for features that are available when we run in a DOS box
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
451 on MS-Windows. */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
452 int
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
453 ms_windows_version (void)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
454 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
455 return dos_windows_version;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
456 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
457
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
458 /* Set the title of the current virtual machine, to appear on
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
459 the caption bar of that machine's window. */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
460
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
461 int
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
462 w95_set_virtual_machine_title (const char *title_string)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
463 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
464 /* Only Windows 9X (version 4 and higher) support this function. */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
465 if (!NILP (Vdos_windows_version)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
466 && (dos_windows_version & 0xff) >= 4)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
467 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
468 _go32_dpmi_registers regs;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
469 dosmemput (title_string, strlen (title_string) + 1, __tb);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
470 regs.x.ax = 0x168e;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
471 regs.x.dx = 1;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
472 regs.x.es = __tb >> 4;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
473 regs.x.di = __tb & 15;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
474 regs.x.sp = regs.x.ss = regs.x.flags = 0;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
475 _go32_dpmi_simulate_int (0x2f, &regs);
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
476 return regs.x.ax == 1;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
477 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
478 return 0;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
479 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
480
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
481 /* Change the title of frame F to NAME.
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
482 If NAME is nil, use the frame name as the title.
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
483
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
484 If Emacs is not run from a DOS box on Windows 9X, this only
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
485 sets the name in the frame struct, but has no other effects. */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
486
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
487 void
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
488 x_set_title (f, name)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
489 struct frame *f;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
490 Lisp_Object name;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
491 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
492 /* Don't change the title if it's already NAME. */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
493 if (EQ (name, f->title))
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
494 return;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
495
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
496 update_mode_lines = 1;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
497
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
498 f->title = name;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
499
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
500 if (NILP (name))
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
501 name = f->name;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
502
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
503 if (FRAME_MSDOS_P (f))
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
504 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
507 UNBLOCK_INPUT;
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
508 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
509 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
510 #endif /* !HAVE_X_WINDOWS */
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
538 void
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
539 dos_cleanup (void)
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
540 {
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
541 #ifndef HAVE_X_WINDOWS
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
542 restore_parent_vm_title ();
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
551 }
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
552
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
553 /*
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
554 * Define everything
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
555 */
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
556 syms_of_dosfns ()
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
557 {
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
567 #ifndef HAVE_X_WINDOWS
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
568 defsubr (&Smsdos_mouse_p);
b36d5e88cccc *** empty log message ***
Morten Welinder <terra@diku.dk>
parents: 7272
diff changeset
569 #endif
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
570
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
574
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
590
5503
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
594 #ifndef HAVE_X_WINDOWS
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
597 #endif
674d7beabce0 (__tb): Define.
Eli Zaretskii <eliz@gnu.org>
parents: 19294
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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
425d5cebd73c Fix whitespace.
Eli Zaretskii <eliz@gnu.org>
parents: 43713
diff changeset
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
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
652 }
003e84b91d21 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
653 #endif /* MSDOS */