Checked trouble.texi.
[emacs.git] / src / dosfns.c
blob62594f1671ff2f4f2e0de4f0fc7be7c74c438eaf
1 /* MS-DOS specific Lisp utilities. Coded by Manabu Higashida, 1991.
2 Major changes May-July 1993 Morten Welinder (only 10% original code left)
3 Copyright (C) 1991, 1993, 1996, 1997, 1998, 2001, 2002, 2003, 2004,
4 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
6 This file is part of GNU Emacs.
8 GNU Emacs is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
13 GNU Emacs is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
21 #include <config.h>
23 #ifdef MSDOS
24 /* The entire file is within this conditional */
26 #include <stdio.h>
27 #include <string.h>
28 #include <dos.h>
29 #include "lisp.h"
30 #include "buffer.h"
31 #include "termchar.h"
32 #include "frame.h"
33 #include "termhooks.h"
34 #include "blockinput.h"
35 #include "window.h"
36 #include "dosfns.h"
37 #include "msdos.h"
38 #include "dispextern.h"
39 #include "character.h"
40 #include "coding.h"
41 #include "process.h"
42 #include <dpmi.h>
43 #include <go32.h>
44 #include <dirent.h>
45 #include <sys/vfs.h>
46 #include <unistd.h>
47 #include <grp.h>
48 #include <crt0.h>
50 #ifndef __DJGPP_MINOR__
51 # define __tb _go32_info_block.linear_address_of_transfer_buffer;
52 #endif
54 DEFUN ("int86", Fint86, Sint86, 2, 2, 0,
55 doc: /* Call specific MS-DOS interrupt number INTERRUPT with REGISTERS.
56 Return the updated REGISTER vector.
58 INTERRUPT should be an integer in the range 0 to 255.
59 REGISTERS should be a vector produced by `make-register' and
60 `set-register-value'. */)
61 (interrupt, registers)
62 Lisp_Object interrupt, registers;
64 register int i;
65 int no;
66 union REGS inregs, outregs;
67 Lisp_Object val;
69 CHECK_NUMBER (interrupt);
70 no = (unsigned long) XINT (interrupt);
71 CHECK_VECTOR (registers);
72 if (no < 0 || no > 0xff || XVECTOR (registers)-> size != 8)
73 return Qnil;
74 for (i = 0; i < 8; i++)
75 CHECK_NUMBER (XVECTOR (registers)->contents[i]);
77 inregs.x.ax = (unsigned long) XFASTINT (XVECTOR (registers)->contents[0]);
78 inregs.x.bx = (unsigned long) XFASTINT (XVECTOR (registers)->contents[1]);
79 inregs.x.cx = (unsigned long) XFASTINT (XVECTOR (registers)->contents[2]);
80 inregs.x.dx = (unsigned long) XFASTINT (XVECTOR (registers)->contents[3]);
81 inregs.x.si = (unsigned long) XFASTINT (XVECTOR (registers)->contents[4]);
82 inregs.x.di = (unsigned long) XFASTINT (XVECTOR (registers)->contents[5]);
83 inregs.x.cflag = (unsigned long) XFASTINT (XVECTOR (registers)->contents[6]);
84 inregs.x.flags = (unsigned long) XFASTINT (XVECTOR (registers)->contents[7]);
86 int86 (no, &inregs, &outregs);
88 XVECTOR (registers)->contents[0] = make_number (outregs.x.ax);
89 XVECTOR (registers)->contents[1] = make_number (outregs.x.bx);
90 XVECTOR (registers)->contents[2] = make_number (outregs.x.cx);
91 XVECTOR (registers)->contents[3] = make_number (outregs.x.dx);
92 XVECTOR (registers)->contents[4] = make_number (outregs.x.si);
93 XVECTOR (registers)->contents[5] = make_number (outregs.x.di);
94 XVECTOR (registers)->contents[6] = make_number (outregs.x.cflag);
95 XVECTOR (registers)->contents[7] = make_number (outregs.x.flags);
97 return registers;
100 DEFUN ("msdos-memget", Fdos_memget, Sdos_memget, 2, 2, 0,
101 doc: /* Read DOS memory at offset ADDRESS into VECTOR.
102 Return the updated VECTOR. */)
103 (address, vector)
104 Lisp_Object address, vector;
106 register int i;
107 int offs, len;
108 char *buf;
109 Lisp_Object val;
111 CHECK_NUMBER (address);
112 offs = (unsigned long) XINT (address);
113 CHECK_VECTOR (vector);
114 len = XVECTOR (vector)-> size;
115 if (len < 1 || len > 2048 || offs < 0 || offs > 0xfffff - len)
116 return Qnil;
117 buf = alloca (len);
118 dosmemget (offs, len, buf);
120 for (i = 0; i < len; i++)
121 XVECTOR (vector)->contents[i] = make_number (buf[i]);
123 return vector;
126 DEFUN ("msdos-memput", Fdos_memput, Sdos_memput, 2, 2, 0,
127 doc: /* Write DOS memory at offset ADDRESS from VECTOR. */)
128 (address, vector)
129 Lisp_Object address, vector;
131 register int i;
132 int offs, len;
133 char *buf;
134 Lisp_Object val;
136 CHECK_NUMBER (address);
137 offs = (unsigned long) XINT (address);
138 CHECK_VECTOR (vector);
139 len = XVECTOR (vector)-> size;
140 if (len < 1 || len > 2048 || offs < 0 || offs > 0xfffff - len)
141 return Qnil;
142 buf = alloca (len);
144 for (i = 0; i < len; i++)
146 CHECK_NUMBER (XVECTOR (vector)->contents[i]);
147 buf[i] = (unsigned char) XFASTINT (XVECTOR (vector)->contents[i]) & 0xFF;
150 dosmemput (buf, len, offs);
151 return Qt;
154 DEFUN ("msdos-set-keyboard", Fmsdos_set_keyboard, Smsdos_set_keyboard, 1, 2, 0,
155 doc: /* Set keyboard layout according to COUNTRY-CODE.
156 If the optional argument ALLKEYS is non-nil, the keyboard is mapped for
157 all keys; otherwise it is only used when the ALT key is pressed.
158 The current keyboard layout is available in dos-keyboard-code. */)
159 (country_code, allkeys)
160 Lisp_Object country_code, allkeys;
162 CHECK_NUMBER (country_code);
163 if (!dos_set_keyboard (XINT (country_code), !NILP (allkeys)))
164 return Qnil;
165 return Qt;
168 #ifndef HAVE_X_WINDOWS
169 /* Later we might want to control the mouse interface with this function,
170 e.g., with respect to non-80 column screen modes. */
172 DEFUN ("msdos-mouse-p", Fmsdos_mouse_p, Smsdos_mouse_p, 0, 0, 0,
173 doc: /* Report whether a mouse is present. */)
176 if (have_mouse)
177 return Qt;
178 else
179 return Qnil;
181 #endif
183 DEFUN ("msdos-mouse-init", Fmsdos_mouse_init, Smsdos_mouse_init, 0, 0, "",
184 doc: /* Initialize and enable mouse if available. */)
187 if (have_mouse)
189 have_mouse = 1;
190 mouse_init ();
191 return Qt;
193 return Qnil;
196 DEFUN ("msdos-mouse-enable", Fmsdos_mouse_enable, Smsdos_mouse_enable, 0, 0, "",
197 doc: /* Enable mouse if available. */)
200 if (have_mouse)
202 have_mouse = 1;
203 mouse_on ();
205 return have_mouse ? Qt : Qnil;
208 DEFUN ("msdos-mouse-disable", Fmsdos_mouse_disable, Smsdos_mouse_disable, 0, 0, "",
209 doc: /* Disable mouse if available. */)
212 mouse_off ();
213 if (have_mouse) have_mouse = -1;
214 return Qnil;
217 DEFUN ("insert-startup-screen", Finsert_startup_screen, Sinsert_startup_screen, 0, 0, "",
218 doc: /* Insert copy of screen contents prior to starting Emacs.
219 Return nil if startup screen is not available. */)
222 char *s;
223 int rows, cols, i, j;
225 if (!dos_get_saved_screen (&s, &rows, &cols))
226 return Qnil;
228 for (i = 0; i < rows; i++)
230 for (j = 0; j < cols; j++)
232 insert_char (*s);
233 s += 2;
235 insert_char ('\n');
238 return Qt;
241 /* country info */
242 EMACS_INT dos_country_code;
243 EMACS_INT dos_codepage;
244 EMACS_INT dos_timezone_offset;
245 EMACS_INT dos_decimal_point;
246 EMACS_INT dos_keyboard_layout;
247 unsigned char dos_country_info[DOS_COUNTRY_INFO];
248 static unsigned char usa_country_info[DOS_COUNTRY_INFO] = {
249 0, 0, /* date format */
250 '$', 0, 0, 0, 0, /* currency string */
251 ',', 0, /* thousands separator */
252 '.', 0, /* decimal separator */
253 '/', 0, /* date separator */
254 ':', 0, /* time separator */
255 0, /* currency format */
256 2, /* digits after decimal in currency */
257 0, /* time format */
258 0, 0, 0, 0, /* address of case map routine, GPF if used */
259 ' ', 0, /* data-list separator (?) */
260 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 /* reserved */
263 EMACS_INT dos_hyper_key;
264 EMACS_INT dos_super_key;
265 EMACS_INT dos_keypad_mode;
267 Lisp_Object Vdos_version;
268 Lisp_Object Vdos_display_scancodes;
270 #ifndef HAVE_X_WINDOWS
271 static unsigned dos_windows_version;
272 Lisp_Object Vdos_windows_version;
274 char parent_vm_title[50]; /* Ralf Brown says 30 is enough */
275 int w95_set_virtual_machine_title (const char *);
277 void
278 restore_parent_vm_title (void)
280 if (NILP (Vdos_windows_version))
281 return;
282 if ((dos_windows_version & 0xff) >= 4 && parent_vm_title[0])
283 w95_set_virtual_machine_title (parent_vm_title);
284 delay (50);
286 #endif /* !HAVE_X_WINDOWS */
288 void
289 init_dosfns ()
291 union REGS regs;
292 _go32_dpmi_registers dpmiregs;
293 unsigned long xbuf = _go32_info_block.linear_address_of_transfer_buffer;
295 #ifndef SYSTEM_MALLOC
296 get_lim_data (); /* why the hell isn't this called elsewhere? */
297 #endif
299 regs.x.ax = 0x3000;
300 intdos (&regs, &regs);
301 Vdos_version = Fcons (make_number (regs.h.al), make_number (regs.h.ah));
303 /* Obtain the country code via DPMI, use DJGPP transfer buffer. */
304 dpmiregs.x.ax = 0x3800;
305 dpmiregs.x.ds = xbuf >> 4;
306 dpmiregs.x.dx = 0;
307 dpmiregs.x.ss = dpmiregs.x.sp = dpmiregs.x.flags = 0;
308 _go32_dpmi_simulate_int (0x21, &dpmiregs);
309 if (dpmiregs.x.flags & 1)
311 dos_country_code = 1; /* assume USA if 213800 failed */
312 memcpy (dos_country_info, usa_country_info, DOS_COUNTRY_INFO);
314 else
316 dos_country_code = dpmiregs.x.bx;
317 dosmemget (xbuf, DOS_COUNTRY_INFO, dos_country_info);
320 dos_set_keyboard (dos_country_code, 0);
322 regs.x.ax = 0x6601;
323 intdos (&regs, &regs);
324 if (regs.x.cflag)
325 /* Estimate code page from country code */
326 switch (dos_country_code)
328 case 45: /* Denmark */
329 case 47: /* Norway */
330 dos_codepage = 865;
331 break;
332 default:
333 /* US */
334 dos_codepage = 437;
336 else
337 dos_codepage = regs.x.bx & 0xffff;
339 #ifndef HAVE_X_WINDOWS
340 parent_vm_title[0] = '\0';
342 /* If we are running from DOS box on MS-Windows, get Windows version. */
343 dpmiregs.x.ax = 0x1600; /* enhanced mode installation check */
344 dpmiregs.x.ss = dpmiregs.x.sp = dpmiregs.x.flags = 0;
345 _go32_dpmi_simulate_int (0x2f, &dpmiregs);
346 /* We only support Windows-specific features when we run on Windows 9X
347 or on Windows 3.X/enhanced mode.
349 Int 2Fh/AX=1600h returns:
351 AL = 00: no Windows at all;
352 AL = 01: Windows/386 2.x;
353 AL = 80h: Windows 3.x in mode other than enhanced;
354 AL = FFh: Windows/386 2.x
356 We also check AH > 0 (Windows 3.1 or later), in case AL tricks us. */
357 if (dpmiregs.h.al > 2 && dpmiregs.h.al != 0x80 && dpmiregs.h.al != 0xff
358 && (dpmiregs.h.al > 3 || dpmiregs.h.ah > 0))
360 dos_windows_version = dpmiregs.x.ax;
361 Vdos_windows_version =
362 Fcons (make_number (dpmiregs.h.al), make_number (dpmiregs.h.ah));
364 /* Save the current title of this virtual machine, so we can restore
365 it before exiting. Otherwise, Windows 95 will continue to use
366 the title we set even after we are history, stupido... */
367 if (dpmiregs.h.al >= 4)
369 dpmiregs.x.ax = 0x168e;
370 dpmiregs.x.dx = 3; /* get VM title */
371 dpmiregs.x.cx = sizeof(parent_vm_title) - 1;
372 dpmiregs.x.es = __tb >> 4;
373 dpmiregs.x.di = __tb & 15;
374 dpmiregs.x.sp = dpmiregs.x.ss = dpmiregs.x.flags = 0;
375 _go32_dpmi_simulate_int (0x2f, &dpmiregs);
376 if (dpmiregs.x.ax == 1)
377 dosmemget (__tb, sizeof(parent_vm_title), parent_vm_title);
380 else
382 dos_windows_version = 0;
383 Vdos_windows_version = Qnil;
385 #endif /* !HAVE_X_WINDOWS */
387 #if __DJGPP__ >= 2
389 /* Without this, we never see hidden files.
390 Don't OR it with the previous value, so the value recorded at dump
391 time, possibly with `preserve-case' flags set, won't get through. */
392 __opendir_flags = __OPENDIR_FIND_HIDDEN;
394 #if __DJGPP_MINOR__ == 0
395 /* Under LFN, preserve the case of files as recorded in the directory
396 (in DJGPP 2.01 and later this is automagically done by the library). */
397 if (!NILP (Fmsdos_long_file_names ()))
398 __opendir_flags |= __OPENDIR_PRESERVE_CASE;
399 #endif /* __DJGPP_MINOR__ == 0 */
400 #endif /* __DJGPP__ >= 2 */
403 #ifndef HAVE_X_WINDOWS
405 /* Emulation of some X window features from xfns.c and xfaces.c. */
407 /* Standard VGA colors, in the order of their standard numbering
408 in the default VGA palette. */
409 static char *vga_colors[16] = {
410 "black", "blue", "green", "cyan", "red", "magenta", "brown",
411 "lightgray", "darkgray", "lightblue", "lightgreen", "lightcyan",
412 "lightred", "lightmagenta", "yellow", "white"
415 /* Given a color name, return its index, or -1 if not found. Note
416 that this only performs case-insensitive comparison against the
417 standard names. For anything more sophisticated, like matching
418 "gray" with "grey" or translating X color names into their MSDOS
419 equivalents, call the Lisp function Qtty_color_desc (defined
420 on lisp/term/tty-colors.el). */
422 msdos_stdcolor_idx (const char *name)
424 int i;
426 for (i = 0; i < sizeof (vga_colors) / sizeof (vga_colors[0]); i++)
427 if (xstrcasecmp (name, vga_colors[i]) == 0)
428 return i;
430 return
431 strcmp (name, unspecified_fg) == 0 ? FACE_TTY_DEFAULT_FG_COLOR
432 : strcmp (name, unspecified_bg) == 0 ? FACE_TTY_DEFAULT_BG_COLOR
433 : FACE_TTY_DEFAULT_COLOR;
436 /* Given a color index, return its standard name. */
437 Lisp_Object
438 msdos_stdcolor_name (int idx)
440 extern Lisp_Object Qunspecified;
442 if (idx == FACE_TTY_DEFAULT_FG_COLOR)
443 return build_string (unspecified_fg);
444 else if (idx == FACE_TTY_DEFAULT_BG_COLOR)
445 return build_string (unspecified_bg);
446 else if (idx >= 0 && idx < sizeof (vga_colors) / sizeof (vga_colors[0]))
447 return build_string (vga_colors[idx]);
448 else
449 return Qunspecified; /* meaning the default */
452 /* Support for features that are available when we run in a DOS box
453 on MS-Windows. */
455 ms_windows_version (void)
457 return dos_windows_version;
460 /* Set the title of the current virtual machine, to appear on
461 the caption bar of that machine's window. */
464 w95_set_virtual_machine_title (const char *title_string)
466 /* Only Windows 9X (version 4 and higher) support this function. */
467 if (!NILP (Vdos_windows_version)
468 && (dos_windows_version & 0xff) >= 4)
470 _go32_dpmi_registers regs;
471 dosmemput (title_string, strlen (title_string) + 1, __tb);
472 regs.x.ax = 0x168e;
473 regs.x.dx = 1;
474 regs.x.es = __tb >> 4;
475 regs.x.di = __tb & 15;
476 regs.x.sp = regs.x.ss = regs.x.flags = 0;
477 _go32_dpmi_simulate_int (0x2f, &regs);
478 return regs.x.ax == 1;
480 return 0;
483 /* Change the title of frame F to NAME.
484 If NAME is nil, use the frame name as the title.
486 If Emacs is not run from a DOS box on Windows 9X, this only
487 sets the name in the frame struct, but has no other effects. */
489 void
490 x_set_title (f, name)
491 struct frame *f;
492 Lisp_Object name;
494 /* Don't change the title if it's already NAME. */
495 if (EQ (name, f->title))
496 return;
498 update_mode_lines = 1;
500 f->title = name;
502 if (NILP (name))
503 name = f->name;
505 if (FRAME_MSDOS_P (f))
507 BLOCK_INPUT;
508 w95_set_virtual_machine_title (SDATA (name));
509 UNBLOCK_INPUT;
512 #endif /* !HAVE_X_WINDOWS */
514 DEFUN ("file-system-info", Ffile_system_info, Sfile_system_info, 1, 1, 0,
515 doc: /* Return storage information about the file system FILENAME is on.
516 Value is a list of floats (TOTAL FREE AVAIL), where TOTAL is the total
517 storage of the file system, FREE is the free storage, and AVAIL is the
518 storage available to a non-superuser. All 3 numbers are in bytes.
519 If the underlying system call fails, value is nil. */)
520 (filename)
521 Lisp_Object filename;
523 struct statfs stfs;
524 Lisp_Object encoded, value;
526 CHECK_STRING (filename);
527 filename = Fexpand_file_name (filename, Qnil);
528 encoded = ENCODE_FILE (filename);
530 if (statfs (SDATA (encoded), &stfs))
531 value = Qnil;
532 else
533 value = list3 (make_float ((double) stfs.f_bsize * stfs.f_blocks),
534 make_float ((double) stfs.f_bsize * stfs.f_bfree),
535 make_float ((double) stfs.f_bsize * stfs.f_bavail));
537 return value;
540 /* System depended enumeration of and access to system processes a-la
541 ps(1). Here, we only return info about the running Emacs process.
542 (There are no other processes on DOS, right?) */
544 Lisp_Object
545 list_system_processes ()
547 Lisp_Object proclist = Qnil;
549 proclist = Fcons (make_fixnum_or_float (getpid ()), proclist);
551 return proclist;
554 Lisp_Object
555 system_process_attributes (Lisp_Object pid)
557 int proc_id;
558 Lisp_Object attrs = Qnil;
560 CHECK_NUMBER_OR_FLOAT (pid);
561 proc_id = FLOATP (pid) ? XFLOAT_DATA (pid) : XINT (pid);
563 if (proc_id == getpid ())
565 EMACS_INT uid, gid;
566 char *usr;
567 struct group *gr;
568 char cmd[FILENAME_MAX];
569 char *cmdline = NULL, *p, *q;
570 size_t cmdline_size = 0;
571 int i;
572 Lisp_Object cmd_str, decoded_cmd, tem;
573 double pmem;
574 #ifndef SYSTEM_MALLOC
575 extern unsigned long ret_lim_data ();
576 #endif
578 uid = getuid ();
579 attrs = Fcons (Fcons (Qeuid, make_fixnum_or_float (uid)), attrs);
580 usr = getlogin ();
581 if (usr)
582 attrs = Fcons (Fcons (Quser, build_string (usr)), attrs);
583 gid = getgid ();
584 attrs = Fcons (Fcons (Qegid, make_fixnum_or_float (gid)), attrs);
585 gr = getgrgid (gid);
586 if (gr)
587 attrs = Fcons (Fcons (Qgroup, build_string (gr->gr_name)), attrs);
588 strcpy (cmd, basename (__crt0_argv[0]));
589 /* Command name is encoded in locale-coding-system; decode it. */
590 cmd_str = make_unibyte_string (cmd, strlen (cmd));
591 decoded_cmd = code_convert_string_norecord (cmd_str,
592 Vlocale_coding_system, 0);
593 attrs = Fcons (Fcons (Qcomm, decoded_cmd), attrs);
594 /* Pretend we have 0 as PPID. */
595 attrs = Fcons (Fcons (Qppid, make_number (0)), attrs);
596 attrs = Fcons (Fcons (Qpgrp, pid), attrs);
597 attrs = Fcons (Fcons (Qttname, build_string ("/dev/tty")), attrs);
598 /* We are never idle! */
599 tem = Fget_internal_run_time ();
600 attrs = Fcons (Fcons (Qtime, tem), attrs);
601 attrs = Fcons (Fcons (Qthcount, make_number (1)), attrs);
602 attrs = Fcons (Fcons (Qstart,
603 Fsymbol_value (intern ("before-init-time"))),
604 attrs);
605 attrs = Fcons (Fcons (Qvsize,
606 make_fixnum_or_float ((unsigned long)sbrk(0)/1024)),
607 attrs);
608 attrs = Fcons (Fcons (Qetime, tem), attrs);
609 #ifndef SYSTEM_MALLOC
610 /* ret_lim_data is on vm-limit.c, which is not compiled in under
611 SYSTEM_MALLOC. */
612 pmem = (double)((unsigned long) sbrk (0)) / ret_lim_data () * 100.0;
613 if (pmem > 100)
614 #endif
615 pmem = 100;
616 attrs = Fcons (Fcons (Qpmem, make_float (pmem)), attrs);
617 /* Pass 1: Count how much storage we need. */
618 for (i = 0; i < __crt0_argc; i++)
620 cmdline_size += strlen (__crt0_argv[i]) + 1; /* +1 for blank delim */
621 if (strpbrk (__crt0_argv[i], " \t\n\r\v\f"))
623 cmdline_size += 2;
624 for (p = __crt0_argv[i]; *p; p++)
626 if (*p == '"')
627 cmdline_size++;
631 /* Pass 2: Allocate storage and concatenate argv[]. */
632 cmdline = xmalloc (cmdline_size + 1);
633 for (i = 0, q = cmdline; i < __crt0_argc; i++)
635 if (strpbrk (__crt0_argv[i], " \t\n\r\v\f"))
637 *q++ = '"';
638 for (p = __crt0_argv[i]; *p; p++)
640 if (*p == '\"')
641 *q++ = '\\';
642 *q++ = *p;
644 *q++ = '"';
646 else
648 strcpy (q, __crt0_argv[i]);
649 q += strlen (__crt0_argv[i]);
651 *q++ = ' ';
653 /* Remove the trailing blank. */
654 if (q > cmdline)
655 q[-1] = '\0';
657 /* Command line is encoded in locale-coding-system; decode it. */
658 cmd_str = make_unibyte_string (cmdline, strlen (cmdline));
659 decoded_cmd = code_convert_string_norecord (cmd_str,
660 Vlocale_coding_system, 0);
661 xfree (cmdline);
662 attrs = Fcons (Fcons (Qargs, decoded_cmd), attrs);
665 return attrs;
668 void
669 dos_cleanup (void)
671 struct tty_display_info *tty;
673 #ifndef HAVE_X_WINDOWS
674 restore_parent_vm_title ();
675 #endif
676 /* Make sure the termscript file is committed, in case we are
677 crashing and some vital info was written there. */
678 if (FRAMEP (selected_frame))
680 struct frame *sf = XFRAME (selected_frame);
682 if (FRAME_LIVE_P (sf)
683 && (FRAME_MSDOS_P (sf) || FRAME_TERMCAP_P (sf)))
685 tty = CURTTY ();
686 if (tty->termscript)
688 fflush (tty->termscript);
689 fsync (fileno (tty->termscript));
696 * Define everything
698 syms_of_dosfns ()
700 defsubr (&Sint86);
701 defsubr (&Sdos_memget);
702 defsubr (&Sdos_memput);
703 defsubr (&Smsdos_mouse_init);
704 defsubr (&Smsdos_mouse_enable);
705 defsubr (&Smsdos_set_keyboard);
706 defsubr (&Sinsert_startup_screen);
707 defsubr (&Smsdos_mouse_disable);
708 defsubr (&Sfile_system_info);
709 #ifndef HAVE_X_WINDOWS
710 defsubr (&Smsdos_mouse_p);
711 #endif
713 DEFVAR_INT ("dos-country-code", &dos_country_code,
714 doc: /* The country code returned by Dos when Emacs was started.
715 Usually this is the international telephone prefix. */);
717 DEFVAR_INT ("dos-codepage", &dos_codepage,
718 doc: /* The codepage active when Emacs was started.
719 The following are known:
720 437 United States
721 850 Multilingual (Latin I)
722 852 Slavic (Latin II)
723 857 Turkish
724 860 Portugal
725 861 Iceland
726 863 Canada (French)
727 865 Norway/Denmark */);
729 DEFVAR_INT ("dos-timezone-offset", &dos_timezone_offset,
730 doc: /* The current timezone offset to UTC in minutes.
731 Implicitly modified when the TZ variable is changed. */);
733 DEFVAR_LISP ("dos-version", &Vdos_version,
734 doc: /* The (MAJOR . MINOR) Dos version (subject to modification with setver). */);
736 #ifndef HAVE_X_WINDOWS
737 DEFVAR_LISP ("dos-windows-version", &Vdos_windows_version,
738 doc: /* The (MAJOR . MINOR) Windows version for DOS session on MS-Windows. */);
739 #endif
741 DEFVAR_LISP ("dos-display-scancodes", &Vdos_display_scancodes,
742 doc: /* *Controls whether DOS raw keyboard events are displayed as you type.
743 When non-nil, the keyboard scan-codes are displayed at the bottom right
744 corner of the display (typically at the end of the mode line).
745 The output format is: scan code:char code*modifiers. */);
747 Vdos_display_scancodes = Qnil;
749 DEFVAR_INT ("dos-hyper-key", &dos_hyper_key,
750 doc: /* *If set to 1, use right ALT key as hyper key.
751 If set to 2, use right CTRL key as hyper key. */);
752 dos_hyper_key = 0;
754 DEFVAR_INT ("dos-super-key", &dos_super_key,
755 doc: /* *If set to 1, use right ALT key as super key.
756 If set to 2, use right CTRL key as super key. */);
757 dos_super_key = 0;
759 DEFVAR_INT ("dos-keypad-mode", &dos_keypad_mode,
760 doc: /* *Controls what key code is returned by a key in the numeric keypad.
761 The `numlock ON' action is only taken if no modifier keys are pressed.
762 The value is an integer constructed by adding the following bits together:
764 0x00 Digit key returns digit (if numlock ON)
765 0x01 Digit key returns kp-digit (if numlock ON)
766 0x02 Digit key returns M-digit (if numlock ON)
767 0x03 Digit key returns edit key (if numlock ON)
769 0x00 Grey key returns char (if numlock ON)
770 0x04 Grey key returns kp-key (if numlock ON)
772 0x00 Digit key returns digit (if numlock OFF)
773 0x10 Digit key returns kp-digit (if numlock OFF)
774 0x20 Digit key returns M-digit (if numlock OFF)
775 0x30 Digit key returns edit key (if numlock OFF)
777 0x00 Grey key returns char (if numlock OFF)
778 0x40 Grey key returns kp-key (if numlock OFF)
780 0x200 ALT-0..ALT-9 in top-row produces shifted codes. */);
781 dos_keypad_mode = 0x75;
783 DEFVAR_INT ("dos-keyboard-layout", &dos_keyboard_layout,
784 doc: /* Contains the country code for the current keyboard layout.
785 Use msdos-set-keyboard to select another keyboard layout. */);
786 dos_keyboard_layout = 1; /* US */
788 DEFVAR_INT ("dos-decimal-point", &dos_decimal_point,
789 doc: /* The character to produce when kp-decimal key is pressed.
790 If non-zero, this variable contains the character to be returned when the
791 decimal point key in the numeric keypad is pressed when Num Lock is on.
792 If zero, the decimal point key returns the country code specific value. */);
793 dos_decimal_point = 0;
795 #endif /* MSDOS */
797 /* arch-tag: f5ea8847-a014-42c9-83f5-7738ad640b17
798 (do not change this comment) */