Update years in copyright notice; nfc.
[bpt/emacs.git] / src / emacs.c
CommitLineData
f927c5ae 1/* Fully extensible Emacs, running on Unix, intended for GNU.
0b5538bd
TTN
2 Copyright (C) 1985, 1986, 1987, 1993, 1994, 1995, 1997, 1998, 1999,
3 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
f927c5ae
JB
4
5This file is part of GNU Emacs.
6
7GNU Emacs is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
40be253a 9the Free Software Foundation; either version 2, or (at your option)
f927c5ae
JB
10any later version.
11
12GNU Emacs is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with GNU Emacs; see the file COPYING. If not, write to
4fc5845f
LK
19the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20Boston, MA 02110-1301, USA. */
f927c5ae
JB
21
22
68c45bf0 23#include <config.h>
f927c5ae
JB
24#include <signal.h>
25#include <errno.h>
f927c5ae
JB
26#include <stdio.h>
27
28#include <sys/types.h>
29#include <sys/file.h>
30
31#ifdef VMS
32#include <ssdef.h>
33#endif
34
cda4a5fd
GM
35#ifdef HAVE_UNISTD_H
36#include <unistd.h>
37#endif
38
488b7cb3 39#ifdef BSD_SYSTEM
f927c5ae
JB
40#include <sys/ioctl.h>
41#endif
42
edd3ff1d
JR
43#ifdef WINDOWSNT
44#include <fcntl.h>
52c7f9ee
JR
45#include <windows.h> /* just for w32.h */
46#include "w32.h"
c68a2829 47#include "w32heap.h" /* for prototype of sbrk */
edd3ff1d
JR
48#endif
49
f927c5ae
JB
50#include "lisp.h"
51#include "commands.h"
bef79ee4 52#include "intervals.h"
a08a816a 53#include "buffer.h"
3f6abfd7 54#include "window.h"
f927c5ae 55
edc8ae07 56#include "systty.h"
6c3a4e9d 57#include "blockinput.h"
8090eb09 58#include "syssignal.h"
6c362a8b 59#include "process.h"
5bda49c6 60#include "termhooks.h"
dfcf069d 61#include "keyboard.h"
e35f6ff7 62#include "keymap.h"
a41f8bed 63
68c45bf0
PE
64#ifdef HAVE_SETLOCALE
65#include <locale.h>
66#endif
67
53c58b5d
RS
68#ifdef HAVE_SETRLIMIT
69#include <sys/time.h>
70#include <sys/resource.h>
71#endif
72
dede2792
JD
73#ifdef HAVE_PERSONALITY_LINUX32
74#include <sys/personality.h>
75#endif
76
f927c5ae
JB
77#ifndef O_RDWR
78#define O_RDWR 2
79#endif
80
f95c3f91 81#ifdef HAVE_SETPGID
2b7e8799 82#if !defined (USG) || defined (BSD_PGRPS)
90553aa3 83#undef setpgrp
f95c3f91
GM
84#define setpgrp setpgid
85#endif
2b7e8799 86#endif
f95c3f91 87
90553aa3
DL
88extern void malloc_warning P_ ((char *));
89extern void set_time_zone_rule P_ ((char *));
8892f40b
GM
90#ifdef HAVE_INDEX
91extern char *index P_ ((const char *, int));
92#endif
43165242 93
30aa3f19
GM
94/* Make these values available in GDB, which doesn't see macros. */
95
0dda8fd8
SM
96#ifdef USE_LSB_TAG
97int gdb_use_lsb = 1;
98#else
99int gdb_use_lsb = 0;
100#endif
101#ifdef NO_UNION_TYPE
102int gdb_use_union = 0;
103#else
104int gdb_use_union = 1;
105#endif
30aa3f19
GM
106EMACS_INT gdb_valbits = VALBITS;
107EMACS_INT gdb_gctypebits = GCTYPEBITS;
30aa3f19
GM
108#ifdef DATA_SEG_BITS
109EMACS_INT gdb_data_seg_bits = DATA_SEG_BITS;
110#else
df50cf6c 111EMACS_INT gdb_data_seg_bits = 0;
30aa3f19 112#endif
00da0e4a 113EMACS_INT PVEC_FLAG = PSEUDOVECTOR_FLAG;
3fba6ca9 114EMACS_INT gdb_array_mark_flag = ARRAY_MARK_FLAG;
30aa3f19 115
7db35a48 116/* Command line args from shell, as list of strings. */
f927c5ae
JB
117Lisp_Object Vcommand_line_args;
118
59653951
JB
119/* The name under which Emacs was invoked, with any leading directory
120 names discarded. */
121Lisp_Object Vinvocation_name;
122
ace40a69
RS
123/* The directory name from which Emacs was invoked. */
124Lisp_Object Vinvocation_directory;
125
07f4d123
RS
126/* The directory name in which to find subdirs such as lisp and etc.
127 nil means get them only from PATH_LOADSEARCH. */
128Lisp_Object Vinstallation_directory;
129
e5d77022
JB
130/* Hook run by `kill-emacs' before it does really anything. */
131Lisp_Object Vkill_emacs_hook;
132
f9a6326d
SM
133/* An empty lisp string. To avoid having to build any other. */
134Lisp_Object empty_string;
135
074a066b
GV
136/* Search path separator. */
137Lisp_Object Vpath_separator;
138
f927c5ae
JB
139/* Set nonzero after Emacs has started up the first time.
140 Prevents reinitialization of the Lisp world and keymaps
141 on subsequent starts. */
142int initialized;
143
15aaf1b5
RS
144#ifdef DOUG_LEA_MALLOC
145/* Preserves a pointer to the memory allocated that copies that
146 static data inside glibc's malloc. */
147void *malloc_state_ptr;
148/* From glibc, a routine that returns a copy of the malloc internal state. */
149extern void *malloc_get_state ();
150/* From glibc, a routine that overwrites the malloc internal state. */
151extern void malloc_set_state ();
7c9cd446
AS
152/* Non-zero if the MALLOC_CHECK_ enviroment variable was set while
153 dumping. Used to work around a bug in glibc's malloc. */
154int malloc_using_checking;
15aaf1b5
RS
155#endif
156
271c7b7c 157/* Variable whose value is symbol giving operating system type. */
f927c5ae 158Lisp_Object Vsystem_type;
271c7b7c
RS
159
160/* Variable whose value is string giving configuration built for. */
161Lisp_Object Vsystem_configuration;
f0fc0b1a
KH
162
163/* Variable whose value is string giving configuration options,
164 for use when reporting bugs. */
165Lisp_Object Vsystem_configuration_options;
166
213d0b1f
RS
167Lisp_Object Qfile_name_handler_alist;
168
68c45bf0 169/* Current and previous system locales for messages and time. */
ca9c0567
PE
170Lisp_Object Vsystem_messages_locale;
171Lisp_Object Vprevious_system_messages_locale;
172Lisp_Object Vsystem_time_locale;
173Lisp_Object Vprevious_system_time_locale;
68c45bf0 174
7d0393cf 175/* If non-zero, emacs should not attempt to use a window-specific code,
7db35a48 176 but instead should use the virtual terminal under which it was started. */
f927c5ae
JB
177int inhibit_window_system;
178
5aa7f46a
JB
179/* If nonzero, set Emacs to run at this priority. This is also used
180 in child_setup and sys_suspend to make sure subshells run at normal
7db35a48 181 priority; those functions have their own extern declaration. */
31ade731 182EMACS_INT emacs_priority;
3005da00 183
7db35a48
PJ
184/* If non-zero, a filter or a sentinel is running. Tested to save the match
185 data on the first attempt to change it inside asynchronous code. */
7074fde6
FP
186int running_asynch_code;
187
647cec74 188#ifdef BSD_PGRPS
9ae8f997
JB
189/* See sysdep.c. */
190extern int inherited_pgroup;
191#endif
192
f927c5ae 193#ifdef HAVE_X_WINDOWS
7db35a48 194/* If non-zero, -d was specified, meaning we're using some window system. */
f927c5ae
JB
195int display_arg;
196#endif
197
198/* An address near the bottom of the stack.
199 Tells GC how to save a copy of the stack. */
200char *stack_bottom;
201
dede2792
JD
202/* The address where the heap starts (from the first sbrk (0) call). */
203static void *my_heap_start;
204
205/* The gap between BSS end and heap start as far as we can tell. */
206static unsigned long heap_bss_diff;
207
208/* If the gap between BSS end and heap start is larger than this we try to
209 work around it, and if that fails, output a warning in dump-emacs. */
210#define MAX_HEAP_BSS_DIFF (1024*1024)
211
212
8ba50e1a 213#ifdef HAVE_WINDOW_SYSTEM
f927c5ae 214extern Lisp_Object Vwindow_system;
8ba50e1a 215#endif /* HAVE_WINDOW_SYSTEM */
f927c5ae 216
1090a161
RS
217extern Lisp_Object Vauto_save_list_file_name;
218
9db03f6c
KS
219extern Lisp_Object Vinhibit_redisplay;
220
f927c5ae
JB
221#ifdef USG_SHARED_LIBRARIES
222/* If nonzero, this is the place to put the end of the writable segment
223 at startup. */
224
225unsigned int bss_end = 0;
226#endif
227
228/* Nonzero means running Emacs without interactive terminal. */
229
230int noninteractive;
231
232/* Value of Lisp variable `noninteractive'.
233 Normally same as C variable `noninteractive'
234 but nothing terrible happens if user sets this one. */
235
236int noninteractive1;
e29f86e4
RS
237
238/* Save argv and argc. */
239char **initial_argv;
240int initial_argc;
081bef73
RS
241
242static void sort_args ();
dfcf069d 243void syms_of_emacs ();
bd4590ba 244
f8125c39
EZ
245/* MSVC needs each string be shorter than 2048 bytes, so the usage
246 strings below are split to not overflow this limit. */
73ebcd25 247#define USAGE1 "\
bd4590ba
GM
248Usage: %s [OPTION-OR-FILENAME]...\n\
249\n\
250Run Emacs, the extensible, customizable, self-documenting real-time\n\
251display editor. The recommended way to start Emacs for normal editing\n\
252is with no options at all.\n\
253\n\
49ca717b 254Run M-x info RET m emacs RET m emacs invocation RET inside Emacs to\n\
bd4590ba
GM
255read the main documentation for these command-line arguments.\n\
256\n\
257Initialization options:\n\
258\n\
bb0b59bf
EZ
259--batch do not do interactive display; implies -q\n\
260--debug-init enable Emacs Lisp debugger for init file\n\
261--display, -d DISPLAY use X server DISPLAY\n\
262--multibyte, --no-unibyte inhibit the effect of EMACS_UNIBYTE\n\
263--no-desktop do not load a saved desktop\n\
264--no-init-file, -q load neither ~/.emacs nor default.el\n\
265--no-shared-memory, -nl do not use shared memory\n\
266--no-site-file do not load site-start.el\n\
267--no-splash do not display a splash screen on startup\n\
2ff86b4e
NR
268--no-window-system, -nw do not communicate with X, ignoring $DISPLAY\n\
269--quick, -Q equivalent to -q --no-site-file\n\
bb0b59bf
EZ
270--script FILE run FILE as an Emacs Lisp script\n\
271--terminal, -t DEVICE use DEVICE for terminal I/O\n\
bd4590ba 272--unibyte, --no-multibyte run Emacs in unibyte mode\n\
bb0b59bf 273--user, -u USER load ~USER/.emacs instead of your own\n\
f8125c39
EZ
274\n%s"
275
276#define USAGE2 "\
bd4590ba
GM
277Action options:\n\
278\n\
bb0b59bf
EZ
279FILE visit FILE using find-file\n\
280+LINE FILE visit FILE using find-file, then go to line LINE\n\
281+LINE:COLUMN FILE visit FILE using find-file, then go to line LINE,\n\
282 column COLUMN\n\
283--directory, -L DIR add DIR to variable load-path\n\
284--eval EXPR evaluate Emacs Lisp expression EXPR\n\
285--execute EXPR evaluate Emacs Lisp expression EXPR\n\
286--file FILE visit FILE using find-file\n\
287--find-file FILE visit FILE using find-file\n\
288--funcall, -f FUNC call Emacs Lisp function FUNC with no arguments\n\
289--insert FILE insert contents of FILE into current buffer\n\
290--kill exit without asking for confirmation\n\
291--load, -l FILE load Emacs Lisp FILE using the load function\n\
292--visit FILE visit FILE using find-file\n\
73ebcd25
AI
293\n"
294
f8125c39 295#define USAGE3 "\
5b2ca26b 296Display options:\n\
bd4590ba 297\n\
bb0b59bf 298--background-color, -bg COLOR window background color\n\
2ff86b4e
NR
299--basic-display, -D disable many display features;\n\
300 used for debugging Emacs\n\
bb0b59bf
EZ
301--border-color, -bd COLOR main border color\n\
302--border-width, -bw WIDTH width of main border\n\
49ca717b 303--color, --color=MODE color mode for character terminals;\n\
bb0b59bf
EZ
304 MODE defaults to `auto', and can also\n\
305 be `never', `auto', `always',\n\
306 or a mode name like `ansi8'\n\
307--cursor-color, -cr COLOR color of the Emacs cursor indicating point\n\
308--font, -fn FONT default font; must be fixed-width\n\
309--foreground-color, -fg COLOR window foreground color\n\
310--fullheight, -fh make the first frame high as the screen\n\
311--fullscreen, -fs make first frame fullscreen\n\
312--fullwidth, -fw make the first frame wide as the screen\n\
313--geometry, -g GEOMETRY window geometry\n\
bb0b59bf
EZ
314--icon-type, -i use picture of gnu for Emacs icon\n\
315--iconic start Emacs in iconified state\n\
316--internal-border, -ib WIDTH width between text and main border\n\
317--line-spacing, -lsp PIXELS additional space to put between lines\n\
318--mouse-color, -ms COLOR mouse cursor color in Emacs window\n\
319--name NAME title for initial Emacs frame\n\
49ca717b 320--no-blinking-cursor, -nbc disable blinking cursor\n\
bb0b59bf
EZ
321--reverse-video, -r, -rv switch foreground and background\n\
322--title, -T TITLE title for initial Emacs frame\n\
323--vertical-scroll-bars, -vb enable vertical scroll bars\n\
324--xrm XRESOURCES set additional X resources\n\
325--help display this help and exit\n\
326--version output version information and exit\n\
07beadff
JR
327\n"
328
329#define USAGE4 "\
bd4590ba
GM
330You can generally also specify long option names with a single -; for\n\
331example, -batch as well as --batch. You can use any unambiguous\n\
332abbreviation for a --option.\n\
333\n\
334Various environment variables and window system resources also affect\n\
335Emacs' operation. See the main documentation.\n\
07beadff 336\n\
d883731c 337Report bugs to %s. First, please see the Bugs\n\
bd4590ba
GM
338section of the Emacs manual or the file BUGS.\n"
339
f927c5ae 340\f
7db35a48 341/* Signal code for the fatal signal that was received. */
f927c5ae
JB
342int fatal_error_code;
343
7db35a48 344/* Nonzero if handling a fatal error already. */
f927c5ae
JB
345int fatal_error_in_progress;
346
7db35a48 347/* If non-null, call this function from fatal_error_signal before
4fab758d
GM
348 committing suicide. */
349
350void (*fatal_error_signal_hook) P_ ((void));
351
333f1b6f
JD
352#ifdef HAVE_GTK_AND_PTHREAD
353/* When compiled with GTK and running under Gnome, multiple threads meay be
354 created. Keep track of our main thread to make sure signals are delivered
355 to it (see syssignal.h). */
356
357pthread_t main_thread;
358#endif
359
4fab758d 360
7317d9e8 361#ifdef SIGUSR1
7317d9e8
RS
362SIGTYPE
363handle_USR1_signal (sig)
364 int sig;
365{
5bda49c6
RS
366 struct input_event buf;
367
333f1b6f 368 SIGNAL_THREAD_CHECK (sig);
75816372 369 bzero (&buf, sizeof buf);
5b50dae1 370 buf.kind = USER_SIGNAL_EVENT;
74c2d1c6 371 buf.frame_or_window = selected_frame;
5bda49c6
RS
372
373 kbd_buffer_store_event (&buf);
7317d9e8 374}
5bda49c6 375#endif /* SIGUSR1 */
fcf01ad3 376
7317d9e8 377#ifdef SIGUSR2
7317d9e8
RS
378SIGTYPE
379handle_USR2_signal (sig)
380 int sig;
381{
5bda49c6
RS
382 struct input_event buf;
383
333f1b6f 384 SIGNAL_THREAD_CHECK (sig);
75816372 385 bzero (&buf, sizeof buf);
5b50dae1 386 buf.kind = USER_SIGNAL_EVENT;
e2fa15ff 387 buf.code = 1;
74c2d1c6 388 buf.frame_or_window = selected_frame;
5bda49c6
RS
389
390 kbd_buffer_store_event (&buf);
7317d9e8 391}
5bda49c6 392#endif /* SIGUSR2 */
7317d9e8 393
7db35a48 394/* Handle bus errors, invalid instruction, etc. */
2447c626 395SIGTYPE
f927c5ae
JB
396fatal_error_signal (sig)
397 int sig;
398{
333f1b6f 399 SIGNAL_THREAD_CHECK (sig);
f927c5ae
JB
400 fatal_error_code = sig;
401 signal (sig, SIG_DFL);
402
061b7f94
RS
403 TOTALLY_UNBLOCK_INPUT;
404
f927c5ae 405 /* If fatal error occurs in code below, avoid infinite recursion. */
8090eb09
JB
406 if (! fatal_error_in_progress)
407 {
408 fatal_error_in_progress = 1;
f927c5ae 409
f7ab4e3d 410 shut_down_emacs (sig, 0, Qnil);
8090eb09 411 }
f927c5ae
JB
412
413#ifdef VMS
f927c5ae
JB
414 LIB$STOP (SS$_ABORT);
415#else
8090eb09
JB
416 /* Signal the same code; this time it will really be fatal.
417 Remember that since we're in a signal handler, the signal we're
418 going to send is probably blocked, so we have to unblock it if we
419 want to really receive it. */
29b89fe0 420#ifndef MSDOS
a90538cb 421 sigunblock (sigmask (fatal_error_code));
29b89fe0 422#endif
4fab758d
GM
423
424 if (fatal_error_signal_hook)
425 fatal_error_signal_hook ();
7db35a48 426
f927c5ae
JB
427 kill (getpid (), fatal_error_code);
428#endif /* not VMS */
429}
271c7b7c
RS
430
431#ifdef SIGDANGER
432
16c323ee 433/* Handler for SIGDANGER. */
271c7b7c
RS
434SIGTYPE
435memory_warning_signal (sig)
436 int sig;
437{
438 signal (sig, memory_warning_signal);
333f1b6f 439 SIGNAL_THREAD_CHECK (sig);
271c7b7c
RS
440
441 malloc_warning ("Operating system warns that virtual memory is running low.\n");
55796183
RS
442
443 /* It might be unsafe to call do_auto_save now. */
444 force_auto_save_soon ();
271c7b7c
RS
445}
446#endif
fcf01ad3
RS
447
448/* We define abort, rather than using it from the library,
c9fe9cce 449 so that GDB can return from a breakpoint here.
7db35a48 450 MSDOS has its own definition in msdos.c. */
fcf01ad3 451
37e2fdd2 452#if ! defined (DOS_NT) && ! defined (NO_ABORT)
ca9c0567
PE
453
454#ifndef ABORT_RETURN_TYPE
455#define ABORT_RETURN_TYPE void
456#endif
457
458ABORT_RETURN_TYPE
fcf01ad3
RS
459abort ()
460{
461 kill (getpid (), SIGABRT);
37e2fdd2
RS
462 /* This shouldn't be executed, but it prevents a warning. */
463 exit (1);
fcf01ad3 464}
c9fe9cce 465#endif
fcf01ad3 466
f927c5ae 467\f
7db35a48 468/* Code for dealing with Lisp access to the Unix command line. */
f927c5ae 469
dfcf069d 470static void
f927c5ae
JB
471init_cmdargs (argc, argv, skip_args)
472 int argc;
473 char **argv;
474 int skip_args;
475{
476 register int i;
213d0b1f 477 Lisp_Object name, dir, tem;
aed13378 478 int count = SPECPDL_INDEX ();
213d0b1f 479 Lisp_Object raw_name;
f927c5ae 480
e29f86e4
RS
481 initial_argv = argv;
482 initial_argc = argc;
483
213d0b1f
RS
484 raw_name = build_string (argv[0]);
485
486 /* Add /: to the front of the name
487 if it would otherwise be treated as magic. */
488 tem = Ffind_file_name_handler (raw_name, Qt);
489 if (! NILP (tem))
490 raw_name = concat2 (build_string ("/:"), raw_name);
491
492 Vinvocation_name = Ffile_name_nondirectory (raw_name);
493 Vinvocation_directory = Ffile_name_directory (raw_name);
494
ace40a69
RS
495 /* If we got no directory in argv[0], search PATH to find where
496 Emacs actually came from. */
497 if (NILP (Vinvocation_directory))
498 {
499 Lisp_Object found;
500 int yes = openp (Vexec_path, Vinvocation_name,
10c0915e 501 Vexec_suffixes, &found, make_number (X_OK));
e443f843 502 if (yes == 1)
213d0b1f
RS
503 {
504 /* Add /: to the front of the name
505 if it would otherwise be treated as magic. */
506 tem = Ffind_file_name_handler (found, Qt);
507 if (! NILP (tem))
508 found = concat2 (build_string ("/:"), found);
509 Vinvocation_directory = Ffile_name_directory (found);
510 }
ace40a69 511 }
59653951 512
4133b300
RS
513 if (!NILP (Vinvocation_directory)
514 && NILP (Ffile_name_absolute_p (Vinvocation_directory)))
213d0b1f
RS
515 /* Emacs was started with relative path, like ./emacs.
516 Make it absolute. */
4133b300
RS
517 Vinvocation_directory = Fexpand_file_name (Vinvocation_directory, Qnil);
518
07f4d123
RS
519 Vinstallation_directory = Qnil;
520
521 if (!NILP (Vinvocation_directory))
522 {
523 dir = Vinvocation_directory;
524 name = Fexpand_file_name (Vinvocation_name, dir);
525 while (1)
526 {
f5ab9736 527 Lisp_Object tem, lib_src_exists;
07f4d123
RS
528 Lisp_Object etc_exists, info_exists;
529
f5ab9736
RS
530 /* See if dir contains subdirs for use by Emacs.
531 Check for the ones that would exist in a build directory,
532 not including lisp and info. */
533 tem = Fexpand_file_name (build_string ("lib-src"), dir);
534 lib_src_exists = Ffile_exists_p (tem);
de004cc6 535
70344b34 536#ifdef MSDOS
de004cc6
RS
537 /* MSDOS installations frequently remove lib-src, but we still
538 must set installation-directory, or else info won't find
539 its files (it uses the value of installation-directory). */
540 tem = Fexpand_file_name (build_string ("info"), dir);
541 info_exists = Ffile_exists_p (tem);
70344b34
EZ
542#else
543 info_exists = Qnil;
544#endif
de004cc6
RS
545
546 if (!NILP (lib_src_exists) || !NILP (info_exists))
07f4d123 547 {
f5ab9736
RS
548 tem = Fexpand_file_name (build_string ("etc"), dir);
549 etc_exists = Ffile_exists_p (tem);
550 if (!NILP (etc_exists))
07f4d123 551 {
f5ab9736
RS
552 Vinstallation_directory
553 = Ffile_name_as_directory (dir);
554 break;
07f4d123
RS
555 }
556 }
557
558 /* See if dir's parent contains those subdirs. */
f5ab9736
RS
559 tem = Fexpand_file_name (build_string ("../lib-src"), dir);
560 lib_src_exists = Ffile_exists_p (tem);
de004cc6 561
70344b34
EZ
562
563#ifdef MSDOS
564 /* See the MSDOS commentary above. */
de004cc6
RS
565 tem = Fexpand_file_name (build_string ("../info"), dir);
566 info_exists = Ffile_exists_p (tem);
70344b34
EZ
567#else
568 info_exists = Qnil;
569#endif
de004cc6
RS
570
571 if (!NILP (lib_src_exists) || !NILP (info_exists))
07f4d123 572 {
f5ab9736
RS
573 tem = Fexpand_file_name (build_string ("../etc"), dir);
574 etc_exists = Ffile_exists_p (tem);
575 if (!NILP (etc_exists))
07f4d123 576 {
f5ab9736
RS
577 tem = Fexpand_file_name (build_string (".."), dir);
578 Vinstallation_directory
579 = Ffile_name_as_directory (tem);
580 break;
07f4d123
RS
581 }
582 }
583
584 /* If the Emacs executable is actually a link,
585 next try the dir that the link points into. */
586 tem = Ffile_symlink_p (name);
587 if (!NILP (tem))
588 {
260ec24d 589 name = Fexpand_file_name (tem, dir);
07f4d123
RS
590 dir = Ffile_name_directory (name);
591 }
592 else
593 break;
594 }
595 }
596
f927c5ae
JB
597 Vcommand_line_args = Qnil;
598
599 for (i = argc - 1; i >= 0; i--)
600 {
601 if (i == 0 || i > skip_args)
a520393d
KH
602 /* For the moment, we keep arguments as is in unibyte strings.
603 They are decoded in the function command-line after we know
604 locale-coding-system. */
f927c5ae 605 Vcommand_line_args
68db37aa 606 = Fcons (make_unibyte_string (argv[i], strlen (argv[i])),
a520393d 607 Vcommand_line_args);
f927c5ae 608 }
213d0b1f
RS
609
610 unbind_to (count, Qnil);
f927c5ae 611}
59653951
JB
612
613DEFUN ("invocation-name", Finvocation_name, Sinvocation_name, 0, 0, 0,
7db35a48
PJ
614 doc: /* Return the program name that was used to run Emacs.
615Any directory names are omitted. */)
616 ()
59653951
JB
617{
618 return Fcopy_sequence (Vinvocation_name);
619}
620
ace40a69 621DEFUN ("invocation-directory", Finvocation_directory, Sinvocation_directory,
7db35a48
PJ
622 0, 0, 0,
623 doc: /* Return the directory name in which the Emacs executable was located. */)
624 ()
ace40a69
RS
625{
626 return Fcopy_sequence (Vinvocation_directory);
627}
628
f927c5ae
JB
629\f
630#ifdef VMS
631#ifdef LINK_CRTL_SHARE
34035df3 632#ifdef SHARABLE_LIB_BUG
f927c5ae 633extern noshare char **environ;
34035df3 634#endif /* SHARABLE_LIB_BUG */
f927c5ae
JB
635#endif /* LINK_CRTL_SHARE */
636#endif /* VMS */
637
0269dedb
RS
638#ifdef HAVE_TZSET
639/* A valid but unlikely value for the TZ environment value.
640 It is OK (though a bit slower) if the user actually chooses this value. */
641static char dump_tz[] = "UtC0";
642#endif
643
a90538cb 644#ifndef ORDINARY_LINK
efd241cc
RS
645/* We don't include crtbegin.o and crtend.o in the link,
646 so these functions and variables might be missed.
647 Provide dummy definitions to avoid error.
648 (We don't have any real constructors or destructors.) */
649#ifdef __GNUC__
46e65b73 650#ifndef GCC_CTORS_IN_LIBC
dfcf069d 651void __do_global_ctors ()
efd241cc 652{}
dfcf069d 653void __do_global_ctors_aux ()
c83a7064 654{}
dfcf069d 655void __do_global_dtors ()
33143604 656{}
554061d8 657/* GNU/Linux has a bug in its library; avoid an error. */
8a2a6032 658#ifndef GNU_LINUX
c83a7064 659char * __CTOR_LIST__[2] = { (char *) (-1), 0 };
64c1864a 660#endif
c83a7064 661char * __DTOR_LIST__[2] = { (char *) (-1), 0 };
46e65b73 662#endif /* GCC_CTORS_IN_LIBC */
dfcf069d 663void __main ()
efd241cc 664{}
efd241cc 665#endif /* __GNUC__ */
a90538cb 666#endif /* ORDINARY_LINK */
efd241cc 667
e2925360
KH
668/* Test whether the next argument in ARGV matches SSTR or a prefix of
669 LSTR (at least MINLEN characters). If so, then if VALPTR is non-null
670 (the argument is supposed to have a value) store in *VALPTR either
671 the next argument or the portion of this one after the equal sign.
672 ARGV is read starting at position *SKIPPTR; this index is advanced
673 by the number of arguments used.
674
675 Too bad we can't just use getopt for all of this, but we don't have
676 enough information to do it right. */
081bef73 677
e2925360 678static int
df6530f8 679argmatch (argv, argc, sstr, lstr, minlen, valptr, skipptr)
e2925360 680 char **argv;
df6530f8 681 int argc;
e2925360
KH
682 char *sstr;
683 char *lstr;
684 int minlen;
685 char **valptr;
686 int *skipptr;
687{
6bbd7a29 688 char *p = NULL;
e2925360 689 int arglen;
df6530f8
RS
690 char *arg;
691
692 /* Don't access argv[argc]; give up in advance. */
693 if (argc <= *skipptr + 1)
694 return 0;
695
696 arg = argv[*skipptr+1];
e2925360
KH
697 if (arg == NULL)
698 return 0;
699 if (strcmp (arg, sstr) == 0)
700 {
701 if (valptr != NULL)
702 {
703 *valptr = argv[*skipptr+2];
704 *skipptr += 2;
705 }
706 else
707 *skipptr += 1;
708 return 1;
709 }
710 arglen = (valptr != NULL && (p = index (arg, '=')) != NULL
711 ? p - arg : strlen (arg));
c03e1113 712 if (lstr == 0 || arglen < minlen || strncmp (arg, lstr, arglen) != 0)
e2925360
KH
713 return 0;
714 else if (valptr == NULL)
715 {
716 *skipptr += 1;
717 return 1;
718 }
719 else if (p != NULL)
720 {
721 *valptr = p+1;
722 *skipptr += 1;
723 return 1;
724 }
725 else if (argv[*skipptr+2] != NULL)
726 {
727 *valptr = argv[*skipptr+2];
728 *skipptr += 2;
729 return 1;
730 }
731 else
732 {
733 return 0;
734 }
735}
736
b6779252 737#ifdef DOUG_LEA_MALLOC
f927c5ae 738
b6779252
KH
739/* malloc can be invoked even before main (e.g. by the dynamic
740 linker), so the dumped malloc state must be restored as early as
741 possible using this special hook. */
742
743static void
744malloc_initialize_hook ()
745{
1f9c3929 746#ifndef USE_CRT_DLL
b6779252 747 extern char **environ;
1f9c3929 748#endif
6000fe37 749
15aaf1b5
RS
750 if (initialized)
751 {
7c9cd446
AS
752 if (!malloc_using_checking)
753 /* Work around a bug in glibc's malloc. MALLOC_CHECK_ must be
754 ignored if the heap to be restored was constructed without
d942e12a
AS
755 malloc checking. Can't use unsetenv, since that calls malloc. */
756 {
757 char **p;
758
a57c4026 759 for (p = environ; p && *p; p++)
d942e12a
AS
760 if (strncmp (*p, "MALLOC_CHECK_=", 14) == 0)
761 {
762 do
763 *p = p[1];
764 while (*++p);
765 break;
766 }
767 }
b6779252 768
15aaf1b5 769 malloc_set_state (malloc_state_ptr);
68db37aa 770#ifndef XMALLOC_OVERRUN_CHECK
15aaf1b5 771 free (malloc_state_ptr);
68db37aa 772#endif
15aaf1b5 773 }
7c9cd446 774 else
dede2792
JD
775 {
776 if (my_heap_start == 0)
777 my_heap_start = sbrk (0);
778 malloc_using_checking = getenv ("MALLOC_CHECK_") != NULL;
779 }
b6779252
KH
780}
781
782void (*__malloc_initialize_hook) () = malloc_initialize_hook;
783
784#endif /* DOUG_LEA_MALLOC */
785
d883731c
PJ
786
787#define REPORT_EMACS_BUG_ADDRESS "bug-gnu-emacs@gnu.org"
788#define REPORT_EMACS_BUG_PRETEST_ADDRESS "emacs-pretest-bug@gnu.org"
789
790/* This function is used to determine an address to which bug report should
791 be sent. */
792
400d6fa9
PJ
793char *
794bug_reporting_address ()
d883731c 795{
400d6fa9 796 int count = 0;
d883731c
PJ
797 Lisp_Object temp;
798 char *string;
799
800 temp = Fsymbol_value (intern ("emacs-version"));
801
802 /* When `emacs-version' is invalid, use normal address. */
803 if (!STRINGP(temp))
804 return REPORT_EMACS_BUG_ADDRESS;
805
d5db4077 806 string = SDATA (temp);
d883731c 807
400d6fa9
PJ
808 /* Count dots in `emacs-version'. */
809 while (*string)
810 {
811 if (*string == '.')
812 count++;
813 string++;
814 }
d883731c
PJ
815
816 /* When `emacs-version' has at least three dots, it is development or
817 pretest version of Emacs. */
400d6fa9 818 return count >= 3 ? REPORT_EMACS_BUG_PRETEST_ADDRESS : REPORT_EMACS_BUG_ADDRESS;
d883731c
PJ
819}
820
821
b6779252
KH
822/* ARGSUSED */
823int
3861bdcd
DL
824main (argc, argv
825#ifdef VMS
826, envp
827#endif
828)
b6779252
KH
829 int argc;
830 char **argv;
3861bdcd 831#ifdef VMS
b6779252 832 char **envp;
3861bdcd 833#endif
b6779252 834{
2313132f 835#if GC_MARK_STACK
39ec21ea
GM
836 Lisp_Object dummy;
837#endif
b6779252 838 char stack_bottom_variable;
68c45bf0 839 int do_initial_setlocale;
b6779252 840 int skip_args = 0;
1f9c3929 841#ifndef USE_CRT_DLL
b6779252 842 extern int errno;
1f9c3929 843#endif
b6779252
KH
844#ifdef HAVE_SETRLIMIT
845 struct rlimit rlim;
846#endif
847 int no_loadup = 0;
6e910e07 848 char *junk = 0;
b6779252 849
2313132f 850#if GC_MARK_STACK
39ec21ea
GM
851 extern Lisp_Object *stack_base;
852 stack_base = &dummy;
853#endif
854
dede2792
JD
855 if (!initialized)
856 {
857 extern char my_endbss[];
858 extern char *my_endbss_static;
859
860 if (my_heap_start == 0)
861 my_heap_start = sbrk (0);
862
863 heap_bss_diff = (char *)my_heap_start - max (my_endbss, my_endbss_static);
864 }
865
b6779252
KH
866#ifdef LINUX_SBRK_BUG
867 __sbrk (1);
15aaf1b5
RS
868#endif
869
d785cf9e
RS
870#ifdef RUN_TIME_REMAP
871 if (initialized)
872 run_time_remap (argv[0]);
873#endif
874
3fb79984 875#ifdef MAC_OSX
e0f712ba
AC
876 if (!initialized)
877 unexec_init_emacs_zone ();
878#endif
879
081bef73 880 sort_args (argc, argv);
956e3c7e
RS
881 argc = 0;
882 while (argv[argc]) argc++;
081bef73 883
3270ae6e
KH
884 if (argmatch (argv, argc, "-version", "--version", 3, NULL, &skip_args)
885 /* We don't know the version number unless this is a dumped Emacs.
886 So ignore --version otherwise. */
887 && initialized)
1702afef
RS
888 {
889 Lisp_Object tem;
890 tem = Fsymbol_value (intern ("emacs-version"));
891 if (!STRINGP (tem))
892 {
893 fprintf (stderr, "Invalid value of `emacs-version'\n");
894 exit (1);
895 }
896 else
897 {
d5db4077 898 printf ("GNU Emacs %s\n", SDATA (tem));
73ccc854 899 printf ("Copyright (C) 2004 Free Software Foundation, Inc.\n");
b455c665
RS
900 printf ("GNU Emacs comes with ABSOLUTELY NO WARRANTY.\n");
901 printf ("You may redistribute copies of Emacs\n");
902 printf ("under the terms of the GNU General Public License.\n");
903 printf ("For more information about these matters, ");
94487c4e 904 printf ("see the file named COPYING.\n");
1702afef
RS
905 exit (0);
906 }
907 }
908
dede2792
JD
909#ifdef HAVE_PERSONALITY_LINUX32
910 /* See if there is a gap between the end of BSS and the heap.
911 In that case, set personality and exec ourself again. */
912 if (!initialized
913 && (strcmp (argv[argc-1], "dump") == 0
914 || strcmp (argv[argc-1], "bootstrap") == 0)
915 && heap_bss_diff > MAX_HEAP_BSS_DIFF)
916 {
917 if (! getenv ("EMACS_HEAP_EXEC"))
918 {
919 /* Set this so we only do this once. */
920 putenv("EMACS_HEAP_EXEC=true");
711877f3
MY
921
922 /* A flag to turn off address randomization which is introduced
923 in linux kernel shipped with fedora core 4 */
924#define ADD_NO_RANDOMIZE 0x0040000
925 personality (PER_LINUX32 | ADD_NO_RANDOMIZE);
926#undef ADD_NO_RANDOMIZE
927
dede2792
JD
928 execvp (argv[0], argv);
929
930 /* If the exec fails, try to dump anyway. */
931 perror ("execvp");
932 }
933 }
934#endif /* HAVE_PERSONALITY_LINUX32 */
935
936
f927c5ae
JB
937/* Map in shared memory, if we are using that. */
938#ifdef HAVE_SHM
df6530f8 939 if (argmatch (argv, argc, "-nl", "--no-shared-memory", 6, NULL, &skip_args))
f927c5ae
JB
940 {
941 map_in_data (0);
942 /* The shared memory was just restored, which clobbered this. */
943 skip_args = 1;
944 }
945 else
946 {
947 map_in_data (1);
948 /* The shared memory was just restored, which clobbered this. */
949 skip_args = 0;
950 }
951#endif
952
19a36ec6 953#ifdef NeXT
b9df9faa
KH
954 {
955 extern int malloc_cookie;
956 /* This helps out unexnext.c. */
957 if (initialized)
958 if (malloc_jumpstart (malloc_cookie) != 0)
959 printf ("malloc jumpstart failed!\n");
960 }
19a36ec6
RS
961#endif /* NeXT */
962
e0f712ba
AC
963#ifdef MAC_OSX
964 /* Skip process serial number passed in the form -psn_x_y as
965 command-line argument. */
966 if (argc > skip_args + 1 && strncmp (argv[skip_args+1], "-psn_", 5) == 0)
967 skip_args++;
968#endif /* MAC_OSX */
969
f927c5ae 970#ifdef VMS
7db35a48 971 /* If -map specified, map the data file in. */
e2925360
KH
972 {
973 char *file;
70646bb5 974 if (argmatch (argv, argc, "-map", "--map-data", 3, &file, &skip_args))
e2925360
KH
975 mapin_data (file);
976 }
f927c5ae
JB
977
978#ifdef LINK_CRTL_SHARE
34035df3 979#ifdef SHARABLE_LIB_BUG
7db35a48 980 /* Bletcherous shared libraries! */
f927c5ae
JB
981 if (!stdin)
982 stdin = fdopen (0, "r");
983 if (!stdout)
984 stdout = fdopen (1, "w");
985 if (!stderr)
986 stderr = fdopen (2, "w");
987 if (!environ)
988 environ = envp;
34035df3 989#endif /* SHARABLE_LIB_BUG */
f927c5ae
JB
990#endif /* LINK_CRTL_SHARE */
991#endif /* VMS */
992
ea2acec5 993#if defined (HAVE_SETRLIMIT) && defined (RLIMIT_STACK)
6c2935e9
RS
994 /* Extend the stack space available.
995 Don't do that if dumping, since some systems (e.g. DJGPP)
996 might define a smaller stack limit at that time. */
997 if (1
998#ifndef CANNOT_DUMP
999 && (!noninteractive || initialized)
1000#endif
1001 && !getrlimit (RLIMIT_STACK, &rlim))
53c58b5d 1002 {
509a8fcd 1003 long newlim;
6c2935e9 1004 extern int re_max_failures;
03effc23
KH
1005 /* Approximate the amount regex.c needs per unit of re_max_failures. */
1006 int ratio = 20 * sizeof (char *);
1007 /* Then add 33% to cover the size of the smaller stacks that regex.c
1008 successively allocates and discards, on its way to the maximum. */
1009 ratio += ratio / 3;
1010 /* Add in some extra to cover
1011 what we're likely to use for other reasons. */
1012 newlim = re_max_failures * ratio + 200000;
d0381a7f
RS
1013#ifdef __NetBSD__
1014 /* NetBSD (at least NetBSD 1.2G and former) has a bug in its
1015 stack allocation routine for new process that the allocation
1016 fails if stack limit is not on page boundary. So, round up the
1017 new limit to page boundary. */
1018 newlim = (newlim + getpagesize () - 1) / getpagesize () * getpagesize();
1019#endif
509a8fcd 1020 if (newlim > rlim.rlim_max)
6c2935e9
RS
1021 {
1022 newlim = rlim.rlim_max;
03effc23
KH
1023 /* Don't let regex.c overflow the stack we have. */
1024 re_max_failures = (newlim - 200000) / ratio;
6c2935e9 1025 }
509a8fcd
RS
1026 if (rlim.rlim_cur < newlim)
1027 rlim.rlim_cur = newlim;
1028
53c58b5d
RS
1029 setrlimit (RLIMIT_STACK, &rlim);
1030 }
ea2acec5 1031#endif /* HAVE_SETRLIMIT and RLIMIT_STACK */
53c58b5d 1032
f927c5ae
JB
1033 /* Record (approximately) where the stack begins. */
1034 stack_bottom = &stack_bottom_variable;
1035
f927c5ae
JB
1036#ifdef USG_SHARED_LIBRARIES
1037 if (bss_end)
1d233b80 1038 brk ((void *)bss_end);
f927c5ae
JB
1039#endif
1040
1041 clearerr (stdin);
9ae8f997 1042
f927c5ae 1043#ifndef SYSTEM_MALLOC
bf7f4e90
RS
1044 /* Arrange to get warning messages as memory fills up. */
1045 memory_warnings (0, malloc_warning);
9ac0d9e0 1046
f5a3c8c4
AI
1047 /* Call malloc at least once, to run the initial __malloc_hook.
1048 Also call realloc and free for consistency. */
1049 free (realloc (malloc (4), 4));
bf7f4e90 1050
06ca62eb 1051# ifndef SYNC_INPUT
bf7f4e90
RS
1052 /* Arrange to disable interrupt input inside malloc etc. */
1053 uninterrupt_malloc ();
06ca62eb 1054# endif /* not SYNC_INPUT */
f927c5ae
JB
1055#endif /* not SYSTEM_MALLOC */
1056
333f1b6f
JD
1057#ifdef HAVE_GTK_AND_PTHREAD
1058 main_thread = pthread_self ();
1059#endif /* HAVE_GTK_AND_PTHREAD */
1060
edd3ff1d 1061#if defined (MSDOS) || defined (WINDOWSNT)
29b89fe0
RS
1062 /* We do all file input/output as binary files. When we need to translate
1063 newlines, we do that manually. */
1064 _fmode = O_BINARY;
edd3ff1d 1065#endif /* MSDOS || WINDOWSNT */
18198bb2 1066
edd3ff1d 1067#ifdef MSDOS
18198bb2
RS
1068#if __DJGPP__ >= 2
1069 if (!isatty (fileno (stdin)))
1070 setmode (fileno (stdin), O_BINARY);
1071 if (!isatty (fileno (stdout)))
1072 {
1073 fflush (stdout);
1074 setmode (fileno (stdout), O_BINARY);
1075 }
1076#else /* not __DJGPP__ >= 2 */
29b89fe0
RS
1077 (stdin)->_flag &= ~_IOTEXT;
1078 (stdout)->_flag &= ~_IOTEXT;
1079 (stderr)->_flag &= ~_IOTEXT;
18198bb2 1080#endif /* not __DJGPP__ >= 2 */
29b89fe0
RS
1081#endif /* MSDOS */
1082
a422068f 1083#ifdef SET_EMACS_PRIORITY
3005da00 1084 if (emacs_priority)
5aa7f46a 1085 nice (emacs_priority);
f927c5ae 1086 setuid (getuid ());
a422068f 1087#endif /* SET_EMACS_PRIORITY */
f927c5ae 1088
68c45bf0
PE
1089 /* Skip initial setlocale if LC_ALL is "C", as it's not needed in that case.
1090 The build procedure uses this while dumping, to ensure that the
1091 dumped Emacs does not have its system locale tables initialized,
1092 as that might cause screwups when the dumped Emacs starts up. */
1093 {
1094 char *lc_all = getenv ("LC_ALL");
1095 do_initial_setlocale = ! lc_all || strcmp (lc_all, "C");
1096 }
1097
1098 /* Set locale now, so that initial error messages are localized properly.
1099 fixup_locale must wait until later, since it builds strings. */
1100 if (do_initial_setlocale)
1101 setlocale (LC_ALL, "");
1102
d8b3a65d 1103#ifdef EXTRA_INITIALIZE
a9260219 1104 EXTRA_INITIALIZE;
d8b3a65d
RS
1105#endif
1106
f927c5ae
JB
1107 inhibit_window_system = 0;
1108
7db35a48 1109 /* Handle the -t switch, which specifies filename to use as terminal. */
956e3c7e
RS
1110 while (1)
1111 {
1112 char *term;
1113 if (argmatch (argv, argc, "-t", "--terminal", 4, &term, &skip_args))
1114 {
1115 int result;
68c45bf0
PE
1116 emacs_close (0);
1117 emacs_close (1);
1118 result = emacs_open (term, O_RDWR, 0);
956e3c7e
RS
1119 if (result < 0)
1120 {
1121 char *errstring = strerror (errno);
186486eb 1122 fprintf (stderr, "%s: %s: %s\n", argv[0], term, errstring);
956e3c7e
RS
1123 exit (1);
1124 }
1125 dup (0);
1126 if (! isatty (0))
1127 {
186486eb 1128 fprintf (stderr, "%s: %s: not a tty\n", argv[0], term);
956e3c7e
RS
1129 exit (1);
1130 }
1131 fprintf (stderr, "Using %s\n", term);
8ba50e1a 1132#ifdef HAVE_WINDOW_SYSTEM
956e3c7e 1133 inhibit_window_system = 1; /* -t => -nw */
f927c5ae 1134#endif
956e3c7e
RS
1135 }
1136 else
1137 break;
1138 }
1139
400d6fa9
PJ
1140 /* Command line option --no-windows is deprecated and thus not mentioned
1141 in the manual and usage informations. */
1142 if (argmatch (argv, argc, "-nw", "--no-window-system", 6, NULL, &skip_args)
1143 || argmatch (argv, argc, "-nw", "--no-windows", 6, NULL, &skip_args))
e2925360 1144 inhibit_window_system = 1;
f927c5ae 1145
e2925360 1146 /* Handle the -batch switch, which means don't do interactive display. */
f927c5ae 1147 noninteractive = 0;
df6530f8 1148 if (argmatch (argv, argc, "-batch", "--batch", 5, NULL, &skip_args))
55f4edbc
RS
1149 {
1150 noninteractive = 1;
1151 Vundo_outer_limit = Qnil;
1152 }
6e910e07
RS
1153 if (argmatch (argv, argc, "-script", "--script", 3, &junk, &skip_args))
1154 {
1155 noninteractive = 1; /* Set batch mode. */
1156 /* Convert --script to -l, un-skip it, and sort again so that -l will be
1157 handled in proper sequence. */
1158 argv[skip_args - 1] = "-l";
1159 skip_args -= 2;
1160 sort_args (argc, argv);
1161 }
e2925360 1162
7db35a48 1163 /* Handle the --help option, which gives a usage message. */
df6530f8 1164 if (argmatch (argv, argc, "-help", "--help", 3, NULL, &skip_args))
f927c5ae 1165 {
f8125c39
EZ
1166 printf (USAGE1, argv[0], USAGE2);
1167 printf (USAGE3);
1168 printf (USAGE4, bug_reporting_address ());
e2925360 1169 exit (0);
f927c5ae
JB
1170 }
1171
edb85f59
RS
1172 if (! noninteractive)
1173 {
1174#ifdef BSD_PGRPS
1175 if (initialized)
1176 {
1177 inherited_pgroup = EMACS_GETPGRP (0);
1178 setpgrp (0, getpid ());
1179 }
1180#else
1181#if defined (USG5) && defined (INTERRUPT_INPUT)
1182 setpgrp ();
1183#endif
1184#endif
1185 }
1186
fb8e9847 1187 init_signals ();
fb8e9847 1188
1efa2983
KH
1189 /* Don't catch SIGHUP if dumping. */
1190 if (1
1191#ifndef CANNOT_DUMP
1192 && initialized
1193#endif
1194 )
1195 {
57e3d22a 1196 sigblock (sigmask (SIGHUP));
1efa2983
KH
1197 /* In --batch mode, don't catch SIGHUP if already ignored.
1198 That makes nohup work. */
1199 if (! noninteractive
1200 || signal (SIGHUP, SIG_IGN) != SIG_IGN)
1201 signal (SIGHUP, fatal_error_signal);
57e3d22a 1202 sigunblock (sigmask (SIGHUP));
1efa2983
KH
1203 }
1204
f927c5ae
JB
1205 if (
1206#ifndef CANNOT_DUMP
1207 ! noninteractive || initialized
1208#else
1209 1
1210#endif
1211 )
1212 {
1efa2983 1213 /* Don't catch these signals in batch mode if dumping.
f927c5ae
JB
1214 On some machines, this sets static data that would make
1215 signal fail to work right when the dumped Emacs is run. */
f927c5ae
JB
1216 signal (SIGQUIT, fatal_error_signal);
1217 signal (SIGILL, fatal_error_signal);
1218 signal (SIGTRAP, fatal_error_signal);
7317d9e8
RS
1219#ifdef SIGUSR1
1220 signal (SIGUSR1, handle_USR1_signal);
1221#ifdef SIGUSR2
1222 signal (SIGUSR2, handle_USR2_signal);
1223#endif
1224#endif
99e372cd
RS
1225#ifdef SIGABRT
1226 signal (SIGABRT, fatal_error_signal);
1227#endif
1228#ifdef SIGHWE
1229 signal (SIGHWE, fatal_error_signal);
1230#endif
1231#ifdef SIGPRE
1232 signal (SIGPRE, fatal_error_signal);
1233#endif
1234#ifdef SIGORE
1235 signal (SIGORE, fatal_error_signal);
1236#endif
1237#ifdef SIGUME
1238 signal (SIGUME, fatal_error_signal);
1239#endif
1240#ifdef SIGDLK
1241 signal (SIGDLK, fatal_error_signal);
1242#endif
1243#ifdef SIGCPULIM
1244 signal (SIGCPULIM, fatal_error_signal);
1245#endif
a90538cb
JB
1246#ifdef SIGIOT
1247 /* This is missing on some systems - OS/2, for example. */
f927c5ae 1248 signal (SIGIOT, fatal_error_signal);
a90538cb 1249#endif
f927c5ae
JB
1250#ifdef SIGEMT
1251 signal (SIGEMT, fatal_error_signal);
1252#endif
1253 signal (SIGFPE, fatal_error_signal);
00eaaa32 1254#ifdef SIGBUS
f927c5ae 1255 signal (SIGBUS, fatal_error_signal);
00eaaa32 1256#endif
f927c5ae 1257 signal (SIGSEGV, fatal_error_signal);
00eaaa32 1258#ifdef SIGSYS
f927c5ae 1259 signal (SIGSYS, fatal_error_signal);
00eaaa32 1260#endif
f927c5ae
JB
1261 signal (SIGTERM, fatal_error_signal);
1262#ifdef SIGXCPU
1263 signal (SIGXCPU, fatal_error_signal);
1264#endif
1265#ifdef SIGXFSZ
1266 signal (SIGXFSZ, fatal_error_signal);
1267#endif /* SIGXFSZ */
1268
271c7b7c
RS
1269#ifdef SIGDANGER
1270 /* This just means available memory is getting low. */
1271 signal (SIGDANGER, memory_warning_signal);
1272#endif
1273
f927c5ae 1274#ifdef AIX
56e034fa
RS
1275/* 20 is SIGCHLD, 21 is SIGTTIN, 22 is SIGTTOU. */
1276 signal (SIGXCPU, fatal_error_signal);
0aef8561 1277#ifndef _I386
f927c5ae 1278 signal (SIGIOINT, fatal_error_signal);
0aef8561 1279#endif
f927c5ae
JB
1280 signal (SIGGRANT, fatal_error_signal);
1281 signal (SIGRETRACT, fatal_error_signal);
1282 signal (SIGSOUND, fatal_error_signal);
1283 signal (SIGMSG, fatal_error_signal);
1284#endif /* AIX */
1285 }
1286
1287 noninteractive1 = noninteractive;
1288
7db35a48 1289/* Perform basic initializations (not merely interning symbols). */
f927c5ae
JB
1290
1291 if (!initialized)
1292 {
1293 init_alloc_once ();
1294 init_obarray ();
1295 init_eval_once ();
270ce821
KH
1296 init_charset_once ();
1297 init_coding_once ();
f927c5ae 1298 init_syntax_once (); /* Create standard syntax table. */
270ce821 1299 init_category_once (); /* Create standard category table. */
7db35a48 1300 /* Must be done before init_buffer. */
f927c5ae 1301 init_casetab_once ();
7db35a48
PJ
1302 init_buffer_once (); /* Create buffer table and some buffers. */
1303 init_minibuf_once (); /* Create list of minibuffers. */
1304 /* Must precede init_window_once. */
1305
90d920b6
GM
1306 /* Call syms_of_xfaces before init_window_once because that
1307 function creates Vterminal_frame. Termcap frames now use
1308 faces, and the face implementation uses some symbols as
1309 face names. */
90d920b6 1310 syms_of_xfaces ();
7a18af49
KR
1311 /* Call syms_of_keyboard before init_window_once because
1312 keyboard sets up symbols that include some face names that
1313 the X support will want to use. This can happen when
1314 CANNOT_DUMP is defined. */
1315 syms_of_keyboard ();
90d920b6 1316
e0f712ba 1317#ifdef MAC_OS8
c1e279c2
AC
1318 /* init_window_once calls make_terminal_frame which on Mac OS
1319 creates a full-fledge output_mac type frame. This does not
1320 work correctly before syms_of_textprop, syms_of_macfns,
1321 syms_of_ccl, syms_of_fontset, syms_of_xterm, syms_of_search,
b15325b2 1322 syms_of_frame, mac_term_init, and init_keyboard have already
c1e279c2 1323 been called. */
1a578e9b
AC
1324 syms_of_textprop ();
1325 syms_of_macfns ();
1326 syms_of_ccl ();
1327 syms_of_fontset ();
1328 syms_of_macterm ();
1329 syms_of_macmenu ();
ab271aca 1330 syms_of_macselect ();
1a578e9b
AC
1331 syms_of_data ();
1332 syms_of_search ();
c1e279c2 1333 syms_of_frame ();
7db35a48 1334
34e1bbc2 1335 init_atimer ();
b15325b2 1336 mac_term_init (build_string ("Mac"), NULL, NULL);
1a578e9b
AC
1337 init_keyboard ();
1338#endif
1339
7db35a48 1340 init_window_once (); /* Init the window system. */
680256a8 1341 init_fileio_once (); /* Must precede any path manipulation. */
0fc4c63e
KS
1342#ifdef HAVE_WINDOW_SYSTEM
1343 init_fringe_once (); /* Swap bitmaps if necessary. */
1344#endif /* HAVE_WINDOW_SYSTEM */
f927c5ae
JB
1345 }
1346
1347 init_alloc ();
68c45bf0
PE
1348
1349 if (do_initial_setlocale)
1350 {
1351 fixup_locale ();
ca9c0567
PE
1352 Vsystem_messages_locale = Vprevious_system_messages_locale;
1353 Vsystem_time_locale = Vprevious_system_time_locale;
68c45bf0
PE
1354 }
1355
f927c5ae
JB
1356 init_eval ();
1357 init_data ();
ad067ea6 1358#ifdef CLASH_DETECTION
01f67d2c 1359 init_filelock ();
ad067ea6 1360#endif
34e1bbc2 1361#ifndef MAC_OS8
ab5d0358 1362 init_atimer ();
34e1bbc2 1363#endif
7074fde6 1364 running_asynch_code = 0;
0e956009 1365
a08a816a
RS
1366 /* Handle --unibyte and the EMACS_UNIBYTE envvar,
1367 but not while dumping. */
e721aa94 1368 if (1)
a08a816a
RS
1369 {
1370 int inhibit_unibyte = 0;
1371
1372 /* --multibyte overrides EMACS_UNIBYTE. */
1373 if (argmatch (argv, argc, "-no-unibyte", "--no-unibyte", 4, NULL, &skip_args)
e721aa94
SM
1374 || argmatch (argv, argc, "-multibyte", "--multibyte", 4, NULL, &skip_args)
1375 /* Ignore EMACS_UNIBYTE before dumping. */
1376 || (!initialized && noninteractive))
a08a816a
RS
1377 inhibit_unibyte = 1;
1378
1379 /* --unibyte requests that we set up to do everything with single-byte
1380 buffers and strings. We need to handle this before calling
1381 init_lread, init_editfns and other places that generate Lisp strings
1382 from text in the environment. */
c0218e1b
DL
1383 /* Actually this shouldn't be needed as of 20.4 in a generally
1384 unibyte environment. As handa says, environment values
1385 aren't now decoded; also existing buffers are now made
1386 unibyte during startup if .emacs sets unibyte. Tested with
1387 8-bit data in environment variables and /etc/passwd, setting
7db35a48 1388 unibyte and Latin-1 in .emacs. -- Dave Love */
a08a816a
RS
1389 if (argmatch (argv, argc, "-unibyte", "--unibyte", 4, NULL, &skip_args)
1390 || argmatch (argv, argc, "-no-multibyte", "--no-multibyte", 4, NULL, &skip_args)
1391 || (getenv ("EMACS_UNIBYTE") && !inhibit_unibyte))
1392 {
1393 Lisp_Object old_log_max;
1394 Lisp_Object symbol, tail;
1395
1396 symbol = intern ("default-enable-multibyte-characters");
1397 Fset (symbol, Qnil);
1398
6524291c
KH
1399 if (initialized)
1400 {
1401 /* Erase pre-dump messages in *Messages* now so no abort. */
1402 old_log_max = Vmessage_log_max;
1403 XSETFASTINT (Vmessage_log_max, 0);
1404 message_dolog ("", 0, 1, 0);
1405 Vmessage_log_max = old_log_max;
1406 }
a08a816a 1407
3e75bb9e 1408 for (tail = Vbuffer_alist; CONSP (tail);
7539e11f 1409 tail = XCDR (tail))
a08a816a
RS
1410 {
1411 Lisp_Object buffer;
1412
7539e11f 1413 buffer = Fcdr (XCAR (tail));
a08a816a
RS
1414 /* Verify that all buffers are empty now, as they
1415 ought to be. */
1416 if (BUF_Z (XBUFFER (buffer)) > BUF_BEG (XBUFFER (buffer)))
1417 abort ();
1418 /* It is safe to do this crudely in an empty buffer. */
1419 XBUFFER (buffer)->enable_multibyte_characters = Qnil;
1420 }
1421 }
1422 }
1423
956e3c7e 1424 no_loadup
b96f9fb7 1425 = argmatch (argv, argc, "-nl", "--no-loadup", 6, NULL, &skip_args);
956e3c7e
RS
1426
1427
1428#ifdef HAVE_X_WINDOWS
1429 /* Stupid kludge to catch command-line display spec. We can't
1430 handle this argument entirely in window system dependent code
1431 because we don't even know which window system dependent code
1432 to run until we've recognized this argument. */
1433 {
1434 char *displayname = 0;
956e3c7e
RS
1435 int count_before = skip_args;
1436
1437 /* Skip any number of -d options, but only use the last one. */
1438 while (1)
1439 {
1440 int count_before_this = skip_args;
1441
1442 if (argmatch (argv, argc, "-d", "--display", 3, &displayname, &skip_args))
1443 display_arg = 1;
1444 else if (argmatch (argv, argc, "-display", 0, 3, &displayname, &skip_args))
1445 display_arg = 1;
1446 else
1447 break;
1448
1449 count_before = count_before_this;
1450 }
1451
1452 /* If we have the form --display=NAME,
1453 convert it into -d name.
1454 This requires inserting a new element into argv. */
1455 if (displayname != 0 && skip_args - count_before == 1)
1456 {
1457 char **new = (char **) xmalloc (sizeof (char *) * (argc + 2));
1458 int j;
1459
1460 for (j = 0; j < count_before + 1; j++)
1461 new[j] = argv[j];
1462 new[count_before + 1] = "-d";
1463 new[count_before + 2] = displayname;
1464 for (j = count_before + 2; j <argc; j++)
1465 new[j + 1] = argv[j];
1466 argv = new;
1467 argc++;
1468 }
1469 /* Change --display to -d, when its arg is separate. */
1470 else if (displayname != 0 && skip_args > count_before
1471 && argv[count_before + 1][1] == '-')
1472 argv[count_before + 1] = "-d";
1473
1474 /* Don't actually discard this arg. */
1475 skip_args = count_before;
1476 }
1477#endif
1478
1479 /* argmatch must not be used after here,
1480 except when bulding temacs
1481 because the -d argument has not been skipped in skip_args. */
1482
29b89fe0
RS
1483#ifdef MSDOS
1484 /* Call early 'cause init_environment needs it. */
1485 init_dosfns ();
1486 /* Set defaults for several environment variables. */
18198bb2
RS
1487 if (initialized)
1488 init_environment (argc, argv, skip_args);
1489 else
d1fc6752 1490 tzset ();
18198bb2 1491#endif /* MSDOS */
29b89fe0 1492
8ba50e1a 1493#ifdef WINDOWSNT
9785d95b 1494 globals_of_w32 ();
8ba50e1a 1495 /* Initialize environment from registry settings. */
a3a58294 1496 init_environment (argv);
7db35a48 1497 init_ntproc (); /* must precede init_editfns. */
8ba50e1a
GV
1498#endif
1499
3ec33130 1500#if defined (MAC_OSX) && defined (HAVE_CARBON)
1000788b
AC
1501 if (initialized)
1502 init_mac_osx_environment ();
1503#endif
1504
0e956009
JB
1505 /* egetenv is a pretty low-level facility, which may get called in
1506 many circumstances; it seems flimsy to put off initializing it
1507 until calling init_callproc. */
1508 set_process_environment ();
93aed04d
RS
1509 /* AIX crashes are reported in system versions 3.2.3 and 3.2.4
1510 if this is not done. Do it after set_process_environment so that we
1511 don't pollute Vprocess_environment. */
fa09a82d
DL
1512 /* Setting LANG here will defeat the startup locale processing... */
1513#ifdef AIX3_2
93aed04d
RS
1514 putenv ("LANG=C");
1515#endif
0e956009 1516
7db35a48 1517 init_buffer (); /* Init default directory of main buffer. */
ace40a69 1518
7928f0b5 1519 init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */
ace40a69 1520 init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */
380e25b8
RS
1521
1522 if (initialized)
1523 {
7db35a48 1524 /* Erase any pre-dump messages in the message log, to avoid confusion. */
380e25b8
RS
1525 Lisp_Object old_log_max;
1526 old_log_max = Vmessage_log_max;
1527 XSETFASTINT (Vmessage_log_max, 0);
f6fe7bb5 1528 message_dolog ("", 0, 1, 0);
380e25b8
RS
1529 Vmessage_log_max = old_log_max;
1530 }
1531
7928f0b5 1532 init_callproc (); /* Must follow init_cmdargs but not init_sys_modes. */
fb8e9847 1533 init_lread ();
f927c5ae 1534
8bb697c0
RS
1535 /* Intern the names of all standard functions and variables;
1536 define standard keys. */
f927c5ae
JB
1537
1538 if (!initialized)
1539 {
7db35a48 1540 /* The basic levels of Lisp must come first. */
f927c5ae 1541 /* And data must come first of all
7db35a48 1542 for the sake of symbols like error-message. */
e0f712ba
AC
1543#ifndef MAC_OS8
1544 /* Called before init_window_once for Mac OS Classic. */
f927c5ae 1545 syms_of_data ();
1a578e9b 1546#endif
f927c5ae 1547 syms_of_alloc ();
fb8e9847 1548 syms_of_lread ();
f927c5ae
JB
1549 syms_of_print ();
1550 syms_of_eval ();
1551 syms_of_fns ();
f927c5ae 1552 syms_of_floatfns ();
f927c5ae
JB
1553
1554 syms_of_abbrev ();
1555 syms_of_buffer ();
1556 syms_of_bytecode ();
1557 syms_of_callint ();
1558 syms_of_casefiddle ();
1559 syms_of_casetab ();
1560 syms_of_callproc ();
270ce821 1561 syms_of_category ();
e0f712ba
AC
1562#ifndef MAC_OS8
1563 /* Called before init_window_once for Mac OS Classic. */
270ce821 1564 syms_of_ccl ();
1a578e9b 1565#endif
270ce821 1566 syms_of_charset ();
f927c5ae
JB
1567 syms_of_cmds ();
1568#ifndef NO_DIR_LIBRARY
1569 syms_of_dired ();
1570#endif /* not NO_DIR_LIBRARY */
1571 syms_of_display ();
1572 syms_of_doc ();
1573 syms_of_editfns ();
1574 syms_of_emacs ();
1575 syms_of_fileio ();
270ce821 1576 syms_of_coding (); /* This should be after syms_of_fileio. */
f927c5ae
JB
1577#ifdef CLASH_DETECTION
1578 syms_of_filelock ();
1579#endif /* CLASH_DETECTION */
1580 syms_of_indent ();
c2c5ed2c 1581 syms_of_insdel ();
f927c5ae
JB
1582 syms_of_keymap ();
1583 syms_of_macros ();
1584 syms_of_marker ();
1585 syms_of_minibuf ();
f927c5ae 1586 syms_of_process ();
e0f712ba
AC
1587#ifndef MAC_OS8
1588 /* Called before init_window_once for Mac OS Classic. */
f927c5ae 1589 syms_of_search ();
1cbd5d9d 1590 syms_of_frame ();
c1e279c2 1591#endif
f927c5ae 1592 syms_of_syntax ();
0d934e7b 1593 syms_of_term ();
f927c5ae 1594 syms_of_undo ();
90d920b6
GM
1595#ifdef HAVE_SOUND
1596 syms_of_sound ();
1597#endif
e0f712ba
AC
1598#ifndef MAC_OS8
1599 /* Called before init_window_once for Mac OS Classic. */
bef79ee4 1600 syms_of_textprop ();
1a578e9b 1601#endif
9d100795 1602 syms_of_composite ();
f927c5ae
JB
1603#ifdef VMS
1604 syms_of_vmsproc ();
1605#endif /* VMS */
05687c54
RS
1606#ifdef WINDOWSNT
1607 syms_of_ntproc ();
1608#endif /* WINDOWSNT */
f927c5ae
JB
1609 syms_of_window ();
1610 syms_of_xdisp ();
0fc4c63e
KS
1611#ifdef HAVE_WINDOW_SYSTEM
1612 syms_of_fringe ();
6e7e181d 1613 syms_of_image ();
0fc4c63e 1614#endif /* HAVE_WINDOW_SYSTEM */
f927c5ae 1615#ifdef HAVE_X_WINDOWS
72412588 1616 syms_of_xterm ();
f927c5ae 1617 syms_of_xfns ();
270ce821 1618 syms_of_fontset ();
28b1b672
JD
1619#ifdef HAVE_X_SM
1620 syms_of_xsmfns ();
1621#endif
72412588
JB
1622#ifdef HAVE_X11
1623 syms_of_xselect ();
1624#endif
f927c5ae
JB
1625#endif /* HAVE_X_WINDOWS */
1626
67fd74d8 1627#ifdef HAVE_MENUS
1e9c210b 1628#ifndef HAVE_NTGUI
e0f712ba
AC
1629#ifndef MAC_OS
1630 /* Called before init_window_once for Mac OS Classic. */
6c850f3c 1631 syms_of_xmenu ();
1e9c210b 1632#endif
1a578e9b 1633#endif
67fd74d8 1634#endif
6c850f3c 1635
8ba50e1a 1636#ifdef HAVE_NTGUI
fbd6baed
GV
1637 syms_of_w32term ();
1638 syms_of_w32fns ();
fbd6baed
GV
1639 syms_of_w32select ();
1640 syms_of_w32menu ();
02062ac3 1641 syms_of_fontset ();
8ba50e1a
GV
1642#endif /* HAVE_NTGUI */
1643
3ec33130 1644#if defined (MAC_OSX) && defined (HAVE_CARBON)
e0f712ba
AC
1645 syms_of_macterm ();
1646 syms_of_macfns ();
1647 syms_of_macmenu ();
ab271aca 1648 syms_of_macselect ();
e0f712ba 1649 syms_of_fontset ();
3ec33130 1650#endif /* MAC_OSX && HAVE_CARBON */
e0f712ba 1651
f927c5ae
JB
1652#ifdef SYMS_SYSTEM
1653 SYMS_SYSTEM;
1654#endif
1655
1656#ifdef SYMS_MACHINE
1657 SYMS_MACHINE;
1658#endif
1659
1660 keys_of_casefiddle ();
1661 keys_of_cmds ();
1662 keys_of_buffer ();
1663 keys_of_keyboard ();
1664 keys_of_keymap ();
f927c5ae
JB
1665 keys_of_minibuf ();
1666 keys_of_window ();
9785d95b 1667 }
3b6536b1 1668 else
9785d95b 1669 {
3b6536b1
AS
1670 /* Initialization that must be done even if the global variable
1671 initialized is non zero. */
9785d95b
BK
1672#ifdef HAVE_NTGUI
1673 globals_of_w32fns ();
1674 globals_of_w32menu ();
52c7f9ee 1675 globals_of_w32select ();
3b6536b1 1676#endif /* HAVE_NTGUI */
f927c5ae
JB
1677 }
1678
8bb697c0
RS
1679 if (!noninteractive)
1680 {
1681#ifdef VMS
7db35a48 1682 init_vms_input ();/* init_display calls get_frame_size, that needs this. */
8bb697c0 1683#endif /* VMS */
7db35a48 1684 init_display (); /* Determine terminal type. init_sys_modes uses results. */
8bb697c0 1685 }
e0f712ba
AC
1686#ifndef MAC_OS8
1687 /* Called before init_window_once for Mac OS Classic. */
7db35a48 1688 init_keyboard (); /* This too must precede init_sys_modes. */
1a578e9b 1689#endif
8bb697c0 1690#ifdef VMS
7db35a48 1691 init_vmsproc (); /* And this too. */
8bb697c0 1692#endif /* VMS */
7db35a48 1693 init_sys_modes (); /* Init system terminal modes (RAW or CBREAK, etc.). */
90d920b6 1694 init_fns ();
8bb697c0 1695 init_xdisp ();
0fc4c63e
KS
1696#ifdef HAVE_WINDOW_SYSTEM
1697 init_fringe ();
6e7e181d 1698 init_image ();
0fc4c63e 1699#endif /* HAVE_WINDOW_SYSTEM */
8bb697c0
RS
1700 init_macros ();
1701 init_editfns ();
8bb697c0 1702 init_floatfns ();
8bb697c0
RS
1703#ifdef VMS
1704 init_vmsfns ();
1705#endif /* VMS */
1706 init_process ();
90d920b6
GM
1707#ifdef HAVE_SOUND
1708 init_sound ();
1709#endif
75816372 1710 init_window ();
8bb697c0 1711
f927c5ae
JB
1712 if (!initialized)
1713 {
e2925360 1714 char *file;
7db35a48 1715 /* Handle -l loadup, args passed by Makefile. */
df6530f8 1716 if (argmatch (argv, argc, "-l", "--load", 3, &file, &skip_args))
f927c5ae 1717 Vtop_level = Fcons (intern ("load"),
e2925360 1718 Fcons (build_string (file), Qnil));
f927c5ae 1719 /* Unless next switch is -nl, load "loadup.el" first thing. */
956e3c7e 1720 if (! no_loadup)
f927c5ae
JB
1721 Vtop_level = Fcons (intern ("load"),
1722 Fcons (build_string ("loadup.el"), Qnil));
f927c5ae
JB
1723 }
1724
93572b43
KH
1725 if (initialized)
1726 {
0269dedb
RS
1727#ifdef HAVE_TZSET
1728 {
1729 /* If the execution TZ happens to be the same as the dump TZ,
1730 change it to some other value and then change it back,
1731 to force the underlying implementation to reload the TZ info.
1732 This is needed on implementations that load TZ info from files,
1733 since the TZ file contents may differ between dump and execution. */
1734 char *tz = getenv ("TZ");
1735 if (tz && !strcmp (tz, dump_tz))
1736 {
1737 ++*tz;
1738 tzset ();
1739 --*tz;
1740 }
1741 }
1742#endif
93572b43
KH
1743 }
1744
37a0ae84
GM
1745 /* Set up for profiling. This is known to work on FreeBSD and
1746 GNU/Linux. It might work on some other systems too. Give it a
1747 try and tell us if it works on your system. To compile for
7db35a48 1748 profiling use something like `make CFLAGS="-pg -g -O -DPROFILING=1'. */
6a97197e 1749#if defined (__FreeBSD__) || defined (__linux)
e610ea43
RS
1750#ifdef PROFILING
1751 if (initialized)
1752 {
7db35a48 1753 extern void _mcleanup ();
e610ea43 1754 extern char etext;
90d920b6 1755 extern void safe_bcopy ();
67a5596f
GM
1756 extern void dump_opcode_frequencies ();
1757
e610ea43 1758 atexit (_mcleanup);
90d920b6
GM
1759 /* This uses safe_bcopy because that function comes first in the
1760 Emacs executable. It might be better to use something that
1761 gives the start of the text segment, but start_of_text is not
1762 defined on all systems now. */
1763 monstartup (safe_bcopy, &etext);
e610ea43
RS
1764 }
1765 else
1766 moncontrol (0);
1767#endif
1768#endif
1769
f927c5ae
JB
1770 initialized = 1;
1771
e7536cff
RS
1772#ifdef LOCALTIME_CACHE
1773 /* Some versions of localtime have a bug. They cache the value of the time
279cc2b8
JB
1774 zone rather than looking it up every time. Since localtime() is
1775 called to bolt the undumping time into the undumped emacs, this
afe9fae9 1776 results in localtime ignoring the TZ environment variable.
7db35a48 1777 This flushes the new TZ value into localtime. */
afe9fae9 1778 tzset ();
e7536cff 1779#endif /* defined (LOCALTIME_CACHE) */
279cc2b8 1780
f927c5ae
JB
1781 /* Enter editor command loop. This never returns. */
1782 Frecursive_edit ();
1783 /* NOTREACHED */
6bbd7a29 1784 return 0;
f927c5ae
JB
1785}
1786\f
081bef73
RS
1787/* Sort the args so we can find the most important ones
1788 at the beginning of argv. */
1789
1790/* First, here's a table of all the standard options. */
1791
1792struct standard_args
1793{
1794 char *name;
1795 char *longname;
1796 int priority;
1797 int nargs;
1798};
1799
1800struct standard_args standard_args[] =
1801{
05922407
RS
1802 { "-version", "--version", 150, 0 },
1803#ifdef HAVE_SHM
1804 { "-nl", "--no-shared-memory", 140, 0 },
1805#endif
2725719a 1806#ifdef VMS
05922407 1807 { "-map", "--map-data", 130, 0 },
2725719a 1808#endif
05922407 1809 { "-t", "--terminal", 120, 1 },
400d6fa9 1810 { "-nw", "--no-window-system", 110, 0 },
05922407
RS
1811 { "-nw", "--no-windows", 110, 0 },
1812 { "-batch", "--batch", 100, 0 },
6e910e07 1813 { "-script", "--script", 100, 1 },
05922407 1814 { "-help", "--help", 90, 0 },
956e3c7e
RS
1815 { "-no-unibyte", "--no-unibyte", 83, 0 },
1816 { "-multibyte", "--multibyte", 82, 0 },
1817 { "-unibyte", "--unibyte", 81, 0 },
1818 { "-no-multibyte", "--no-multibyte", 80, 0 },
956e3c7e 1819 { "-nl", "--no-loadup", 70, 0 },
956e3c7e
RS
1820 /* -d must come last before the options handled in startup.el. */
1821 { "-d", "--display", 60, 1 },
1822 { "-display", 0, 60, 1 },
05922407 1823 /* Now for the options handled in startup.el. */
a1716a57
RS
1824 { "-Q", "--quick", 55, 0 },
1825 { "-quick", 0, 55, 0 },
081bef73
RS
1826 { "-q", "--no-init-file", 50, 0 },
1827 { "-no-init-file", 0, 50, 0 },
1828 { "-no-site-file", "--no-site-file", 40, 0 },
af2bf12f 1829 { "-no-splash", "--no-splash", 40, 0 },
081bef73
RS
1830 { "-u", "--user", 30, 1 },
1831 { "-user", 0, 30, 1 },
1832 { "-debug-init", "--debug-init", 20, 0 },
adab4483
KH
1833 { "-i", "--icon-type", 15, 0 },
1834 { "-itype", 0, 15, 0 },
f2bc3538 1835 { "-iconic", "--iconic", 15, 0 },
a1716a57
RS
1836 { "-D", "--basic-display", 12, 0},
1837 { "--basic-display", 0, 12, 0},
081bef73
RS
1838 { "-bg", "--background-color", 10, 1 },
1839 { "-background", 0, 10, 1 },
1840 { "-fg", "--foreground-color", 10, 1 },
1841 { "-foreground", 0, 10, 1 },
1842 { "-bd", "--border-color", 10, 1 },
1843 { "-bw", "--border-width", 10, 1 },
1844 { "-ib", "--internal-border", 10, 1 },
1845 { "-ms", "--mouse-color", 10, 1 },
1846 { "-cr", "--cursor-color", 10, 1 },
49ca717b 1847 { "-nbc", "--no-blinking-cursor", 10, 0 },
081bef73
RS
1848 { "-fn", "--font", 10, 1 },
1849 { "-font", 0, 10, 1 },
94452530
EZ
1850 { "-fs", "--fullscreen", 10, 0 },
1851 { "-fw", "--fullwidth", 10, 0 },
1852 { "-fh", "--fullheight", 10, 0 },
081bef73
RS
1853 { "-g", "--geometry", 10, 1 },
1854 { "-geometry", 0, 10, 1 },
1855 { "-T", "--title", 10, 1 },
ae63ae52 1856 { "-title", 0, 10, 1 },
081bef73
RS
1857 { "-name", "--name", 10, 1 },
1858 { "-xrm", "--xrm", 10, 1 },
fcdeb5d9
RS
1859 { "-r", "--reverse-video", 5, 0 },
1860 { "-rv", 0, 5, 0 },
1861 { "-reverse", 0, 5, 0 },
ae63ae52 1862 { "-hb", "--horizontal-scroll-bars", 5, 0 },
fcdeb5d9 1863 { "-vb", "--vertical-scroll-bars", 5, 0 },
d20e1b1e 1864 { "-color", "--color", 5, 0},
fcdeb5d9
RS
1865 /* These have the same priority as ordinary file name args,
1866 so they are not reordered with respect to those. */
4af9e0b3
RS
1867 { "-L", "--directory", 0, 1 },
1868 { "-directory", 0, 0, 1 },
fcdeb5d9
RS
1869 { "-l", "--load", 0, 1 },
1870 { "-load", 0, 0, 1 },
1871 { "-f", "--funcall", 0, 1 },
1872 { "-funcall", 0, 0, 1 },
575985b1 1873 { "-eval", "--eval", 0, 1 },
67a5596f 1874 { "-execute", "--execute", 0, 1 },
2e13f8e9
RS
1875 { "-find-file", "--find-file", 0, 1 },
1876 { "-visit", "--visit", 0, 1 },
67a5596f 1877 { "-file", "--file", 0, 1 },
fcdeb5d9 1878 { "-insert", "--insert", 0, 1 },
f2bc3538 1879 /* This should be processed after ordinary file name args and the like. */
fcdeb5d9 1880 { "-kill", "--kill", -10, 0 },
081bef73
RS
1881};
1882
1883/* Reorder the elements of ARGV (assumed to have ARGC elements)
1884 so that the highest priority ones come first.
1885 Do not change the order of elements of equal priority.
956e3c7e
RS
1886 If an option takes an argument, keep it and its argument together.
1887
1888 If an option that takes no argument appears more
1889 than once, eliminate all but one copy of it. */
081bef73
RS
1890
1891static void
1892sort_args (argc, argv)
1893 int argc;
1894 char **argv;
1895{
1896 char **new = (char **) xmalloc (sizeof (char *) * argc);
1897 /* For each element of argv,
1898 the corresponding element of options is:
1899 0 for an option that takes no arguments,
1900 1 for an option that takes one argument, etc.
1901 -1 for an ordinary non-option argument. */
6dad9359 1902 int *options = (int *) xmalloc (sizeof (int) * argc);
081bef73
RS
1903 int *priority = (int *) xmalloc (sizeof (int) * argc);
1904 int to = 1;
956e3c7e 1905 int incoming_used = 1;
081bef73
RS
1906 int from;
1907 int i;
1908
1909 /* Categorize all the options,
1910 and figure out which argv elts are option arguments. */
1911 for (from = 1; from < argc; from++)
1912 {
1913 options[from] = -1;
fcdeb5d9 1914 priority[from] = 0;
081bef73
RS
1915 if (argv[from][0] == '-')
1916 {
1917 int match, thislen;
1918 char *equals;
1919
c96f26f4
RS
1920 /* If we have found "--", don't consider
1921 any more arguments as options. */
249443b6 1922 if (argv[from][1] == '-' && argv[from][2] == 0)
c96f26f4
RS
1923 {
1924 /* Leave the "--", and everything following it, at the end. */
1925 for (; from < argc; from++)
1926 {
1927 priority[from] = -100;
1928 options[from] = -1;
1929 }
1930 break;
1931 }
1932
081bef73
RS
1933 /* Look for a match with a known old-fashioned option. */
1934 for (i = 0; i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1935 if (!strcmp (argv[from], standard_args[i].name))
1936 {
1937 options[from] = standard_args[i].nargs;
1938 priority[from] = standard_args[i].priority;
fd76ec52
RS
1939 if (from + standard_args[i].nargs >= argc)
1940 fatal ("Option `%s' requires an argument\n", argv[from]);
081bef73
RS
1941 from += standard_args[i].nargs;
1942 goto done;
1943 }
1944
1945 /* Look for a match with a known long option.
1946 MATCH is -1 if no match so far, -2 if two or more matches so far,
1947 >= 0 (the table index of the match) if just one match so far. */
1948 if (argv[from][1] == '-')
1949 {
1950 match = -1;
1951 thislen = strlen (argv[from]);
1952 equals = index (argv[from], '=');
1953 if (equals != 0)
1954 thislen = equals - argv[from];
1955
f609ef57
KH
1956 for (i = 0;
1957 i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1958 if (standard_args[i].longname
1959 && !strncmp (argv[from], standard_args[i].longname,
1960 thislen))
081bef73
RS
1961 {
1962 if (match == -1)
1963 match = i;
1964 else
1965 match = -2;
1966 }
1967
1968 /* If we found exactly one match, use that. */
1969 if (match >= 0)
1970 {
1971 options[from] = standard_args[match].nargs;
1972 priority[from] = standard_args[match].priority;
1973 /* If --OPTION=VALUE syntax is used,
1974 this option uses just one argv element. */
1975 if (equals != 0)
1976 options[from] = 0;
fd76ec52
RS
1977 if (from + options[from] >= argc)
1978 fatal ("Option `%s' requires an argument\n", argv[from]);
081bef73
RS
1979 from += options[from];
1980 }
1981 }
1982 done: ;
1983 }
1984 }
1985
1986 /* Copy the arguments, in order of decreasing priority, to NEW. */
1987 new[0] = argv[0];
956e3c7e 1988 while (incoming_used < argc)
081bef73
RS
1989 {
1990 int best = -1;
2c70c992 1991 int best_priority = -9999;
081bef73
RS
1992
1993 /* Find the highest priority remaining option.
1994 If several have equal priority, take the first of them. */
1995 for (from = 1; from < argc; from++)
1996 {
1997 if (argv[from] != 0 && priority[from] > best_priority)
1998 {
1999 best_priority = priority[from];
2000 best = from;
2001 }
2002 /* Skip option arguments--they are tied to the options. */
2003 if (options[from] > 0)
2004 from += options[from];
2005 }
7db35a48 2006
081bef73
RS
2007 if (best < 0)
2008 abort ();
2009
956e3c7e
RS
2010 /* Copy the highest priority remaining option, with its args, to NEW.
2011 Unless it is a duplicate of the previous one. */
2012 if (! (options[best] == 0
2013 && ! strcmp (new[to - 1], argv[best])))
2014 {
2015 new[to++] = argv[best];
2016 for (i = 0; i < options[best]; i++)
2017 new[to++] = argv[best + i + 1];
2018 }
2019
2020 incoming_used += 1 + (options[best] > 0 ? options[best] : 0);
081bef73
RS
2021
2022 /* Clear out this option in ARGV. */
2023 argv[best] = 0;
2024 for (i = 0; i < options[best]; i++)
2025 argv[best + i + 1] = 0;
2026 }
2027
81b7af72
RS
2028 /* If duplicate options were deleted, fill up extra space with null ptrs. */
2029 while (to < argc)
2030 new[to++] = 0;
2031
6dad9359 2032 bcopy (new, argv, sizeof (char *) * argc);
0bf591da 2033
68db37aa
KS
2034 xfree (options);
2035 xfree (new);
2036 xfree (priority);
081bef73
RS
2037}
2038\f
f927c5ae 2039DEFUN ("kill-emacs", Fkill_emacs, Skill_emacs, 0, 1, "P",
7db35a48
PJ
2040 doc: /* Exit the Emacs job and kill it.
2041If ARG is an integer, return ARG as the exit program code.
2042If ARG is a string, stuff it as keyboard input.
2043
2044The value of `kill-emacs-hook', if not void,
2045is a list of functions (of no args),
2046all of which are called before Emacs is actually killed. */)
2047 (arg)
f927c5ae
JB
2048 Lisp_Object arg;
2049{
f927c5ae
JB
2050 struct gcpro gcpro1;
2051
2052 GCPRO1 (arg);
2053
2054 if (feof (stdin))
2055 arg = Qt;
2056
2447c626 2057 if (!NILP (Vrun_hooks) && !noninteractive)
f927c5ae
JB
2058 call1 (Vrun_hooks, intern ("kill-emacs-hook"));
2059
f927c5ae
JB
2060 UNGCPRO;
2061
2062/* Is it really necessary to do this deassign
2063 when we are going to exit anyway? */
2064/* #ifdef VMS
2065 stop_vms_input ();
2066 #endif */
40be253a 2067
d0068e25 2068 shut_down_emacs (0, 0, STRINGP (arg) ? arg : Qnil);
40be253a 2069
58545838
KH
2070 /* If we have an auto-save list file,
2071 kill it because we are exiting Emacs deliberately (not crashing).
2072 Do it after shut_down_emacs, which does an auto-save. */
2073 if (STRINGP (Vauto_save_list_file_name))
d5db4077 2074 unlink (SDATA (Vauto_save_list_file_name));
58545838 2075
fa439170 2076 exit (INTEGERP (arg) ? XINT (arg) : EXIT_SUCCESS);
f927c5ae 2077 /* NOTREACHED */
f1145b54 2078 return Qnil;
f927c5ae 2079}
40be253a
JB
2080
2081
2082/* Perform an orderly shutdown of Emacs. Autosave any modified
2083 buffers, kill any child processes, clean up the terminal modes (if
2084 we're in the foreground), and other stuff like that. Don't perform
2085 any redisplay; this may be called when Emacs is shutting down in
2086 the background, or after its X connection has died.
2087
2088 If SIG is a signal number, print a message for it.
2089
2090 This is called by fatal signal handlers, X protocol error handlers,
2091 and Fkill_emacs. */
f7ab4e3d 2092
40be253a 2093void
f7ab4e3d 2094shut_down_emacs (sig, no_x, stuff)
41423a80 2095 int sig, no_x;
f7ab4e3d 2096 Lisp_Object stuff;
40be253a 2097{
829d872b
RS
2098 /* Prevent running of hooks from now on. */
2099 Vrun_hooks = Qnil;
2100
9db03f6c
KS
2101 /* Don't update display from now on. */
2102 Vinhibit_redisplay = Qt;
2103
7db35a48 2104 /* If we are controlling the terminal, reset terminal modes. */
40be253a
JB
2105#ifdef EMACS_HAVE_TTY_PGRP
2106 {
d04d81d2
RS
2107 int pgrp = EMACS_GETPGRP (0);
2108
40be253a
JB
2109 int tpgrp;
2110 if (EMACS_GET_TTY_PGRP (0, &tpgrp) != -1
5a570e37 2111 && tpgrp == pgrp)
40be253a
JB
2112 {
2113 fflush (stdout);
2114 reset_sys_modes ();
2115 if (sig && sig != SIGTERM)
7c402969 2116 fprintf (stderr, "Fatal error (%d)", sig);
40be253a
JB
2117 }
2118 }
2119#else
2120 fflush (stdout);
2121 reset_sys_modes ();
2122#endif
2123
f7ab4e3d
RS
2124 stuff_buffered_input (stuff);
2125
40be253a
JB
2126 kill_buffer_processes (Qnil);
2127 Fdo_auto_save (Qt, Qnil);
2128
2129#ifdef CLASH_DETECTION
2130 unlock_all_files ();
2131#endif
2132
2133#ifdef VMS
2134 kill_vms_processes ();
2135#endif
2136
5e7f8733 2137#if 0 /* This triggers a bug in XCloseDisplay and is not needed. */
41423a80 2138#ifdef HAVE_X_WINDOWS
f7511647
RS
2139 /* It's not safe to call intern here. Maybe we are crashing. */
2140 if (!noninteractive && SYMBOLP (Vwindow_system)
d5db4077
KR
2141 && SCHARS (SYMBOL_NAME (Vwindow_system)) == 1
2142 && SREF (SYMBOL_NAME (Vwindow_system), 0) == 'x'
f7511647 2143 && ! no_x)
41423a80
RS
2144 Fx_close_current_connection ();
2145#endif /* HAVE_X_WINDOWS */
5e7f8733 2146#endif
41423a80 2147
40be253a
JB
2148#ifdef SIGIO
2149 /* There is a tendency for a SIGIO signal to arrive within exit,
2150 and cause a SIGHUP because the input descriptor is already closed. */
2151 unrequest_sigio ();
2152 signal (SIGIO, SIG_IGN);
2153#endif
41f339d4
RS
2154
2155#ifdef WINDOWSNT
2156 term_ntproc ();
2157#endif
d546e578 2158
cd8d4168
GM
2159 /* Do this only if terminating normally, we want glyph matrices
2160 etc. in a core dump. */
200f868e 2161 if (sig == 0 || sig == SIGTERM)
cd8d4168
GM
2162 {
2163 check_glyph_memory ();
2164 check_message_stack ();
2165 }
90d920b6 2166
d546e578
EZ
2167#ifdef MSDOS
2168 dos_cleanup ();
2169#endif
40be253a
JB
2170}
2171
2172
f927c5ae
JB
2173\f
2174#ifndef CANNOT_DUMP
f927c5ae
JB
2175
2176#ifdef HAVE_SHM
2177
2178DEFUN ("dump-emacs-data", Fdump_emacs_data, Sdump_emacs_data, 1, 1, 0,
7db35a48
PJ
2179 doc: /* Dump current state of Emacs into data file FILENAME.
2180This function exists on systems that use HAVE_SHM. */)
2181 (filename)
c9aae259 2182 Lisp_Object filename;
f927c5ae 2183{
55697f5b 2184 extern char my_edata[];
f927c5ae 2185 Lisp_Object tem;
f927c5ae 2186
4fab758d 2187 check_pure_size ();
b7826503 2188 CHECK_STRING (filename);
c9aae259 2189 filename = Fexpand_file_name (filename, Qnil);
f927c5ae
JB
2190
2191 tem = Vpurify_flag;
2192 Vpurify_flag = Qnil;
2193
2194 fflush (stdout);
7db35a48 2195 /* Tell malloc where start of impure now is. */
f927c5ae
JB
2196 /* Also arrange for warnings when nearly out of space. */
2197#ifndef SYSTEM_MALLOC
1090a161 2198 memory_warnings (my_edata, malloc_warning);
f927c5ae 2199#endif
d5db4077 2200 map_out_data (SDATA (filename));
f927c5ae
JB
2201
2202 Vpurify_flag = tem;
2203
2204 return Qnil;
2205}
2206
2207#else /* not HAVE_SHM */
2208
2209DEFUN ("dump-emacs", Fdump_emacs, Sdump_emacs, 2, 2, 0,
7db35a48
PJ
2210 doc: /* Dump current state of Emacs into executable file FILENAME.
2211Take symbols from SYMFILE (presumably the file you executed to run Emacs).
2212This is used in the file `loadup.el' when building Emacs.
2213
2214You must run Emacs in batch mode in order to dump it. */)
2215 (filename, symfile)
c9aae259 2216 Lisp_Object filename, symfile;
f927c5ae 2217{
55697f5b 2218 extern char my_edata[];
f927c5ae 2219 Lisp_Object tem;
1b7ddf4f 2220 Lisp_Object symbol;
331379bf 2221 int count = SPECPDL_INDEX ();
4fab758d
GM
2222
2223 check_pure_size ();
f927c5ae 2224
87a98b1a
RS
2225 if (! noninteractive)
2226 error ("Dumping Emacs works only in batch mode");
2227
c37caf9d 2228#ifdef __linux__
dede2792
JD
2229 if (heap_bss_diff > MAX_HEAP_BSS_DIFF)
2230 {
2231 fprintf (stderr, "**************************************************\n");
2232 fprintf (stderr, "Warning: Your system has a gap between BSS and the\n");
9b33d596 2233 fprintf (stderr, "heap (%lu byte). This usually means that exec-shield\n",
c37caf9d
JD
2234 heap_bss_diff);
2235 fprintf (stderr, "or something similar is in effect. The dump may\n");
2236 fprintf (stderr, "fail because of this. See the section about \n");
2237 fprintf (stderr, "exec-shield in etc/PROBLEMS for more information.\n");
dede2792
JD
2238 fprintf (stderr, "**************************************************\n");
2239 }
c37caf9d 2240#endif /* __linux__ */
dede2792 2241
1b7ddf4f
RS
2242 /* Bind `command-line-processed' to nil before dumping,
2243 so that the dumped Emacs will process its command line
2244 and set up to work with X windows if appropriate. */
4aaa3607 2245 symbol = intern ("command-line-processed");
1b7ddf4f
RS
2246 specbind (symbol, Qnil);
2247
b7826503 2248 CHECK_STRING (filename);
c9aae259
EN
2249 filename = Fexpand_file_name (filename, Qnil);
2250 if (!NILP (symfile))
f927c5ae 2251 {
b7826503 2252 CHECK_STRING (symfile);
d5db4077 2253 if (SCHARS (symfile))
c9aae259 2254 symfile = Fexpand_file_name (symfile, Qnil);
f927c5ae
JB
2255 }
2256
2257 tem = Vpurify_flag;
2258 Vpurify_flag = Qnil;
2259
0269dedb
RS
2260#ifdef HAVE_TZSET
2261 set_time_zone_rule (dump_tz);
2262#ifndef LOCALTIME_CACHE
2263 /* Force a tz reload, since set_time_zone_rule doesn't. */
2264 tzset ();
2265#endif
2266#endif
2267
f927c5ae
JB
2268 fflush (stdout);
2269#ifdef VMS
d5db4077 2270 mapout_data (SDATA (filename));
f927c5ae 2271#else
7db35a48 2272 /* Tell malloc where start of impure now is. */
f927c5ae
JB
2273 /* Also arrange for warnings when nearly out of space. */
2274#ifndef SYSTEM_MALLOC
cc5f52cb
RS
2275#ifndef WINDOWSNT
2276 /* On Windows, this was done before dumping, and that once suffices.
2277 Meanwhile, my_edata is not valid on Windows. */
cb37cf78 2278 memory_warnings (my_edata, malloc_warning);
cc5f52cb 2279#endif /* not WINDOWSNT */
15aaf1b5 2280#endif
06ca62eb 2281#if !defined (SYSTEM_MALLOC) && defined (HAVE_GTK_AND_PTHREAD) && !defined SYNC_INPUT
aa477689
JD
2282 /* Pthread may call malloc before main, and then we will get an endless
2283 loop, because pthread_self (see alloc.c) calls malloc the first time
2284 it is called on some systems. */
2285 reset_malloc_hooks ();
2286#endif
15aaf1b5
RS
2287#ifdef DOUG_LEA_MALLOC
2288 malloc_state_ptr = malloc_get_state ();
f927c5ae 2289#endif
2b7377ca 2290
a74c5ec1 2291#ifdef USE_MMAP_FOR_BUFFERS
2b7377ca
GM
2292 mmap_set_vars (0);
2293#endif
d5db4077
KR
2294 unexec (SDATA (filename),
2295 !NILP (symfile) ? SDATA (symfile) : 0, my_edata, 0, 0);
a74c5ec1 2296#ifdef USE_MMAP_FOR_BUFFERS
2b7377ca
GM
2297 mmap_set_vars (1);
2298#endif
15aaf1b5
RS
2299#ifdef DOUG_LEA_MALLOC
2300 free (malloc_state_ptr);
2301#endif
f927c5ae
JB
2302#endif /* not VMS */
2303
2304 Vpurify_flag = tem;
2305
1b7ddf4f 2306 return unbind_to (count, Qnil);
f927c5ae
JB
2307}
2308
2309#endif /* not HAVE_SHM */
2310
2311#endif /* not CANNOT_DUMP */
2312\f
68c45bf0
PE
2313#if HAVE_SETLOCALE
2314/* Recover from setlocale (LC_ALL, ""). */
2315void
2316fixup_locale ()
2317{
68c45bf0
PE
2318 /* The Emacs Lisp reader needs LC_NUMERIC to be "C",
2319 so that numbers are read and printed properly for Emacs Lisp. */
2320 setlocale (LC_NUMERIC, "C");
68c45bf0
PE
2321}
2322
0c8559bb
PE
2323/* Set system locale CATEGORY, with previous locale *PLOCALE, to
2324 DESIRED_LOCALE. */
68c45bf0
PE
2325static void
2326synchronize_locale (category, plocale, desired_locale)
2327 int category;
2328 Lisp_Object *plocale;
2329 Lisp_Object desired_locale;
2330{
0c8559bb
PE
2331 if (! EQ (*plocale, desired_locale))
2332 {
2333 *plocale = desired_locale;
2334 setlocale (category, (STRINGP (desired_locale)
3b6536b1 2335 ? (char *) SDATA (desired_locale)
0c8559bb
PE
2336 : ""));
2337 }
68c45bf0
PE
2338}
2339
ca9c0567 2340/* Set system time locale to match Vsystem_time_locale, if possible. */
68c45bf0 2341void
ca9c0567 2342synchronize_system_time_locale ()
68c45bf0 2343{
ca9c0567
PE
2344 synchronize_locale (LC_TIME, &Vprevious_system_time_locale,
2345 Vsystem_time_locale);
68c45bf0
PE
2346}
2347
ca9c0567
PE
2348/* Set system messages locale to match Vsystem_messages_locale, if
2349 possible. */
68c45bf0 2350void
ca9c0567 2351synchronize_system_messages_locale ()
68c45bf0
PE
2352{
2353#ifdef LC_MESSAGES
ca9c0567
PE
2354 synchronize_locale (LC_MESSAGES, &Vprevious_system_messages_locale,
2355 Vsystem_messages_locale);
68c45bf0
PE
2356#endif
2357}
2358#endif /* HAVE_SETLOCALE */
2359\f
4b163808 2360#ifndef SEPCHAR
f927c5ae
JB
2361#define SEPCHAR ':'
2362#endif
2363
2364Lisp_Object
2365decode_env_path (evarname, defalt)
2366 char *evarname, *defalt;
2367{
2368 register char *path, *p;
213d0b1f 2369 Lisp_Object lpath, element, tem;
f927c5ae 2370
2447c626
JB
2371 /* It's okay to use getenv here, because this function is only used
2372 to initialize variables when Emacs starts up, and isn't called
2373 after that. */
e065a56e
JB
2374 if (evarname != 0)
2375 path = (char *) getenv (evarname);
2376 else
2377 path = 0;
f927c5ae
JB
2378 if (!path)
2379 path = defalt;
6a30e6d6
RS
2380#ifdef DOS_NT
2381 /* Ensure values from the environment use the proper directory separator. */
2382 if (path)
2383 {
2384 p = alloca (strlen (path) + 1);
2385 strcpy (p, path);
2386 path = p;
2387
2388 if ('/' == DIRECTORY_SEP)
2389 dostounix_filename (path);
2390 else
2391 unixtodos_filename (path);
2392 }
2393#endif
f927c5ae
JB
2394 lpath = Qnil;
2395 while (1)
2396 {
2397 p = index (path, SEPCHAR);
2398 if (!p) p = path + strlen (path);
213d0b1f
RS
2399 element = (p - path ? make_string (path, p - path)
2400 : build_string ("."));
2401
2402 /* Add /: to the front of the name
2403 if it would otherwise be treated as magic. */
2404 tem = Ffind_file_name_handler (element, Qt);
ca3df2d5
RS
2405
2406 /* However, if the handler says "I'm safe",
2407 don't bother adding /:. */
2408 if (SYMBOLP (tem))
2409 {
2410 Lisp_Object prop;
2411 prop = Fget (tem, intern ("safe-magic"));
2412 if (! NILP (prop))
2413 tem = Qnil;
2414 }
2415
213d0b1f
RS
2416 if (! NILP (tem))
2417 element = concat2 (build_string ("/:"), element);
2418
2419 lpath = Fcons (element, lpath);
f927c5ae
JB
2420 if (*p)
2421 path = p + 1;
2422 else
2423 break;
2424 }
2425 return Fnreverse (lpath);
2426}
2427
dfcf069d 2428void
f927c5ae
JB
2429syms_of_emacs ()
2430{
213d0b1f
RS
2431 Qfile_name_handler_alist = intern ("file-name-handler-alist");
2432 staticpro (&Qfile_name_handler_alist);
2433
83591e66 2434#ifndef CANNOT_DUMP
f927c5ae
JB
2435#ifdef HAVE_SHM
2436 defsubr (&Sdump_emacs_data);
2437#else
2438 defsubr (&Sdump_emacs);
83591e66 2439#endif
f927c5ae
JB
2440#endif
2441
2442 defsubr (&Skill_emacs);
2443
59653951 2444 defsubr (&Sinvocation_name);
ace40a69 2445 defsubr (&Sinvocation_directory);
59653951 2446
f927c5ae 2447 DEFVAR_LISP ("command-line-args", &Vcommand_line_args,
2a9d2ed6
RS
2448 doc: /* Args passed by shell to Emacs, as a list of strings.
2449Many arguments are deleted from the list as they are processed. */);
f927c5ae
JB
2450
2451 DEFVAR_LISP ("system-type", &Vsystem_type,
40a8993a
NR
2452 doc: /* Value is symbol indicating type of operating system you are using.
2453Special values:
2454 `gnu/linux' compiled for a GNU/Linux system.
2455 `darwin' compiled for Darwin (GNU-Darwin, Mac OS X, ...).
2456 `macos' compiled for Mac OS 9.
2457 `ms-dos' compiled as an MS-DOS application.
2458 `windows-nt' compiled as a native W32 application.
2459 `cygwin' compiled using the Cygwin library.
2460 `vax-vms' or `axp-vms': compiled for a (Open)VMS system.
2461Anything else indicates some sort of Unix system. */);
f927c5ae
JB
2462 Vsystem_type = intern (SYSTEM_TYPE);
2463
271c7b7c 2464 DEFVAR_LISP ("system-configuration", &Vsystem_configuration,
7db35a48
PJ
2465 doc: /* Value is string indicating configuration Emacs was built for.
2466On MS-Windows, the value reflects the OS flavor and version on which
2467Emacs is running. */);
f7511647 2468 Vsystem_configuration = build_string (EMACS_CONFIGURATION);
271c7b7c 2469
f0fc0b1a 2470 DEFVAR_LISP ("system-configuration-options", &Vsystem_configuration_options,
7db35a48 2471 doc: /* String containing the configuration options Emacs was built with. */);
f0fc0b1a
KH
2472 Vsystem_configuration_options = build_string (EMACS_CONFIG_OPTIONS);
2473
f927c5ae 2474 DEFVAR_BOOL ("noninteractive", &noninteractive1,
7db35a48 2475 doc: /* Non-nil means Emacs is running without interactive terminal. */);
e5d77022 2476
e5d77022 2477 DEFVAR_LISP ("kill-emacs-hook", &Vkill_emacs_hook,
d77b70e5
MR
2478 doc: /* Hook to be run when kill-emacs is called.
2479Since `kill-emacs' may be invoked when the terminal is disconnected (or
7db35a48
PJ
2480in other similar situations), functions placed on this hook should not
2481expect to be able to interact with the user. To ask for confirmation,
d77b70e5
MR
2482see `kill-emacs-query-functions' instead.
2483
2484The hook is not run in batch mode, i.e., if `noninteractive' is non-nil. */);
edc8ae07 2485 Vkill_emacs_hook = Qnil;
3005da00 2486
f9a6326d
SM
2487 empty_string = build_string ("");
2488 staticpro (&empty_string);
2489
3005da00 2490 DEFVAR_INT ("emacs-priority", &emacs_priority,
7db35a48
PJ
2491 doc: /* Priority for Emacs to run at.
2492This value is effective only if set before Emacs is dumped,
2493and only if the Emacs executable is installed with setuid to permit
2494it to change priority. (Emacs sets its uid back to the real uid.)
2495Currently, you need to define SET_EMACS_PRIORITY in `config.h'
2496before you compile Emacs, to enable the code for this feature. */);
e7a9e1c3 2497 emacs_priority = 0;
074a066b
GV
2498
2499 DEFVAR_LISP ("path-separator", &Vpath_separator,
ddb67bdc 2500 doc: /* The directory separator in search paths, as a string. */);
074a066b
GV
2501 {
2502 char c = SEPCHAR;
2503 Vpath_separator = make_string (&c, 1);
2504 }
59653951 2505
f67de86f 2506 DEFVAR_LISP ("invocation-name", &Vinvocation_name,
7db35a48
PJ
2507 doc: /* The program name that was used to run Emacs.
2508Any directory names are omitted. */);
f67de86f
RS
2509
2510 DEFVAR_LISP ("invocation-directory", &Vinvocation_directory,
7db35a48
PJ
2511 doc: /* The directory in which the Emacs executable was found, to run it.
2512The value is nil if that directory's name is not known. */);
f67de86f
RS
2513
2514 DEFVAR_LISP ("installation-directory", &Vinstallation_directory,
7db35a48
PJ
2515 doc: /* A directory within which to look for the `lib-src' and `etc' directories.
2516This is non-nil when we can't find those directories in their standard
2517installed locations, but we can find them
2518near where the Emacs executable was found. */);
07f4d123 2519 Vinstallation_directory = Qnil;
68c45bf0 2520
ca9c0567 2521 DEFVAR_LISP ("system-messages-locale", &Vsystem_messages_locale,
7db35a48 2522 doc: /* System locale for messages. */);
ca9c0567 2523 Vsystem_messages_locale = Qnil;
68c45bf0 2524
ca9c0567 2525 DEFVAR_LISP ("previous-system-messages-locale",
7db35a48
PJ
2526 &Vprevious_system_messages_locale,
2527 doc: /* Most recently used system locale for messages. */);
ca9c0567 2528 Vprevious_system_messages_locale = Qnil;
68c45bf0 2529
ca9c0567 2530 DEFVAR_LISP ("system-time-locale", &Vsystem_time_locale,
7db35a48 2531 doc: /* System locale for time. */);
ca9c0567 2532 Vsystem_time_locale = Qnil;
68c45bf0 2533
ca9c0567 2534 DEFVAR_LISP ("previous-system-time-locale", &Vprevious_system_time_locale,
7db35a48 2535 doc: /* Most recently used system locale for time. */);
ca9c0567 2536 Vprevious_system_time_locale = Qnil;
f927c5ae 2537}
ab5796a9
MB
2538
2539/* arch-tag: 7bfd356a-c720-4612-8ab6-aa4222931c2e
2540 (do not change this comment) */