Update years in copyright notice; nfc.
[bpt/emacs.git] / src / emacs.c
1 /* Fully extensible Emacs, running on Unix, intended for GNU.
2 Copyright (C) 1985, 1986, 1987, 1993, 1994, 1995, 1997, 1998, 1999,
3 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
4
5 This file is part of GNU Emacs.
6
7 GNU Emacs is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
11
12 GNU Emacs is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with GNU Emacs; see the file COPYING. If not, write to
19 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20 Boston, MA 02110-1301, USA. */
21
22
23 #include <config.h>
24 #include <signal.h>
25 #include <errno.h>
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
35 #ifdef HAVE_UNISTD_H
36 #include <unistd.h>
37 #endif
38
39 #ifdef BSD_SYSTEM
40 #include <sys/ioctl.h>
41 #endif
42
43 #ifdef WINDOWSNT
44 #include <fcntl.h>
45 #include <windows.h> /* just for w32.h */
46 #include "w32.h"
47 #include "w32heap.h" /* for prototype of sbrk */
48 #endif
49
50 #include "lisp.h"
51 #include "commands.h"
52 #include "intervals.h"
53 #include "buffer.h"
54 #include "window.h"
55
56 #include "systty.h"
57 #include "blockinput.h"
58 #include "syssignal.h"
59 #include "process.h"
60 #include "termhooks.h"
61 #include "keyboard.h"
62 #include "keymap.h"
63
64 #ifdef HAVE_SETLOCALE
65 #include <locale.h>
66 #endif
67
68 #ifdef HAVE_SETRLIMIT
69 #include <sys/time.h>
70 #include <sys/resource.h>
71 #endif
72
73 #ifdef HAVE_PERSONALITY_LINUX32
74 #include <sys/personality.h>
75 #endif
76
77 #ifndef O_RDWR
78 #define O_RDWR 2
79 #endif
80
81 #ifdef HAVE_SETPGID
82 #if !defined (USG) || defined (BSD_PGRPS)
83 #undef setpgrp
84 #define setpgrp setpgid
85 #endif
86 #endif
87
88 extern void malloc_warning P_ ((char *));
89 extern void set_time_zone_rule P_ ((char *));
90 #ifdef HAVE_INDEX
91 extern char *index P_ ((const char *, int));
92 #endif
93
94 /* Make these values available in GDB, which doesn't see macros. */
95
96 #ifdef USE_LSB_TAG
97 int gdb_use_lsb = 1;
98 #else
99 int gdb_use_lsb = 0;
100 #endif
101 #ifdef NO_UNION_TYPE
102 int gdb_use_union = 0;
103 #else
104 int gdb_use_union = 1;
105 #endif
106 EMACS_INT gdb_valbits = VALBITS;
107 EMACS_INT gdb_gctypebits = GCTYPEBITS;
108 #ifdef DATA_SEG_BITS
109 EMACS_INT gdb_data_seg_bits = DATA_SEG_BITS;
110 #else
111 EMACS_INT gdb_data_seg_bits = 0;
112 #endif
113 EMACS_INT PVEC_FLAG = PSEUDOVECTOR_FLAG;
114 EMACS_INT gdb_array_mark_flag = ARRAY_MARK_FLAG;
115
116 /* Command line args from shell, as list of strings. */
117 Lisp_Object Vcommand_line_args;
118
119 /* The name under which Emacs was invoked, with any leading directory
120 names discarded. */
121 Lisp_Object Vinvocation_name;
122
123 /* The directory name from which Emacs was invoked. */
124 Lisp_Object Vinvocation_directory;
125
126 /* The directory name in which to find subdirs such as lisp and etc.
127 nil means get them only from PATH_LOADSEARCH. */
128 Lisp_Object Vinstallation_directory;
129
130 /* Hook run by `kill-emacs' before it does really anything. */
131 Lisp_Object Vkill_emacs_hook;
132
133 /* An empty lisp string. To avoid having to build any other. */
134 Lisp_Object empty_string;
135
136 /* Search path separator. */
137 Lisp_Object Vpath_separator;
138
139 /* Set nonzero after Emacs has started up the first time.
140 Prevents reinitialization of the Lisp world and keymaps
141 on subsequent starts. */
142 int initialized;
143
144 #ifdef DOUG_LEA_MALLOC
145 /* Preserves a pointer to the memory allocated that copies that
146 static data inside glibc's malloc. */
147 void *malloc_state_ptr;
148 /* From glibc, a routine that returns a copy of the malloc internal state. */
149 extern void *malloc_get_state ();
150 /* From glibc, a routine that overwrites the malloc internal state. */
151 extern void malloc_set_state ();
152 /* Non-zero if the MALLOC_CHECK_ enviroment variable was set while
153 dumping. Used to work around a bug in glibc's malloc. */
154 int malloc_using_checking;
155 #endif
156
157 /* Variable whose value is symbol giving operating system type. */
158 Lisp_Object Vsystem_type;
159
160 /* Variable whose value is string giving configuration built for. */
161 Lisp_Object Vsystem_configuration;
162
163 /* Variable whose value is string giving configuration options,
164 for use when reporting bugs. */
165 Lisp_Object Vsystem_configuration_options;
166
167 Lisp_Object Qfile_name_handler_alist;
168
169 /* Current and previous system locales for messages and time. */
170 Lisp_Object Vsystem_messages_locale;
171 Lisp_Object Vprevious_system_messages_locale;
172 Lisp_Object Vsystem_time_locale;
173 Lisp_Object Vprevious_system_time_locale;
174
175 /* If non-zero, emacs should not attempt to use a window-specific code,
176 but instead should use the virtual terminal under which it was started. */
177 int inhibit_window_system;
178
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
181 priority; those functions have their own extern declaration. */
182 EMACS_INT emacs_priority;
183
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. */
186 int running_asynch_code;
187
188 #ifdef BSD_PGRPS
189 /* See sysdep.c. */
190 extern int inherited_pgroup;
191 #endif
192
193 #ifdef HAVE_X_WINDOWS
194 /* If non-zero, -d was specified, meaning we're using some window system. */
195 int 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. */
200 char *stack_bottom;
201
202 /* The address where the heap starts (from the first sbrk (0) call). */
203 static void *my_heap_start;
204
205 /* The gap between BSS end and heap start as far as we can tell. */
206 static 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
213 #ifdef HAVE_WINDOW_SYSTEM
214 extern Lisp_Object Vwindow_system;
215 #endif /* HAVE_WINDOW_SYSTEM */
216
217 extern Lisp_Object Vauto_save_list_file_name;
218
219 extern Lisp_Object Vinhibit_redisplay;
220
221 #ifdef USG_SHARED_LIBRARIES
222 /* If nonzero, this is the place to put the end of the writable segment
223 at startup. */
224
225 unsigned int bss_end = 0;
226 #endif
227
228 /* Nonzero means running Emacs without interactive terminal. */
229
230 int 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
236 int noninteractive1;
237
238 /* Save argv and argc. */
239 char **initial_argv;
240 int initial_argc;
241
242 static void sort_args ();
243 void syms_of_emacs ();
244
245 /* MSVC needs each string be shorter than 2048 bytes, so the usage
246 strings below are split to not overflow this limit. */
247 #define USAGE1 "\
248 Usage: %s [OPTION-OR-FILENAME]...\n\
249 \n\
250 Run Emacs, the extensible, customizable, self-documenting real-time\n\
251 display editor. The recommended way to start Emacs for normal editing\n\
252 is with no options at all.\n\
253 \n\
254 Run M-x info RET m emacs RET m emacs invocation RET inside Emacs to\n\
255 read the main documentation for these command-line arguments.\n\
256 \n\
257 Initialization options:\n\
258 \n\
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\
268 --no-window-system, -nw do not communicate with X, ignoring $DISPLAY\n\
269 --quick, -Q equivalent to -q --no-site-file\n\
270 --script FILE run FILE as an Emacs Lisp script\n\
271 --terminal, -t DEVICE use DEVICE for terminal I/O\n\
272 --unibyte, --no-multibyte run Emacs in unibyte mode\n\
273 --user, -u USER load ~USER/.emacs instead of your own\n\
274 \n%s"
275
276 #define USAGE2 "\
277 Action options:\n\
278 \n\
279 FILE 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\
293 \n"
294
295 #define USAGE3 "\
296 Display options:\n\
297 \n\
298 --background-color, -bg COLOR window background color\n\
299 --basic-display, -D disable many display features;\n\
300 used for debugging Emacs\n\
301 --border-color, -bd COLOR main border color\n\
302 --border-width, -bw WIDTH width of main border\n\
303 --color, --color=MODE color mode for character terminals;\n\
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\
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\
320 --no-blinking-cursor, -nbc disable blinking cursor\n\
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\
327 \n"
328
329 #define USAGE4 "\
330 You can generally also specify long option names with a single -; for\n\
331 example, -batch as well as --batch. You can use any unambiguous\n\
332 abbreviation for a --option.\n\
333 \n\
334 Various environment variables and window system resources also affect\n\
335 Emacs' operation. See the main documentation.\n\
336 \n\
337 Report bugs to %s. First, please see the Bugs\n\
338 section of the Emacs manual or the file BUGS.\n"
339
340 \f
341 /* Signal code for the fatal signal that was received. */
342 int fatal_error_code;
343
344 /* Nonzero if handling a fatal error already. */
345 int fatal_error_in_progress;
346
347 /* If non-null, call this function from fatal_error_signal before
348 committing suicide. */
349
350 void (*fatal_error_signal_hook) P_ ((void));
351
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
357 pthread_t main_thread;
358 #endif
359
360
361 #ifdef SIGUSR1
362 SIGTYPE
363 handle_USR1_signal (sig)
364 int sig;
365 {
366 struct input_event buf;
367
368 SIGNAL_THREAD_CHECK (sig);
369 bzero (&buf, sizeof buf);
370 buf.kind = USER_SIGNAL_EVENT;
371 buf.frame_or_window = selected_frame;
372
373 kbd_buffer_store_event (&buf);
374 }
375 #endif /* SIGUSR1 */
376
377 #ifdef SIGUSR2
378 SIGTYPE
379 handle_USR2_signal (sig)
380 int sig;
381 {
382 struct input_event buf;
383
384 SIGNAL_THREAD_CHECK (sig);
385 bzero (&buf, sizeof buf);
386 buf.kind = USER_SIGNAL_EVENT;
387 buf.code = 1;
388 buf.frame_or_window = selected_frame;
389
390 kbd_buffer_store_event (&buf);
391 }
392 #endif /* SIGUSR2 */
393
394 /* Handle bus errors, invalid instruction, etc. */
395 SIGTYPE
396 fatal_error_signal (sig)
397 int sig;
398 {
399 SIGNAL_THREAD_CHECK (sig);
400 fatal_error_code = sig;
401 signal (sig, SIG_DFL);
402
403 TOTALLY_UNBLOCK_INPUT;
404
405 /* If fatal error occurs in code below, avoid infinite recursion. */
406 if (! fatal_error_in_progress)
407 {
408 fatal_error_in_progress = 1;
409
410 shut_down_emacs (sig, 0, Qnil);
411 }
412
413 #ifdef VMS
414 LIB$STOP (SS$_ABORT);
415 #else
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. */
420 #ifndef MSDOS
421 sigunblock (sigmask (fatal_error_code));
422 #endif
423
424 if (fatal_error_signal_hook)
425 fatal_error_signal_hook ();
426
427 kill (getpid (), fatal_error_code);
428 #endif /* not VMS */
429 }
430
431 #ifdef SIGDANGER
432
433 /* Handler for SIGDANGER. */
434 SIGTYPE
435 memory_warning_signal (sig)
436 int sig;
437 {
438 signal (sig, memory_warning_signal);
439 SIGNAL_THREAD_CHECK (sig);
440
441 malloc_warning ("Operating system warns that virtual memory is running low.\n");
442
443 /* It might be unsafe to call do_auto_save now. */
444 force_auto_save_soon ();
445 }
446 #endif
447
448 /* We define abort, rather than using it from the library,
449 so that GDB can return from a breakpoint here.
450 MSDOS has its own definition in msdos.c. */
451
452 #if ! defined (DOS_NT) && ! defined (NO_ABORT)
453
454 #ifndef ABORT_RETURN_TYPE
455 #define ABORT_RETURN_TYPE void
456 #endif
457
458 ABORT_RETURN_TYPE
459 abort ()
460 {
461 kill (getpid (), SIGABRT);
462 /* This shouldn't be executed, but it prevents a warning. */
463 exit (1);
464 }
465 #endif
466
467 \f
468 /* Code for dealing with Lisp access to the Unix command line. */
469
470 static void
471 init_cmdargs (argc, argv, skip_args)
472 int argc;
473 char **argv;
474 int skip_args;
475 {
476 register int i;
477 Lisp_Object name, dir, tem;
478 int count = SPECPDL_INDEX ();
479 Lisp_Object raw_name;
480
481 initial_argv = argv;
482 initial_argc = argc;
483
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
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,
501 Vexec_suffixes, &found, make_number (X_OK));
502 if (yes == 1)
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 }
511 }
512
513 if (!NILP (Vinvocation_directory)
514 && NILP (Ffile_name_absolute_p (Vinvocation_directory)))
515 /* Emacs was started with relative path, like ./emacs.
516 Make it absolute. */
517 Vinvocation_directory = Fexpand_file_name (Vinvocation_directory, Qnil);
518
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 {
527 Lisp_Object tem, lib_src_exists;
528 Lisp_Object etc_exists, info_exists;
529
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);
535
536 #ifdef MSDOS
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);
542 #else
543 info_exists = Qnil;
544 #endif
545
546 if (!NILP (lib_src_exists) || !NILP (info_exists))
547 {
548 tem = Fexpand_file_name (build_string ("etc"), dir);
549 etc_exists = Ffile_exists_p (tem);
550 if (!NILP (etc_exists))
551 {
552 Vinstallation_directory
553 = Ffile_name_as_directory (dir);
554 break;
555 }
556 }
557
558 /* See if dir's parent contains those subdirs. */
559 tem = Fexpand_file_name (build_string ("../lib-src"), dir);
560 lib_src_exists = Ffile_exists_p (tem);
561
562
563 #ifdef MSDOS
564 /* See the MSDOS commentary above. */
565 tem = Fexpand_file_name (build_string ("../info"), dir);
566 info_exists = Ffile_exists_p (tem);
567 #else
568 info_exists = Qnil;
569 #endif
570
571 if (!NILP (lib_src_exists) || !NILP (info_exists))
572 {
573 tem = Fexpand_file_name (build_string ("../etc"), dir);
574 etc_exists = Ffile_exists_p (tem);
575 if (!NILP (etc_exists))
576 {
577 tem = Fexpand_file_name (build_string (".."), dir);
578 Vinstallation_directory
579 = Ffile_name_as_directory (tem);
580 break;
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 {
589 name = Fexpand_file_name (tem, dir);
590 dir = Ffile_name_directory (name);
591 }
592 else
593 break;
594 }
595 }
596
597 Vcommand_line_args = Qnil;
598
599 for (i = argc - 1; i >= 0; i--)
600 {
601 if (i == 0 || i > skip_args)
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. */
605 Vcommand_line_args
606 = Fcons (make_unibyte_string (argv[i], strlen (argv[i])),
607 Vcommand_line_args);
608 }
609
610 unbind_to (count, Qnil);
611 }
612
613 DEFUN ("invocation-name", Finvocation_name, Sinvocation_name, 0, 0, 0,
614 doc: /* Return the program name that was used to run Emacs.
615 Any directory names are omitted. */)
616 ()
617 {
618 return Fcopy_sequence (Vinvocation_name);
619 }
620
621 DEFUN ("invocation-directory", Finvocation_directory, Sinvocation_directory,
622 0, 0, 0,
623 doc: /* Return the directory name in which the Emacs executable was located. */)
624 ()
625 {
626 return Fcopy_sequence (Vinvocation_directory);
627 }
628
629 \f
630 #ifdef VMS
631 #ifdef LINK_CRTL_SHARE
632 #ifdef SHARABLE_LIB_BUG
633 extern noshare char **environ;
634 #endif /* SHARABLE_LIB_BUG */
635 #endif /* LINK_CRTL_SHARE */
636 #endif /* VMS */
637
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. */
641 static char dump_tz[] = "UtC0";
642 #endif
643
644 #ifndef ORDINARY_LINK
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__
650 #ifndef GCC_CTORS_IN_LIBC
651 void __do_global_ctors ()
652 {}
653 void __do_global_ctors_aux ()
654 {}
655 void __do_global_dtors ()
656 {}
657 /* GNU/Linux has a bug in its library; avoid an error. */
658 #ifndef GNU_LINUX
659 char * __CTOR_LIST__[2] = { (char *) (-1), 0 };
660 #endif
661 char * __DTOR_LIST__[2] = { (char *) (-1), 0 };
662 #endif /* GCC_CTORS_IN_LIBC */
663 void __main ()
664 {}
665 #endif /* __GNUC__ */
666 #endif /* ORDINARY_LINK */
667
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. */
677
678 static int
679 argmatch (argv, argc, sstr, lstr, minlen, valptr, skipptr)
680 char **argv;
681 int argc;
682 char *sstr;
683 char *lstr;
684 int minlen;
685 char **valptr;
686 int *skipptr;
687 {
688 char *p = NULL;
689 int arglen;
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];
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));
712 if (lstr == 0 || arglen < minlen || strncmp (arg, lstr, arglen) != 0)
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
737 #ifdef DOUG_LEA_MALLOC
738
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
743 static void
744 malloc_initialize_hook ()
745 {
746 #ifndef USE_CRT_DLL
747 extern char **environ;
748 #endif
749
750 if (initialized)
751 {
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
755 malloc checking. Can't use unsetenv, since that calls malloc. */
756 {
757 char **p;
758
759 for (p = environ; p && *p; p++)
760 if (strncmp (*p, "MALLOC_CHECK_=", 14) == 0)
761 {
762 do
763 *p = p[1];
764 while (*++p);
765 break;
766 }
767 }
768
769 malloc_set_state (malloc_state_ptr);
770 #ifndef XMALLOC_OVERRUN_CHECK
771 free (malloc_state_ptr);
772 #endif
773 }
774 else
775 {
776 if (my_heap_start == 0)
777 my_heap_start = sbrk (0);
778 malloc_using_checking = getenv ("MALLOC_CHECK_") != NULL;
779 }
780 }
781
782 void (*__malloc_initialize_hook) () = malloc_initialize_hook;
783
784 #endif /* DOUG_LEA_MALLOC */
785
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
793 char *
794 bug_reporting_address ()
795 {
796 int count = 0;
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
806 string = SDATA (temp);
807
808 /* Count dots in `emacs-version'. */
809 while (*string)
810 {
811 if (*string == '.')
812 count++;
813 string++;
814 }
815
816 /* When `emacs-version' has at least three dots, it is development or
817 pretest version of Emacs. */
818 return count >= 3 ? REPORT_EMACS_BUG_PRETEST_ADDRESS : REPORT_EMACS_BUG_ADDRESS;
819 }
820
821
822 /* ARGSUSED */
823 int
824 main (argc, argv
825 #ifdef VMS
826 , envp
827 #endif
828 )
829 int argc;
830 char **argv;
831 #ifdef VMS
832 char **envp;
833 #endif
834 {
835 #if GC_MARK_STACK
836 Lisp_Object dummy;
837 #endif
838 char stack_bottom_variable;
839 int do_initial_setlocale;
840 int skip_args = 0;
841 #ifndef USE_CRT_DLL
842 extern int errno;
843 #endif
844 #ifdef HAVE_SETRLIMIT
845 struct rlimit rlim;
846 #endif
847 int no_loadup = 0;
848 char *junk = 0;
849
850 #if GC_MARK_STACK
851 extern Lisp_Object *stack_base;
852 stack_base = &dummy;
853 #endif
854
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
866 #ifdef LINUX_SBRK_BUG
867 __sbrk (1);
868 #endif
869
870 #ifdef RUN_TIME_REMAP
871 if (initialized)
872 run_time_remap (argv[0]);
873 #endif
874
875 #ifdef MAC_OSX
876 if (!initialized)
877 unexec_init_emacs_zone ();
878 #endif
879
880 sort_args (argc, argv);
881 argc = 0;
882 while (argv[argc]) argc++;
883
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)
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 {
898 printf ("GNU Emacs %s\n", SDATA (tem));
899 printf ("Copyright (C) 2004 Free Software Foundation, Inc.\n");
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, ");
904 printf ("see the file named COPYING.\n");
905 exit (0);
906 }
907 }
908
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");
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
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
937 /* Map in shared memory, if we are using that. */
938 #ifdef HAVE_SHM
939 if (argmatch (argv, argc, "-nl", "--no-shared-memory", 6, NULL, &skip_args))
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
953 #ifdef NeXT
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 }
961 #endif /* NeXT */
962
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
970 #ifdef VMS
971 /* If -map specified, map the data file in. */
972 {
973 char *file;
974 if (argmatch (argv, argc, "-map", "--map-data", 3, &file, &skip_args))
975 mapin_data (file);
976 }
977
978 #ifdef LINK_CRTL_SHARE
979 #ifdef SHARABLE_LIB_BUG
980 /* Bletcherous shared libraries! */
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;
989 #endif /* SHARABLE_LIB_BUG */
990 #endif /* LINK_CRTL_SHARE */
991 #endif /* VMS */
992
993 #if defined (HAVE_SETRLIMIT) && defined (RLIMIT_STACK)
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))
1002 {
1003 long newlim;
1004 extern int re_max_failures;
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;
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
1020 if (newlim > rlim.rlim_max)
1021 {
1022 newlim = rlim.rlim_max;
1023 /* Don't let regex.c overflow the stack we have. */
1024 re_max_failures = (newlim - 200000) / ratio;
1025 }
1026 if (rlim.rlim_cur < newlim)
1027 rlim.rlim_cur = newlim;
1028
1029 setrlimit (RLIMIT_STACK, &rlim);
1030 }
1031 #endif /* HAVE_SETRLIMIT and RLIMIT_STACK */
1032
1033 /* Record (approximately) where the stack begins. */
1034 stack_bottom = &stack_bottom_variable;
1035
1036 #ifdef USG_SHARED_LIBRARIES
1037 if (bss_end)
1038 brk ((void *)bss_end);
1039 #endif
1040
1041 clearerr (stdin);
1042
1043 #ifndef SYSTEM_MALLOC
1044 /* Arrange to get warning messages as memory fills up. */
1045 memory_warnings (0, malloc_warning);
1046
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));
1050
1051 # ifndef SYNC_INPUT
1052 /* Arrange to disable interrupt input inside malloc etc. */
1053 uninterrupt_malloc ();
1054 # endif /* not SYNC_INPUT */
1055 #endif /* not SYSTEM_MALLOC */
1056
1057 #ifdef HAVE_GTK_AND_PTHREAD
1058 main_thread = pthread_self ();
1059 #endif /* HAVE_GTK_AND_PTHREAD */
1060
1061 #if defined (MSDOS) || defined (WINDOWSNT)
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;
1065 #endif /* MSDOS || WINDOWSNT */
1066
1067 #ifdef MSDOS
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 */
1077 (stdin)->_flag &= ~_IOTEXT;
1078 (stdout)->_flag &= ~_IOTEXT;
1079 (stderr)->_flag &= ~_IOTEXT;
1080 #endif /* not __DJGPP__ >= 2 */
1081 #endif /* MSDOS */
1082
1083 #ifdef SET_EMACS_PRIORITY
1084 if (emacs_priority)
1085 nice (emacs_priority);
1086 setuid (getuid ());
1087 #endif /* SET_EMACS_PRIORITY */
1088
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
1103 #ifdef EXTRA_INITIALIZE
1104 EXTRA_INITIALIZE;
1105 #endif
1106
1107 inhibit_window_system = 0;
1108
1109 /* Handle the -t switch, which specifies filename to use as terminal. */
1110 while (1)
1111 {
1112 char *term;
1113 if (argmatch (argv, argc, "-t", "--terminal", 4, &term, &skip_args))
1114 {
1115 int result;
1116 emacs_close (0);
1117 emacs_close (1);
1118 result = emacs_open (term, O_RDWR, 0);
1119 if (result < 0)
1120 {
1121 char *errstring = strerror (errno);
1122 fprintf (stderr, "%s: %s: %s\n", argv[0], term, errstring);
1123 exit (1);
1124 }
1125 dup (0);
1126 if (! isatty (0))
1127 {
1128 fprintf (stderr, "%s: %s: not a tty\n", argv[0], term);
1129 exit (1);
1130 }
1131 fprintf (stderr, "Using %s\n", term);
1132 #ifdef HAVE_WINDOW_SYSTEM
1133 inhibit_window_system = 1; /* -t => -nw */
1134 #endif
1135 }
1136 else
1137 break;
1138 }
1139
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))
1144 inhibit_window_system = 1;
1145
1146 /* Handle the -batch switch, which means don't do interactive display. */
1147 noninteractive = 0;
1148 if (argmatch (argv, argc, "-batch", "--batch", 5, NULL, &skip_args))
1149 {
1150 noninteractive = 1;
1151 Vundo_outer_limit = Qnil;
1152 }
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 }
1162
1163 /* Handle the --help option, which gives a usage message. */
1164 if (argmatch (argv, argc, "-help", "--help", 3, NULL, &skip_args))
1165 {
1166 printf (USAGE1, argv[0], USAGE2);
1167 printf (USAGE3);
1168 printf (USAGE4, bug_reporting_address ());
1169 exit (0);
1170 }
1171
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
1187 init_signals ();
1188
1189 /* Don't catch SIGHUP if dumping. */
1190 if (1
1191 #ifndef CANNOT_DUMP
1192 && initialized
1193 #endif
1194 )
1195 {
1196 sigblock (sigmask (SIGHUP));
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);
1202 sigunblock (sigmask (SIGHUP));
1203 }
1204
1205 if (
1206 #ifndef CANNOT_DUMP
1207 ! noninteractive || initialized
1208 #else
1209 1
1210 #endif
1211 )
1212 {
1213 /* Don't catch these signals in batch mode if dumping.
1214 On some machines, this sets static data that would make
1215 signal fail to work right when the dumped Emacs is run. */
1216 signal (SIGQUIT, fatal_error_signal);
1217 signal (SIGILL, fatal_error_signal);
1218 signal (SIGTRAP, fatal_error_signal);
1219 #ifdef SIGUSR1
1220 signal (SIGUSR1, handle_USR1_signal);
1221 #ifdef SIGUSR2
1222 signal (SIGUSR2, handle_USR2_signal);
1223 #endif
1224 #endif
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
1246 #ifdef SIGIOT
1247 /* This is missing on some systems - OS/2, for example. */
1248 signal (SIGIOT, fatal_error_signal);
1249 #endif
1250 #ifdef SIGEMT
1251 signal (SIGEMT, fatal_error_signal);
1252 #endif
1253 signal (SIGFPE, fatal_error_signal);
1254 #ifdef SIGBUS
1255 signal (SIGBUS, fatal_error_signal);
1256 #endif
1257 signal (SIGSEGV, fatal_error_signal);
1258 #ifdef SIGSYS
1259 signal (SIGSYS, fatal_error_signal);
1260 #endif
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
1269 #ifdef SIGDANGER
1270 /* This just means available memory is getting low. */
1271 signal (SIGDANGER, memory_warning_signal);
1272 #endif
1273
1274 #ifdef AIX
1275 /* 20 is SIGCHLD, 21 is SIGTTIN, 22 is SIGTTOU. */
1276 signal (SIGXCPU, fatal_error_signal);
1277 #ifndef _I386
1278 signal (SIGIOINT, fatal_error_signal);
1279 #endif
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
1289 /* Perform basic initializations (not merely interning symbols). */
1290
1291 if (!initialized)
1292 {
1293 init_alloc_once ();
1294 init_obarray ();
1295 init_eval_once ();
1296 init_charset_once ();
1297 init_coding_once ();
1298 init_syntax_once (); /* Create standard syntax table. */
1299 init_category_once (); /* Create standard category table. */
1300 /* Must be done before init_buffer. */
1301 init_casetab_once ();
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
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. */
1310 syms_of_xfaces ();
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 ();
1316
1317 #ifdef MAC_OS8
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,
1322 syms_of_frame, mac_term_init, and init_keyboard have already
1323 been called. */
1324 syms_of_textprop ();
1325 syms_of_macfns ();
1326 syms_of_ccl ();
1327 syms_of_fontset ();
1328 syms_of_macterm ();
1329 syms_of_macmenu ();
1330 syms_of_macselect ();
1331 syms_of_data ();
1332 syms_of_search ();
1333 syms_of_frame ();
1334
1335 init_atimer ();
1336 mac_term_init (build_string ("Mac"), NULL, NULL);
1337 init_keyboard ();
1338 #endif
1339
1340 init_window_once (); /* Init the window system. */
1341 init_fileio_once (); /* Must precede any path manipulation. */
1342 #ifdef HAVE_WINDOW_SYSTEM
1343 init_fringe_once (); /* Swap bitmaps if necessary. */
1344 #endif /* HAVE_WINDOW_SYSTEM */
1345 }
1346
1347 init_alloc ();
1348
1349 if (do_initial_setlocale)
1350 {
1351 fixup_locale ();
1352 Vsystem_messages_locale = Vprevious_system_messages_locale;
1353 Vsystem_time_locale = Vprevious_system_time_locale;
1354 }
1355
1356 init_eval ();
1357 init_data ();
1358 #ifdef CLASH_DETECTION
1359 init_filelock ();
1360 #endif
1361 #ifndef MAC_OS8
1362 init_atimer ();
1363 #endif
1364 running_asynch_code = 0;
1365
1366 /* Handle --unibyte and the EMACS_UNIBYTE envvar,
1367 but not while dumping. */
1368 if (1)
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)
1374 || argmatch (argv, argc, "-multibyte", "--multibyte", 4, NULL, &skip_args)
1375 /* Ignore EMACS_UNIBYTE before dumping. */
1376 || (!initialized && noninteractive))
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. */
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
1388 unibyte and Latin-1 in .emacs. -- Dave Love */
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
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 }
1407
1408 for (tail = Vbuffer_alist; CONSP (tail);
1409 tail = XCDR (tail))
1410 {
1411 Lisp_Object buffer;
1412
1413 buffer = Fcdr (XCAR (tail));
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
1424 no_loadup
1425 = argmatch (argv, argc, "-nl", "--no-loadup", 6, NULL, &skip_args);
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;
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
1483 #ifdef MSDOS
1484 /* Call early 'cause init_environment needs it. */
1485 init_dosfns ();
1486 /* Set defaults for several environment variables. */
1487 if (initialized)
1488 init_environment (argc, argv, skip_args);
1489 else
1490 tzset ();
1491 #endif /* MSDOS */
1492
1493 #ifdef WINDOWSNT
1494 globals_of_w32 ();
1495 /* Initialize environment from registry settings. */
1496 init_environment (argv);
1497 init_ntproc (); /* must precede init_editfns. */
1498 #endif
1499
1500 #if defined (MAC_OSX) && defined (HAVE_CARBON)
1501 if (initialized)
1502 init_mac_osx_environment ();
1503 #endif
1504
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 ();
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. */
1512 /* Setting LANG here will defeat the startup locale processing... */
1513 #ifdef AIX3_2
1514 putenv ("LANG=C");
1515 #endif
1516
1517 init_buffer (); /* Init default directory of main buffer. */
1518
1519 init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */
1520 init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */
1521
1522 if (initialized)
1523 {
1524 /* Erase any pre-dump messages in the message log, to avoid confusion. */
1525 Lisp_Object old_log_max;
1526 old_log_max = Vmessage_log_max;
1527 XSETFASTINT (Vmessage_log_max, 0);
1528 message_dolog ("", 0, 1, 0);
1529 Vmessage_log_max = old_log_max;
1530 }
1531
1532 init_callproc (); /* Must follow init_cmdargs but not init_sys_modes. */
1533 init_lread ();
1534
1535 /* Intern the names of all standard functions and variables;
1536 define standard keys. */
1537
1538 if (!initialized)
1539 {
1540 /* The basic levels of Lisp must come first. */
1541 /* And data must come first of all
1542 for the sake of symbols like error-message. */
1543 #ifndef MAC_OS8
1544 /* Called before init_window_once for Mac OS Classic. */
1545 syms_of_data ();
1546 #endif
1547 syms_of_alloc ();
1548 syms_of_lread ();
1549 syms_of_print ();
1550 syms_of_eval ();
1551 syms_of_fns ();
1552 syms_of_floatfns ();
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 ();
1561 syms_of_category ();
1562 #ifndef MAC_OS8
1563 /* Called before init_window_once for Mac OS Classic. */
1564 syms_of_ccl ();
1565 #endif
1566 syms_of_charset ();
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 ();
1576 syms_of_coding (); /* This should be after syms_of_fileio. */
1577 #ifdef CLASH_DETECTION
1578 syms_of_filelock ();
1579 #endif /* CLASH_DETECTION */
1580 syms_of_indent ();
1581 syms_of_insdel ();
1582 syms_of_keymap ();
1583 syms_of_macros ();
1584 syms_of_marker ();
1585 syms_of_minibuf ();
1586 syms_of_process ();
1587 #ifndef MAC_OS8
1588 /* Called before init_window_once for Mac OS Classic. */
1589 syms_of_search ();
1590 syms_of_frame ();
1591 #endif
1592 syms_of_syntax ();
1593 syms_of_term ();
1594 syms_of_undo ();
1595 #ifdef HAVE_SOUND
1596 syms_of_sound ();
1597 #endif
1598 #ifndef MAC_OS8
1599 /* Called before init_window_once for Mac OS Classic. */
1600 syms_of_textprop ();
1601 #endif
1602 syms_of_composite ();
1603 #ifdef VMS
1604 syms_of_vmsproc ();
1605 #endif /* VMS */
1606 #ifdef WINDOWSNT
1607 syms_of_ntproc ();
1608 #endif /* WINDOWSNT */
1609 syms_of_window ();
1610 syms_of_xdisp ();
1611 #ifdef HAVE_WINDOW_SYSTEM
1612 syms_of_fringe ();
1613 syms_of_image ();
1614 #endif /* HAVE_WINDOW_SYSTEM */
1615 #ifdef HAVE_X_WINDOWS
1616 syms_of_xterm ();
1617 syms_of_xfns ();
1618 syms_of_fontset ();
1619 #ifdef HAVE_X_SM
1620 syms_of_xsmfns ();
1621 #endif
1622 #ifdef HAVE_X11
1623 syms_of_xselect ();
1624 #endif
1625 #endif /* HAVE_X_WINDOWS */
1626
1627 #ifdef HAVE_MENUS
1628 #ifndef HAVE_NTGUI
1629 #ifndef MAC_OS
1630 /* Called before init_window_once for Mac OS Classic. */
1631 syms_of_xmenu ();
1632 #endif
1633 #endif
1634 #endif
1635
1636 #ifdef HAVE_NTGUI
1637 syms_of_w32term ();
1638 syms_of_w32fns ();
1639 syms_of_w32select ();
1640 syms_of_w32menu ();
1641 syms_of_fontset ();
1642 #endif /* HAVE_NTGUI */
1643
1644 #if defined (MAC_OSX) && defined (HAVE_CARBON)
1645 syms_of_macterm ();
1646 syms_of_macfns ();
1647 syms_of_macmenu ();
1648 syms_of_macselect ();
1649 syms_of_fontset ();
1650 #endif /* MAC_OSX && HAVE_CARBON */
1651
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 ();
1665 keys_of_minibuf ();
1666 keys_of_window ();
1667 }
1668 else
1669 {
1670 /* Initialization that must be done even if the global variable
1671 initialized is non zero. */
1672 #ifdef HAVE_NTGUI
1673 globals_of_w32fns ();
1674 globals_of_w32menu ();
1675 globals_of_w32select ();
1676 #endif /* HAVE_NTGUI */
1677 }
1678
1679 if (!noninteractive)
1680 {
1681 #ifdef VMS
1682 init_vms_input ();/* init_display calls get_frame_size, that needs this. */
1683 #endif /* VMS */
1684 init_display (); /* Determine terminal type. init_sys_modes uses results. */
1685 }
1686 #ifndef MAC_OS8
1687 /* Called before init_window_once for Mac OS Classic. */
1688 init_keyboard (); /* This too must precede init_sys_modes. */
1689 #endif
1690 #ifdef VMS
1691 init_vmsproc (); /* And this too. */
1692 #endif /* VMS */
1693 init_sys_modes (); /* Init system terminal modes (RAW or CBREAK, etc.). */
1694 init_fns ();
1695 init_xdisp ();
1696 #ifdef HAVE_WINDOW_SYSTEM
1697 init_fringe ();
1698 init_image ();
1699 #endif /* HAVE_WINDOW_SYSTEM */
1700 init_macros ();
1701 init_editfns ();
1702 init_floatfns ();
1703 #ifdef VMS
1704 init_vmsfns ();
1705 #endif /* VMS */
1706 init_process ();
1707 #ifdef HAVE_SOUND
1708 init_sound ();
1709 #endif
1710 init_window ();
1711
1712 if (!initialized)
1713 {
1714 char *file;
1715 /* Handle -l loadup, args passed by Makefile. */
1716 if (argmatch (argv, argc, "-l", "--load", 3, &file, &skip_args))
1717 Vtop_level = Fcons (intern ("load"),
1718 Fcons (build_string (file), Qnil));
1719 /* Unless next switch is -nl, load "loadup.el" first thing. */
1720 if (! no_loadup)
1721 Vtop_level = Fcons (intern ("load"),
1722 Fcons (build_string ("loadup.el"), Qnil));
1723 }
1724
1725 if (initialized)
1726 {
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
1743 }
1744
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
1748 profiling use something like `make CFLAGS="-pg -g -O -DPROFILING=1'. */
1749 #if defined (__FreeBSD__) || defined (__linux)
1750 #ifdef PROFILING
1751 if (initialized)
1752 {
1753 extern void _mcleanup ();
1754 extern char etext;
1755 extern void safe_bcopy ();
1756 extern void dump_opcode_frequencies ();
1757
1758 atexit (_mcleanup);
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);
1764 }
1765 else
1766 moncontrol (0);
1767 #endif
1768 #endif
1769
1770 initialized = 1;
1771
1772 #ifdef LOCALTIME_CACHE
1773 /* Some versions of localtime have a bug. They cache the value of the time
1774 zone rather than looking it up every time. Since localtime() is
1775 called to bolt the undumping time into the undumped emacs, this
1776 results in localtime ignoring the TZ environment variable.
1777 This flushes the new TZ value into localtime. */
1778 tzset ();
1779 #endif /* defined (LOCALTIME_CACHE) */
1780
1781 /* Enter editor command loop. This never returns. */
1782 Frecursive_edit ();
1783 /* NOTREACHED */
1784 return 0;
1785 }
1786 \f
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
1792 struct standard_args
1793 {
1794 char *name;
1795 char *longname;
1796 int priority;
1797 int nargs;
1798 };
1799
1800 struct standard_args standard_args[] =
1801 {
1802 { "-version", "--version", 150, 0 },
1803 #ifdef HAVE_SHM
1804 { "-nl", "--no-shared-memory", 140, 0 },
1805 #endif
1806 #ifdef VMS
1807 { "-map", "--map-data", 130, 0 },
1808 #endif
1809 { "-t", "--terminal", 120, 1 },
1810 { "-nw", "--no-window-system", 110, 0 },
1811 { "-nw", "--no-windows", 110, 0 },
1812 { "-batch", "--batch", 100, 0 },
1813 { "-script", "--script", 100, 1 },
1814 { "-help", "--help", 90, 0 },
1815 { "-no-unibyte", "--no-unibyte", 83, 0 },
1816 { "-multibyte", "--multibyte", 82, 0 },
1817 { "-unibyte", "--unibyte", 81, 0 },
1818 { "-no-multibyte", "--no-multibyte", 80, 0 },
1819 { "-nl", "--no-loadup", 70, 0 },
1820 /* -d must come last before the options handled in startup.el. */
1821 { "-d", "--display", 60, 1 },
1822 { "-display", 0, 60, 1 },
1823 /* Now for the options handled in startup.el. */
1824 { "-Q", "--quick", 55, 0 },
1825 { "-quick", 0, 55, 0 },
1826 { "-q", "--no-init-file", 50, 0 },
1827 { "-no-init-file", 0, 50, 0 },
1828 { "-no-site-file", "--no-site-file", 40, 0 },
1829 { "-no-splash", "--no-splash", 40, 0 },
1830 { "-u", "--user", 30, 1 },
1831 { "-user", 0, 30, 1 },
1832 { "-debug-init", "--debug-init", 20, 0 },
1833 { "-i", "--icon-type", 15, 0 },
1834 { "-itype", 0, 15, 0 },
1835 { "-iconic", "--iconic", 15, 0 },
1836 { "-D", "--basic-display", 12, 0},
1837 { "--basic-display", 0, 12, 0},
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 },
1847 { "-nbc", "--no-blinking-cursor", 10, 0 },
1848 { "-fn", "--font", 10, 1 },
1849 { "-font", 0, 10, 1 },
1850 { "-fs", "--fullscreen", 10, 0 },
1851 { "-fw", "--fullwidth", 10, 0 },
1852 { "-fh", "--fullheight", 10, 0 },
1853 { "-g", "--geometry", 10, 1 },
1854 { "-geometry", 0, 10, 1 },
1855 { "-T", "--title", 10, 1 },
1856 { "-title", 0, 10, 1 },
1857 { "-name", "--name", 10, 1 },
1858 { "-xrm", "--xrm", 10, 1 },
1859 { "-r", "--reverse-video", 5, 0 },
1860 { "-rv", 0, 5, 0 },
1861 { "-reverse", 0, 5, 0 },
1862 { "-hb", "--horizontal-scroll-bars", 5, 0 },
1863 { "-vb", "--vertical-scroll-bars", 5, 0 },
1864 { "-color", "--color", 5, 0},
1865 /* These have the same priority as ordinary file name args,
1866 so they are not reordered with respect to those. */
1867 { "-L", "--directory", 0, 1 },
1868 { "-directory", 0, 0, 1 },
1869 { "-l", "--load", 0, 1 },
1870 { "-load", 0, 0, 1 },
1871 { "-f", "--funcall", 0, 1 },
1872 { "-funcall", 0, 0, 1 },
1873 { "-eval", "--eval", 0, 1 },
1874 { "-execute", "--execute", 0, 1 },
1875 { "-find-file", "--find-file", 0, 1 },
1876 { "-visit", "--visit", 0, 1 },
1877 { "-file", "--file", 0, 1 },
1878 { "-insert", "--insert", 0, 1 },
1879 /* This should be processed after ordinary file name args and the like. */
1880 { "-kill", "--kill", -10, 0 },
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.
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. */
1890
1891 static void
1892 sort_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. */
1902 int *options = (int *) xmalloc (sizeof (int) * argc);
1903 int *priority = (int *) xmalloc (sizeof (int) * argc);
1904 int to = 1;
1905 int incoming_used = 1;
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;
1914 priority[from] = 0;
1915 if (argv[from][0] == '-')
1916 {
1917 int match, thislen;
1918 char *equals;
1919
1920 /* If we have found "--", don't consider
1921 any more arguments as options. */
1922 if (argv[from][1] == '-' && argv[from][2] == 0)
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
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;
1939 if (from + standard_args[i].nargs >= argc)
1940 fatal ("Option `%s' requires an argument\n", argv[from]);
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
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))
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;
1977 if (from + options[from] >= argc)
1978 fatal ("Option `%s' requires an argument\n", argv[from]);
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];
1988 while (incoming_used < argc)
1989 {
1990 int best = -1;
1991 int best_priority = -9999;
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 }
2006
2007 if (best < 0)
2008 abort ();
2009
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);
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
2028 /* If duplicate options were deleted, fill up extra space with null ptrs. */
2029 while (to < argc)
2030 new[to++] = 0;
2031
2032 bcopy (new, argv, sizeof (char *) * argc);
2033
2034 xfree (options);
2035 xfree (new);
2036 xfree (priority);
2037 }
2038 \f
2039 DEFUN ("kill-emacs", Fkill_emacs, Skill_emacs, 0, 1, "P",
2040 doc: /* Exit the Emacs job and kill it.
2041 If ARG is an integer, return ARG as the exit program code.
2042 If ARG is a string, stuff it as keyboard input.
2043
2044 The value of `kill-emacs-hook', if not void,
2045 is a list of functions (of no args),
2046 all of which are called before Emacs is actually killed. */)
2047 (arg)
2048 Lisp_Object arg;
2049 {
2050 struct gcpro gcpro1;
2051
2052 GCPRO1 (arg);
2053
2054 if (feof (stdin))
2055 arg = Qt;
2056
2057 if (!NILP (Vrun_hooks) && !noninteractive)
2058 call1 (Vrun_hooks, intern ("kill-emacs-hook"));
2059
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 */
2067
2068 shut_down_emacs (0, 0, STRINGP (arg) ? arg : Qnil);
2069
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))
2074 unlink (SDATA (Vauto_save_list_file_name));
2075
2076 exit (INTEGERP (arg) ? XINT (arg) : EXIT_SUCCESS);
2077 /* NOTREACHED */
2078 return Qnil;
2079 }
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. */
2092
2093 void
2094 shut_down_emacs (sig, no_x, stuff)
2095 int sig, no_x;
2096 Lisp_Object stuff;
2097 {
2098 /* Prevent running of hooks from now on. */
2099 Vrun_hooks = Qnil;
2100
2101 /* Don't update display from now on. */
2102 Vinhibit_redisplay = Qt;
2103
2104 /* If we are controlling the terminal, reset terminal modes. */
2105 #ifdef EMACS_HAVE_TTY_PGRP
2106 {
2107 int pgrp = EMACS_GETPGRP (0);
2108
2109 int tpgrp;
2110 if (EMACS_GET_TTY_PGRP (0, &tpgrp) != -1
2111 && tpgrp == pgrp)
2112 {
2113 fflush (stdout);
2114 reset_sys_modes ();
2115 if (sig && sig != SIGTERM)
2116 fprintf (stderr, "Fatal error (%d)", sig);
2117 }
2118 }
2119 #else
2120 fflush (stdout);
2121 reset_sys_modes ();
2122 #endif
2123
2124 stuff_buffered_input (stuff);
2125
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
2137 #if 0 /* This triggers a bug in XCloseDisplay and is not needed. */
2138 #ifdef HAVE_X_WINDOWS
2139 /* It's not safe to call intern here. Maybe we are crashing. */
2140 if (!noninteractive && SYMBOLP (Vwindow_system)
2141 && SCHARS (SYMBOL_NAME (Vwindow_system)) == 1
2142 && SREF (SYMBOL_NAME (Vwindow_system), 0) == 'x'
2143 && ! no_x)
2144 Fx_close_current_connection ();
2145 #endif /* HAVE_X_WINDOWS */
2146 #endif
2147
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
2154
2155 #ifdef WINDOWSNT
2156 term_ntproc ();
2157 #endif
2158
2159 /* Do this only if terminating normally, we want glyph matrices
2160 etc. in a core dump. */
2161 if (sig == 0 || sig == SIGTERM)
2162 {
2163 check_glyph_memory ();
2164 check_message_stack ();
2165 }
2166
2167 #ifdef MSDOS
2168 dos_cleanup ();
2169 #endif
2170 }
2171
2172
2173 \f
2174 #ifndef CANNOT_DUMP
2175
2176 #ifdef HAVE_SHM
2177
2178 DEFUN ("dump-emacs-data", Fdump_emacs_data, Sdump_emacs_data, 1, 1, 0,
2179 doc: /* Dump current state of Emacs into data file FILENAME.
2180 This function exists on systems that use HAVE_SHM. */)
2181 (filename)
2182 Lisp_Object filename;
2183 {
2184 extern char my_edata[];
2185 Lisp_Object tem;
2186
2187 check_pure_size ();
2188 CHECK_STRING (filename);
2189 filename = Fexpand_file_name (filename, Qnil);
2190
2191 tem = Vpurify_flag;
2192 Vpurify_flag = Qnil;
2193
2194 fflush (stdout);
2195 /* Tell malloc where start of impure now is. */
2196 /* Also arrange for warnings when nearly out of space. */
2197 #ifndef SYSTEM_MALLOC
2198 memory_warnings (my_edata, malloc_warning);
2199 #endif
2200 map_out_data (SDATA (filename));
2201
2202 Vpurify_flag = tem;
2203
2204 return Qnil;
2205 }
2206
2207 #else /* not HAVE_SHM */
2208
2209 DEFUN ("dump-emacs", Fdump_emacs, Sdump_emacs, 2, 2, 0,
2210 doc: /* Dump current state of Emacs into executable file FILENAME.
2211 Take symbols from SYMFILE (presumably the file you executed to run Emacs).
2212 This is used in the file `loadup.el' when building Emacs.
2213
2214 You must run Emacs in batch mode in order to dump it. */)
2215 (filename, symfile)
2216 Lisp_Object filename, symfile;
2217 {
2218 extern char my_edata[];
2219 Lisp_Object tem;
2220 Lisp_Object symbol;
2221 int count = SPECPDL_INDEX ();
2222
2223 check_pure_size ();
2224
2225 if (! noninteractive)
2226 error ("Dumping Emacs works only in batch mode");
2227
2228 #ifdef __linux__
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");
2233 fprintf (stderr, "heap (%lu byte). This usually means that exec-shield\n",
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");
2238 fprintf (stderr, "**************************************************\n");
2239 }
2240 #endif /* __linux__ */
2241
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. */
2245 symbol = intern ("command-line-processed");
2246 specbind (symbol, Qnil);
2247
2248 CHECK_STRING (filename);
2249 filename = Fexpand_file_name (filename, Qnil);
2250 if (!NILP (symfile))
2251 {
2252 CHECK_STRING (symfile);
2253 if (SCHARS (symfile))
2254 symfile = Fexpand_file_name (symfile, Qnil);
2255 }
2256
2257 tem = Vpurify_flag;
2258 Vpurify_flag = Qnil;
2259
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
2268 fflush (stdout);
2269 #ifdef VMS
2270 mapout_data (SDATA (filename));
2271 #else
2272 /* Tell malloc where start of impure now is. */
2273 /* Also arrange for warnings when nearly out of space. */
2274 #ifndef SYSTEM_MALLOC
2275 #ifndef WINDOWSNT
2276 /* On Windows, this was done before dumping, and that once suffices.
2277 Meanwhile, my_edata is not valid on Windows. */
2278 memory_warnings (my_edata, malloc_warning);
2279 #endif /* not WINDOWSNT */
2280 #endif
2281 #if !defined (SYSTEM_MALLOC) && defined (HAVE_GTK_AND_PTHREAD) && !defined SYNC_INPUT
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
2287 #ifdef DOUG_LEA_MALLOC
2288 malloc_state_ptr = malloc_get_state ();
2289 #endif
2290
2291 #ifdef USE_MMAP_FOR_BUFFERS
2292 mmap_set_vars (0);
2293 #endif
2294 unexec (SDATA (filename),
2295 !NILP (symfile) ? SDATA (symfile) : 0, my_edata, 0, 0);
2296 #ifdef USE_MMAP_FOR_BUFFERS
2297 mmap_set_vars (1);
2298 #endif
2299 #ifdef DOUG_LEA_MALLOC
2300 free (malloc_state_ptr);
2301 #endif
2302 #endif /* not VMS */
2303
2304 Vpurify_flag = tem;
2305
2306 return unbind_to (count, Qnil);
2307 }
2308
2309 #endif /* not HAVE_SHM */
2310
2311 #endif /* not CANNOT_DUMP */
2312 \f
2313 #if HAVE_SETLOCALE
2314 /* Recover from setlocale (LC_ALL, ""). */
2315 void
2316 fixup_locale ()
2317 {
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");
2321 }
2322
2323 /* Set system locale CATEGORY, with previous locale *PLOCALE, to
2324 DESIRED_LOCALE. */
2325 static void
2326 synchronize_locale (category, plocale, desired_locale)
2327 int category;
2328 Lisp_Object *plocale;
2329 Lisp_Object desired_locale;
2330 {
2331 if (! EQ (*plocale, desired_locale))
2332 {
2333 *plocale = desired_locale;
2334 setlocale (category, (STRINGP (desired_locale)
2335 ? (char *) SDATA (desired_locale)
2336 : ""));
2337 }
2338 }
2339
2340 /* Set system time locale to match Vsystem_time_locale, if possible. */
2341 void
2342 synchronize_system_time_locale ()
2343 {
2344 synchronize_locale (LC_TIME, &Vprevious_system_time_locale,
2345 Vsystem_time_locale);
2346 }
2347
2348 /* Set system messages locale to match Vsystem_messages_locale, if
2349 possible. */
2350 void
2351 synchronize_system_messages_locale ()
2352 {
2353 #ifdef LC_MESSAGES
2354 synchronize_locale (LC_MESSAGES, &Vprevious_system_messages_locale,
2355 Vsystem_messages_locale);
2356 #endif
2357 }
2358 #endif /* HAVE_SETLOCALE */
2359 \f
2360 #ifndef SEPCHAR
2361 #define SEPCHAR ':'
2362 #endif
2363
2364 Lisp_Object
2365 decode_env_path (evarname, defalt)
2366 char *evarname, *defalt;
2367 {
2368 register char *path, *p;
2369 Lisp_Object lpath, element, tem;
2370
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. */
2374 if (evarname != 0)
2375 path = (char *) getenv (evarname);
2376 else
2377 path = 0;
2378 if (!path)
2379 path = defalt;
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
2394 lpath = Qnil;
2395 while (1)
2396 {
2397 p = index (path, SEPCHAR);
2398 if (!p) p = path + strlen (path);
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);
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
2416 if (! NILP (tem))
2417 element = concat2 (build_string ("/:"), element);
2418
2419 lpath = Fcons (element, lpath);
2420 if (*p)
2421 path = p + 1;
2422 else
2423 break;
2424 }
2425 return Fnreverse (lpath);
2426 }
2427
2428 void
2429 syms_of_emacs ()
2430 {
2431 Qfile_name_handler_alist = intern ("file-name-handler-alist");
2432 staticpro (&Qfile_name_handler_alist);
2433
2434 #ifndef CANNOT_DUMP
2435 #ifdef HAVE_SHM
2436 defsubr (&Sdump_emacs_data);
2437 #else
2438 defsubr (&Sdump_emacs);
2439 #endif
2440 #endif
2441
2442 defsubr (&Skill_emacs);
2443
2444 defsubr (&Sinvocation_name);
2445 defsubr (&Sinvocation_directory);
2446
2447 DEFVAR_LISP ("command-line-args", &Vcommand_line_args,
2448 doc: /* Args passed by shell to Emacs, as a list of strings.
2449 Many arguments are deleted from the list as they are processed. */);
2450
2451 DEFVAR_LISP ("system-type", &Vsystem_type,
2452 doc: /* Value is symbol indicating type of operating system you are using.
2453 Special 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.
2461 Anything else indicates some sort of Unix system. */);
2462 Vsystem_type = intern (SYSTEM_TYPE);
2463
2464 DEFVAR_LISP ("system-configuration", &Vsystem_configuration,
2465 doc: /* Value is string indicating configuration Emacs was built for.
2466 On MS-Windows, the value reflects the OS flavor and version on which
2467 Emacs is running. */);
2468 Vsystem_configuration = build_string (EMACS_CONFIGURATION);
2469
2470 DEFVAR_LISP ("system-configuration-options", &Vsystem_configuration_options,
2471 doc: /* String containing the configuration options Emacs was built with. */);
2472 Vsystem_configuration_options = build_string (EMACS_CONFIG_OPTIONS);
2473
2474 DEFVAR_BOOL ("noninteractive", &noninteractive1,
2475 doc: /* Non-nil means Emacs is running without interactive terminal. */);
2476
2477 DEFVAR_LISP ("kill-emacs-hook", &Vkill_emacs_hook,
2478 doc: /* Hook to be run when kill-emacs is called.
2479 Since `kill-emacs' may be invoked when the terminal is disconnected (or
2480 in other similar situations), functions placed on this hook should not
2481 expect to be able to interact with the user. To ask for confirmation,
2482 see `kill-emacs-query-functions' instead.
2483
2484 The hook is not run in batch mode, i.e., if `noninteractive' is non-nil. */);
2485 Vkill_emacs_hook = Qnil;
2486
2487 empty_string = build_string ("");
2488 staticpro (&empty_string);
2489
2490 DEFVAR_INT ("emacs-priority", &emacs_priority,
2491 doc: /* Priority for Emacs to run at.
2492 This value is effective only if set before Emacs is dumped,
2493 and only if the Emacs executable is installed with setuid to permit
2494 it to change priority. (Emacs sets its uid back to the real uid.)
2495 Currently, you need to define SET_EMACS_PRIORITY in `config.h'
2496 before you compile Emacs, to enable the code for this feature. */);
2497 emacs_priority = 0;
2498
2499 DEFVAR_LISP ("path-separator", &Vpath_separator,
2500 doc: /* The directory separator in search paths, as a string. */);
2501 {
2502 char c = SEPCHAR;
2503 Vpath_separator = make_string (&c, 1);
2504 }
2505
2506 DEFVAR_LISP ("invocation-name", &Vinvocation_name,
2507 doc: /* The program name that was used to run Emacs.
2508 Any directory names are omitted. */);
2509
2510 DEFVAR_LISP ("invocation-directory", &Vinvocation_directory,
2511 doc: /* The directory in which the Emacs executable was found, to run it.
2512 The value is nil if that directory's name is not known. */);
2513
2514 DEFVAR_LISP ("installation-directory", &Vinstallation_directory,
2515 doc: /* A directory within which to look for the `lib-src' and `etc' directories.
2516 This is non-nil when we can't find those directories in their standard
2517 installed locations, but we can find them
2518 near where the Emacs executable was found. */);
2519 Vinstallation_directory = Qnil;
2520
2521 DEFVAR_LISP ("system-messages-locale", &Vsystem_messages_locale,
2522 doc: /* System locale for messages. */);
2523 Vsystem_messages_locale = Qnil;
2524
2525 DEFVAR_LISP ("previous-system-messages-locale",
2526 &Vprevious_system_messages_locale,
2527 doc: /* Most recently used system locale for messages. */);
2528 Vprevious_system_messages_locale = Qnil;
2529
2530 DEFVAR_LISP ("system-time-locale", &Vsystem_time_locale,
2531 doc: /* System locale for time. */);
2532 Vsystem_time_locale = Qnil;
2533
2534 DEFVAR_LISP ("previous-system-time-locale", &Vprevious_system_time_locale,
2535 doc: /* Most recently used system locale for time. */);
2536 Vprevious_system_time_locale = Qnil;
2537 }
2538
2539 /* arch-tag: 7bfd356a-c720-4612-8ab6-aa4222931c2e
2540 (do not change this comment) */