]> code.delx.au - gnu-emacs/blob - src/emacs.c
(cp1125): Set :ascii-compatible-p property to t.
[gnu-emacs] / 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, 2001,
3 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_character_once ();
1297 init_charset_once ();
1298 init_coding_once ();
1299 init_syntax_once (); /* Create standard syntax table. */
1300 init_category_once (); /* Create standard category table. */
1301 /* Must be done before init_buffer. */
1302 init_casetab_once ();
1303 init_buffer_once (); /* Create buffer table and some buffers. */
1304 init_minibuf_once (); /* Create list of minibuffers. */
1305 /* Must precede init_window_once. */
1306
1307 /* Call syms_of_xfaces before init_window_once because that
1308 function creates Vterminal_frame. Termcap frames now use
1309 faces, and the face implementation uses some symbols as
1310 face names. */
1311 syms_of_xfaces ();
1312 /* Call syms_of_keyboard before init_window_once because
1313 keyboard sets up symbols that include some face names that
1314 the X support will want to use. This can happen when
1315 CANNOT_DUMP is defined. */
1316 syms_of_keyboard ();
1317
1318 #ifdef MAC_OS8
1319 /* init_window_once calls make_terminal_frame which on Mac OS
1320 creates a full-fledge output_mac type frame. This does not
1321 work correctly before syms_of_textprop, syms_of_macfns,
1322 syms_of_ccl, syms_of_fontset, syms_of_xterm, syms_of_search,
1323 syms_of_frame, mac_term_init, and init_keyboard have already
1324 been called. */
1325 syms_of_textprop ();
1326 syms_of_macfns ();
1327 syms_of_ccl ();
1328 syms_of_fontset ();
1329 syms_of_macterm ();
1330 syms_of_macmenu ();
1331 syms_of_macselect ();
1332 syms_of_data ();
1333 syms_of_search ();
1334 syms_of_frame ();
1335
1336 init_atimer ();
1337 mac_term_init (build_string ("Mac"), NULL, NULL);
1338 init_keyboard ();
1339 #endif
1340
1341 init_window_once (); /* Init the window system. */
1342 init_fileio_once (); /* Must precede any path manipulation. */
1343 #ifdef HAVE_WINDOW_SYSTEM
1344 init_fringe_once (); /* Swap bitmaps if necessary. */
1345 #endif /* HAVE_WINDOW_SYSTEM */
1346 }
1347
1348 init_alloc ();
1349
1350 if (do_initial_setlocale)
1351 {
1352 fixup_locale ();
1353 Vsystem_messages_locale = Vprevious_system_messages_locale;
1354 Vsystem_time_locale = Vprevious_system_time_locale;
1355 }
1356
1357 init_eval ();
1358 init_data ();
1359 #ifdef CLASH_DETECTION
1360 init_filelock ();
1361 #endif
1362 #ifndef MAC_OS8
1363 init_atimer ();
1364 #endif
1365 running_asynch_code = 0;
1366
1367 /* Handle --unibyte and the EMACS_UNIBYTE envvar,
1368 but not while dumping. */
1369 if (1)
1370 {
1371 int inhibit_unibyte = 0;
1372
1373 /* --multibyte overrides EMACS_UNIBYTE. */
1374 if (argmatch (argv, argc, "-no-unibyte", "--no-unibyte", 4, NULL, &skip_args)
1375 || argmatch (argv, argc, "-multibyte", "--multibyte", 4, NULL, &skip_args)
1376 /* Ignore EMACS_UNIBYTE before dumping. */
1377 || (!initialized && noninteractive))
1378 inhibit_unibyte = 1;
1379
1380 /* --unibyte requests that we set up to do everything with single-byte
1381 buffers and strings. We need to handle this before calling
1382 init_lread, init_editfns and other places that generate Lisp strings
1383 from text in the environment. */
1384 /* Actually this shouldn't be needed as of 20.4 in a generally
1385 unibyte environment. As handa says, environment values
1386 aren't now decoded; also existing buffers are now made
1387 unibyte during startup if .emacs sets unibyte. Tested with
1388 8-bit data in environment variables and /etc/passwd, setting
1389 unibyte and Latin-1 in .emacs. -- Dave Love */
1390 if (argmatch (argv, argc, "-unibyte", "--unibyte", 4, NULL, &skip_args)
1391 || argmatch (argv, argc, "-no-multibyte", "--no-multibyte", 4, NULL, &skip_args)
1392 || (getenv ("EMACS_UNIBYTE") && !inhibit_unibyte))
1393 {
1394 Lisp_Object old_log_max;
1395 Lisp_Object symbol, tail;
1396
1397 symbol = intern ("default-enable-multibyte-characters");
1398 Fset (symbol, Qnil);
1399
1400 if (initialized)
1401 {
1402 /* Erase pre-dump messages in *Messages* now so no abort. */
1403 old_log_max = Vmessage_log_max;
1404 XSETFASTINT (Vmessage_log_max, 0);
1405 message_dolog ("", 0, 1, 0);
1406 Vmessage_log_max = old_log_max;
1407 }
1408
1409 for (tail = Vbuffer_alist; CONSP (tail);
1410 tail = XCDR (tail))
1411 {
1412 Lisp_Object buffer;
1413
1414 buffer = Fcdr (XCAR (tail));
1415 /* Make a multibyte buffer unibyte. */
1416 if (BUF_Z_BYTE (XBUFFER (buffer)) > BUF_Z (XBUFFER (buffer)))
1417 {
1418 struct buffer *current = current_buffer;
1419
1420 set_buffer_temp (XBUFFER (buffer));
1421 Fset_buffer_multibyte (Qnil);
1422 set_buffer_temp (current);
1423 }
1424 }
1425 }
1426 }
1427
1428 no_loadup
1429 = argmatch (argv, argc, "-nl", "--no-loadup", 6, NULL, &skip_args);
1430
1431
1432 #ifdef HAVE_X_WINDOWS
1433 /* Stupid kludge to catch command-line display spec. We can't
1434 handle this argument entirely in window system dependent code
1435 because we don't even know which window system dependent code
1436 to run until we've recognized this argument. */
1437 {
1438 char *displayname = 0;
1439 int count_before = skip_args;
1440
1441 /* Skip any number of -d options, but only use the last one. */
1442 while (1)
1443 {
1444 int count_before_this = skip_args;
1445
1446 if (argmatch (argv, argc, "-d", "--display", 3, &displayname, &skip_args))
1447 display_arg = 1;
1448 else if (argmatch (argv, argc, "-display", 0, 3, &displayname, &skip_args))
1449 display_arg = 1;
1450 else
1451 break;
1452
1453 count_before = count_before_this;
1454 }
1455
1456 /* If we have the form --display=NAME,
1457 convert it into -d name.
1458 This requires inserting a new element into argv. */
1459 if (displayname != 0 && skip_args - count_before == 1)
1460 {
1461 char **new = (char **) xmalloc (sizeof (char *) * (argc + 2));
1462 int j;
1463
1464 for (j = 0; j < count_before + 1; j++)
1465 new[j] = argv[j];
1466 new[count_before + 1] = "-d";
1467 new[count_before + 2] = displayname;
1468 for (j = count_before + 2; j <argc; j++)
1469 new[j + 1] = argv[j];
1470 argv = new;
1471 argc++;
1472 }
1473 /* Change --display to -d, when its arg is separate. */
1474 else if (displayname != 0 && skip_args > count_before
1475 && argv[count_before + 1][1] == '-')
1476 argv[count_before + 1] = "-d";
1477
1478 /* Don't actually discard this arg. */
1479 skip_args = count_before;
1480 }
1481 #endif
1482
1483 /* argmatch must not be used after here,
1484 except when bulding temacs
1485 because the -d argument has not been skipped in skip_args. */
1486
1487 #ifdef MSDOS
1488 /* Call early 'cause init_environment needs it. */
1489 init_dosfns ();
1490 /* Set defaults for several environment variables. */
1491 if (initialized)
1492 init_environment (argc, argv, skip_args);
1493 else
1494 tzset ();
1495 #endif /* MSDOS */
1496
1497 #ifdef WINDOWSNT
1498 globals_of_w32 ();
1499 /* Initialize environment from registry settings. */
1500 init_environment (argv);
1501 init_ntproc (); /* must precede init_editfns. */
1502 #endif
1503
1504 #if defined (MAC_OSX) && defined (HAVE_CARBON)
1505 if (initialized)
1506 init_mac_osx_environment ();
1507 #endif
1508
1509 /* egetenv is a pretty low-level facility, which may get called in
1510 many circumstances; it seems flimsy to put off initializing it
1511 until calling init_callproc. */
1512 set_process_environment ();
1513 /* AIX crashes are reported in system versions 3.2.3 and 3.2.4
1514 if this is not done. Do it after set_process_environment so that we
1515 don't pollute Vprocess_environment. */
1516 /* Setting LANG here will defeat the startup locale processing... */
1517 #ifdef AIX3_2
1518 putenv ("LANG=C");
1519 #endif
1520
1521 init_buffer (); /* Init default directory of main buffer. */
1522
1523 init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */
1524 init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */
1525
1526 if (initialized)
1527 {
1528 /* Erase any pre-dump messages in the message log, to avoid confusion. */
1529 Lisp_Object old_log_max;
1530 old_log_max = Vmessage_log_max;
1531 XSETFASTINT (Vmessage_log_max, 0);
1532 message_dolog ("", 0, 1, 0);
1533 Vmessage_log_max = old_log_max;
1534 }
1535
1536 init_callproc (); /* Must follow init_cmdargs but not init_sys_modes. */
1537 init_lread ();
1538
1539 /* Intern the names of all standard functions and variables;
1540 define standard keys. */
1541
1542 if (!initialized)
1543 {
1544 /* The basic levels of Lisp must come first. */
1545 /* And data must come first of all
1546 for the sake of symbols like error-message. */
1547 #ifndef MAC_OS8
1548 /* Called before init_window_once for Mac OS Classic. */
1549 syms_of_data ();
1550 #endif
1551 syms_of_alloc ();
1552 syms_of_chartab ();
1553 syms_of_lread ();
1554 syms_of_print ();
1555 syms_of_eval ();
1556 syms_of_fns ();
1557 syms_of_floatfns ();
1558
1559 syms_of_abbrev ();
1560 syms_of_buffer ();
1561 syms_of_bytecode ();
1562 syms_of_callint ();
1563 syms_of_casefiddle ();
1564 syms_of_casetab ();
1565 syms_of_callproc ();
1566 syms_of_category ();
1567 #ifndef MAC_OS8
1568 /* Called before init_window_once for Mac OS Classic. */
1569 syms_of_ccl ();
1570 #endif
1571 syms_of_character ();
1572 syms_of_charset ();
1573 syms_of_cmds ();
1574 #ifndef NO_DIR_LIBRARY
1575 syms_of_dired ();
1576 #endif /* not NO_DIR_LIBRARY */
1577 syms_of_display ();
1578 syms_of_doc ();
1579 syms_of_editfns ();
1580 syms_of_emacs ();
1581 syms_of_fileio ();
1582 syms_of_coding (); /* This should be after syms_of_fileio. */
1583 #ifdef CLASH_DETECTION
1584 syms_of_filelock ();
1585 #endif /* CLASH_DETECTION */
1586 syms_of_indent ();
1587 syms_of_insdel ();
1588 syms_of_keymap ();
1589 syms_of_macros ();
1590 syms_of_marker ();
1591 syms_of_minibuf ();
1592 syms_of_process ();
1593 #ifndef MAC_OS8
1594 /* Called before init_window_once for Mac OS Classic. */
1595 syms_of_search ();
1596 syms_of_frame ();
1597 #endif
1598 syms_of_syntax ();
1599 syms_of_term ();
1600 syms_of_undo ();
1601 #ifdef HAVE_SOUND
1602 syms_of_sound ();
1603 #endif
1604 #ifndef MAC_OS8
1605 /* Called before init_window_once for Mac OS Classic. */
1606 syms_of_textprop ();
1607 #endif
1608 syms_of_composite ();
1609 #ifdef VMS
1610 syms_of_vmsproc ();
1611 #endif /* VMS */
1612 #ifdef WINDOWSNT
1613 syms_of_ntproc ();
1614 #endif /* WINDOWSNT */
1615 syms_of_window ();
1616 syms_of_xdisp ();
1617 #ifdef HAVE_WINDOW_SYSTEM
1618 syms_of_fringe ();
1619 syms_of_image ();
1620 #endif /* HAVE_WINDOW_SYSTEM */
1621 #ifdef HAVE_X_WINDOWS
1622 syms_of_xterm ();
1623 syms_of_xfns ();
1624 syms_of_fontset ();
1625 #ifdef HAVE_X_SM
1626 syms_of_xsmfns ();
1627 #endif
1628 #ifdef HAVE_X11
1629 syms_of_xselect ();
1630 #endif
1631 #endif /* HAVE_X_WINDOWS */
1632
1633 #ifdef HAVE_MENUS
1634 #ifndef HAVE_NTGUI
1635 #ifndef MAC_OS
1636 /* Called before init_window_once for Mac OS Classic. */
1637 syms_of_xmenu ();
1638 #endif
1639 #endif
1640 #endif
1641
1642 #ifdef HAVE_NTGUI
1643 syms_of_w32term ();
1644 syms_of_w32fns ();
1645 syms_of_w32select ();
1646 syms_of_w32menu ();
1647 syms_of_fontset ();
1648 #endif /* HAVE_NTGUI */
1649
1650 #if defined (MAC_OSX) && defined (HAVE_CARBON)
1651 syms_of_macterm ();
1652 syms_of_macfns ();
1653 syms_of_macmenu ();
1654 syms_of_macselect ();
1655 syms_of_fontset ();
1656 #endif /* MAC_OSX && HAVE_CARBON */
1657
1658 #ifdef SYMS_SYSTEM
1659 SYMS_SYSTEM;
1660 #endif
1661
1662 #ifdef SYMS_MACHINE
1663 SYMS_MACHINE;
1664 #endif
1665
1666 keys_of_casefiddle ();
1667 keys_of_cmds ();
1668 keys_of_buffer ();
1669 keys_of_keyboard ();
1670 keys_of_keymap ();
1671 keys_of_minibuf ();
1672 keys_of_window ();
1673 }
1674 else
1675 {
1676 /* Initialization that must be done even if the global variable
1677 initialized is non zero. */
1678 #ifdef HAVE_NTGUI
1679 globals_of_w32fns ();
1680 globals_of_w32menu ();
1681 globals_of_w32select ();
1682 #endif /* HAVE_NTGUI */
1683 }
1684
1685 init_charset ();
1686
1687 if (!noninteractive)
1688 {
1689 #ifdef VMS
1690 init_vms_input ();/* init_display calls get_frame_size, that needs this. */
1691 #endif /* VMS */
1692 init_display (); /* Determine terminal type. init_sys_modes uses results. */
1693 }
1694 #ifndef MAC_OS8
1695 /* Called before init_window_once for Mac OS Classic. */
1696 init_keyboard (); /* This too must precede init_sys_modes. */
1697 #endif
1698 #ifdef VMS
1699 init_vmsproc (); /* And this too. */
1700 #endif /* VMS */
1701 init_sys_modes (); /* Init system terminal modes (RAW or CBREAK, etc.). */
1702 init_fns ();
1703 init_xdisp ();
1704 #ifdef HAVE_WINDOW_SYSTEM
1705 init_fringe ();
1706 init_image ();
1707 #endif /* HAVE_WINDOW_SYSTEM */
1708 init_macros ();
1709 init_editfns ();
1710 init_floatfns ();
1711 #ifdef VMS
1712 init_vmsfns ();
1713 #endif /* VMS */
1714 init_process ();
1715 #ifdef HAVE_SOUND
1716 init_sound ();
1717 #endif
1718 init_window ();
1719
1720 if (!initialized)
1721 {
1722 char *file;
1723 /* Handle -l loadup, args passed by Makefile. */
1724 if (argmatch (argv, argc, "-l", "--load", 3, &file, &skip_args))
1725 Vtop_level = Fcons (intern ("load"),
1726 Fcons (build_string (file), Qnil));
1727 /* Unless next switch is -nl, load "loadup.el" first thing. */
1728 if (! no_loadup)
1729 Vtop_level = Fcons (intern ("load"),
1730 Fcons (build_string ("loadup.el"), Qnil));
1731 }
1732
1733 if (initialized)
1734 {
1735 #ifdef HAVE_TZSET
1736 {
1737 /* If the execution TZ happens to be the same as the dump TZ,
1738 change it to some other value and then change it back,
1739 to force the underlying implementation to reload the TZ info.
1740 This is needed on implementations that load TZ info from files,
1741 since the TZ file contents may differ between dump and execution. */
1742 char *tz = getenv ("TZ");
1743 if (tz && !strcmp (tz, dump_tz))
1744 {
1745 ++*tz;
1746 tzset ();
1747 --*tz;
1748 }
1749 }
1750 #endif
1751 }
1752
1753 /* Set up for profiling. This is known to work on FreeBSD and
1754 GNU/Linux. It might work on some other systems too. Give it a
1755 try and tell us if it works on your system. To compile for
1756 profiling use something like `make CFLAGS="-pg -g -O -DPROFILING=1'. */
1757 #if defined (__FreeBSD__) || defined (__linux)
1758 #ifdef PROFILING
1759 if (initialized)
1760 {
1761 extern void _mcleanup ();
1762 extern char etext;
1763 extern void safe_bcopy ();
1764 extern void dump_opcode_frequencies ();
1765
1766 atexit (_mcleanup);
1767 /* This uses safe_bcopy because that function comes first in the
1768 Emacs executable. It might be better to use something that
1769 gives the start of the text segment, but start_of_text is not
1770 defined on all systems now. */
1771 monstartup (safe_bcopy, &etext);
1772 }
1773 else
1774 moncontrol (0);
1775 #endif
1776 #endif
1777
1778 initialized = 1;
1779
1780 #ifdef LOCALTIME_CACHE
1781 /* Some versions of localtime have a bug. They cache the value of the time
1782 zone rather than looking it up every time. Since localtime() is
1783 called to bolt the undumping time into the undumped emacs, this
1784 results in localtime ignoring the TZ environment variable.
1785 This flushes the new TZ value into localtime. */
1786 tzset ();
1787 #endif /* defined (LOCALTIME_CACHE) */
1788
1789 /* Enter editor command loop. This never returns. */
1790 Frecursive_edit ();
1791 /* NOTREACHED */
1792 return 0;
1793 }
1794 \f
1795 /* Sort the args so we can find the most important ones
1796 at the beginning of argv. */
1797
1798 /* First, here's a table of all the standard options. */
1799
1800 struct standard_args
1801 {
1802 char *name;
1803 char *longname;
1804 int priority;
1805 int nargs;
1806 };
1807
1808 struct standard_args standard_args[] =
1809 {
1810 { "-version", "--version", 150, 0 },
1811 #ifdef HAVE_SHM
1812 { "-nl", "--no-shared-memory", 140, 0 },
1813 #endif
1814 #ifdef VMS
1815 { "-map", "--map-data", 130, 0 },
1816 #endif
1817 { "-t", "--terminal", 120, 1 },
1818 { "-nw", "--no-window-system", 110, 0 },
1819 { "-nw", "--no-windows", 110, 0 },
1820 { "-batch", "--batch", 100, 0 },
1821 { "-script", "--script", 100, 1 },
1822 { "-help", "--help", 90, 0 },
1823 { "-no-unibyte", "--no-unibyte", 83, 0 },
1824 { "-multibyte", "--multibyte", 82, 0 },
1825 { "-unibyte", "--unibyte", 81, 0 },
1826 { "-no-multibyte", "--no-multibyte", 80, 0 },
1827 { "-nl", "--no-loadup", 70, 0 },
1828 /* -d must come last before the options handled in startup.el. */
1829 { "-d", "--display", 60, 1 },
1830 { "-display", 0, 60, 1 },
1831 /* Now for the options handled in startup.el. */
1832 { "-Q", "--quick", 55, 0 },
1833 { "-quick", 0, 55, 0 },
1834 { "-q", "--no-init-file", 50, 0 },
1835 { "-no-init-file", 0, 50, 0 },
1836 { "-no-site-file", "--no-site-file", 40, 0 },
1837 { "-no-splash", "--no-splash", 40, 0 },
1838 { "-u", "--user", 30, 1 },
1839 { "-user", 0, 30, 1 },
1840 { "-debug-init", "--debug-init", 20, 0 },
1841 { "-i", "--icon-type", 15, 0 },
1842 { "-itype", 0, 15, 0 },
1843 { "-iconic", "--iconic", 15, 0 },
1844 { "-D", "--basic-display", 12, 0},
1845 { "--basic-display", 0, 12, 0},
1846 { "-bg", "--background-color", 10, 1 },
1847 { "-background", 0, 10, 1 },
1848 { "-fg", "--foreground-color", 10, 1 },
1849 { "-foreground", 0, 10, 1 },
1850 { "-bd", "--border-color", 10, 1 },
1851 { "-bw", "--border-width", 10, 1 },
1852 { "-ib", "--internal-border", 10, 1 },
1853 { "-ms", "--mouse-color", 10, 1 },
1854 { "-cr", "--cursor-color", 10, 1 },
1855 { "-nbc", "--no-blinking-cursor", 10, 0 },
1856 { "-fn", "--font", 10, 1 },
1857 { "-font", 0, 10, 1 },
1858 { "-fs", "--fullscreen", 10, 0 },
1859 { "-fw", "--fullwidth", 10, 0 },
1860 { "-fh", "--fullheight", 10, 0 },
1861 { "-g", "--geometry", 10, 1 },
1862 { "-geometry", 0, 10, 1 },
1863 { "-T", "--title", 10, 1 },
1864 { "-title", 0, 10, 1 },
1865 { "-name", "--name", 10, 1 },
1866 { "-xrm", "--xrm", 10, 1 },
1867 { "-r", "--reverse-video", 5, 0 },
1868 { "-rv", 0, 5, 0 },
1869 { "-reverse", 0, 5, 0 },
1870 { "-hb", "--horizontal-scroll-bars", 5, 0 },
1871 { "-vb", "--vertical-scroll-bars", 5, 0 },
1872 { "-color", "--color", 5, 0},
1873 /* These have the same priority as ordinary file name args,
1874 so they are not reordered with respect to those. */
1875 { "-L", "--directory", 0, 1 },
1876 { "-directory", 0, 0, 1 },
1877 { "-l", "--load", 0, 1 },
1878 { "-load", 0, 0, 1 },
1879 { "-f", "--funcall", 0, 1 },
1880 { "-funcall", 0, 0, 1 },
1881 { "-eval", "--eval", 0, 1 },
1882 { "-execute", "--execute", 0, 1 },
1883 { "-find-file", "--find-file", 0, 1 },
1884 { "-visit", "--visit", 0, 1 },
1885 { "-file", "--file", 0, 1 },
1886 { "-insert", "--insert", 0, 1 },
1887 /* This should be processed after ordinary file name args and the like. */
1888 { "-kill", "--kill", -10, 0 },
1889 };
1890
1891 /* Reorder the elements of ARGV (assumed to have ARGC elements)
1892 so that the highest priority ones come first.
1893 Do not change the order of elements of equal priority.
1894 If an option takes an argument, keep it and its argument together.
1895
1896 If an option that takes no argument appears more
1897 than once, eliminate all but one copy of it. */
1898
1899 static void
1900 sort_args (argc, argv)
1901 int argc;
1902 char **argv;
1903 {
1904 char **new = (char **) xmalloc (sizeof (char *) * argc);
1905 /* For each element of argv,
1906 the corresponding element of options is:
1907 0 for an option that takes no arguments,
1908 1 for an option that takes one argument, etc.
1909 -1 for an ordinary non-option argument. */
1910 int *options = (int *) xmalloc (sizeof (int) * argc);
1911 int *priority = (int *) xmalloc (sizeof (int) * argc);
1912 int to = 1;
1913 int incoming_used = 1;
1914 int from;
1915 int i;
1916
1917 /* Categorize all the options,
1918 and figure out which argv elts are option arguments. */
1919 for (from = 1; from < argc; from++)
1920 {
1921 options[from] = -1;
1922 priority[from] = 0;
1923 if (argv[from][0] == '-')
1924 {
1925 int match, thislen;
1926 char *equals;
1927
1928 /* If we have found "--", don't consider
1929 any more arguments as options. */
1930 if (argv[from][1] == '-' && argv[from][2] == 0)
1931 {
1932 /* Leave the "--", and everything following it, at the end. */
1933 for (; from < argc; from++)
1934 {
1935 priority[from] = -100;
1936 options[from] = -1;
1937 }
1938 break;
1939 }
1940
1941 /* Look for a match with a known old-fashioned option. */
1942 for (i = 0; i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1943 if (!strcmp (argv[from], standard_args[i].name))
1944 {
1945 options[from] = standard_args[i].nargs;
1946 priority[from] = standard_args[i].priority;
1947 if (from + standard_args[i].nargs >= argc)
1948 fatal ("Option `%s' requires an argument\n", argv[from]);
1949 from += standard_args[i].nargs;
1950 goto done;
1951 }
1952
1953 /* Look for a match with a known long option.
1954 MATCH is -1 if no match so far, -2 if two or more matches so far,
1955 >= 0 (the table index of the match) if just one match so far. */
1956 if (argv[from][1] == '-')
1957 {
1958 match = -1;
1959 thislen = strlen (argv[from]);
1960 equals = index (argv[from], '=');
1961 if (equals != 0)
1962 thislen = equals - argv[from];
1963
1964 for (i = 0;
1965 i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1966 if (standard_args[i].longname
1967 && !strncmp (argv[from], standard_args[i].longname,
1968 thislen))
1969 {
1970 if (match == -1)
1971 match = i;
1972 else
1973 match = -2;
1974 }
1975
1976 /* If we found exactly one match, use that. */
1977 if (match >= 0)
1978 {
1979 options[from] = standard_args[match].nargs;
1980 priority[from] = standard_args[match].priority;
1981 /* If --OPTION=VALUE syntax is used,
1982 this option uses just one argv element. */
1983 if (equals != 0)
1984 options[from] = 0;
1985 if (from + options[from] >= argc)
1986 fatal ("Option `%s' requires an argument\n", argv[from]);
1987 from += options[from];
1988 }
1989 }
1990 done: ;
1991 }
1992 }
1993
1994 /* Copy the arguments, in order of decreasing priority, to NEW. */
1995 new[0] = argv[0];
1996 while (incoming_used < argc)
1997 {
1998 int best = -1;
1999 int best_priority = -9999;
2000
2001 /* Find the highest priority remaining option.
2002 If several have equal priority, take the first of them. */
2003 for (from = 1; from < argc; from++)
2004 {
2005 if (argv[from] != 0 && priority[from] > best_priority)
2006 {
2007 best_priority = priority[from];
2008 best = from;
2009 }
2010 /* Skip option arguments--they are tied to the options. */
2011 if (options[from] > 0)
2012 from += options[from];
2013 }
2014
2015 if (best < 0)
2016 abort ();
2017
2018 /* Copy the highest priority remaining option, with its args, to NEW.
2019 Unless it is a duplicate of the previous one. */
2020 if (! (options[best] == 0
2021 && ! strcmp (new[to - 1], argv[best])))
2022 {
2023 new[to++] = argv[best];
2024 for (i = 0; i < options[best]; i++)
2025 new[to++] = argv[best + i + 1];
2026 }
2027
2028 incoming_used += 1 + (options[best] > 0 ? options[best] : 0);
2029
2030 /* Clear out this option in ARGV. */
2031 argv[best] = 0;
2032 for (i = 0; i < options[best]; i++)
2033 argv[best + i + 1] = 0;
2034 }
2035
2036 /* If duplicate options were deleted, fill up extra space with null ptrs. */
2037 while (to < argc)
2038 new[to++] = 0;
2039
2040 bcopy (new, argv, sizeof (char *) * argc);
2041
2042 xfree (options);
2043 xfree (new);
2044 xfree (priority);
2045 }
2046 \f
2047 DEFUN ("kill-emacs", Fkill_emacs, Skill_emacs, 0, 1, "P",
2048 doc: /* Exit the Emacs job and kill it.
2049 If ARG is an integer, return ARG as the exit program code.
2050 If ARG is a string, stuff it as keyboard input.
2051
2052 The value of `kill-emacs-hook', if not void,
2053 is a list of functions (of no args),
2054 all of which are called before Emacs is actually killed. */)
2055 (arg)
2056 Lisp_Object arg;
2057 {
2058 struct gcpro gcpro1;
2059
2060 GCPRO1 (arg);
2061
2062 if (feof (stdin))
2063 arg = Qt;
2064
2065 if (!NILP (Vrun_hooks) && !noninteractive)
2066 call1 (Vrun_hooks, intern ("kill-emacs-hook"));
2067
2068 UNGCPRO;
2069
2070 /* Is it really necessary to do this deassign
2071 when we are going to exit anyway? */
2072 /* #ifdef VMS
2073 stop_vms_input ();
2074 #endif */
2075
2076 shut_down_emacs (0, 0, STRINGP (arg) ? arg : Qnil);
2077
2078 /* If we have an auto-save list file,
2079 kill it because we are exiting Emacs deliberately (not crashing).
2080 Do it after shut_down_emacs, which does an auto-save. */
2081 if (STRINGP (Vauto_save_list_file_name))
2082 unlink (SDATA (Vauto_save_list_file_name));
2083
2084 exit (INTEGERP (arg) ? XINT (arg) : EXIT_SUCCESS);
2085 /* NOTREACHED */
2086 return Qnil;
2087 }
2088
2089
2090 /* Perform an orderly shutdown of Emacs. Autosave any modified
2091 buffers, kill any child processes, clean up the terminal modes (if
2092 we're in the foreground), and other stuff like that. Don't perform
2093 any redisplay; this may be called when Emacs is shutting down in
2094 the background, or after its X connection has died.
2095
2096 If SIG is a signal number, print a message for it.
2097
2098 This is called by fatal signal handlers, X protocol error handlers,
2099 and Fkill_emacs. */
2100
2101 void
2102 shut_down_emacs (sig, no_x, stuff)
2103 int sig, no_x;
2104 Lisp_Object stuff;
2105 {
2106 /* Prevent running of hooks from now on. */
2107 Vrun_hooks = Qnil;
2108
2109 /* Don't update display from now on. */
2110 Vinhibit_redisplay = Qt;
2111
2112 /* If we are controlling the terminal, reset terminal modes. */
2113 #ifdef EMACS_HAVE_TTY_PGRP
2114 {
2115 int pgrp = EMACS_GETPGRP (0);
2116
2117 int tpgrp;
2118 if (EMACS_GET_TTY_PGRP (0, &tpgrp) != -1
2119 && tpgrp == pgrp)
2120 {
2121 fflush (stdout);
2122 reset_sys_modes ();
2123 if (sig && sig != SIGTERM)
2124 fprintf (stderr, "Fatal error (%d)", sig);
2125 }
2126 }
2127 #else
2128 fflush (stdout);
2129 reset_sys_modes ();
2130 #endif
2131
2132 stuff_buffered_input (stuff);
2133
2134 kill_buffer_processes (Qnil);
2135 Fdo_auto_save (Qt, Qnil);
2136
2137 #ifdef CLASH_DETECTION
2138 unlock_all_files ();
2139 #endif
2140
2141 #ifdef VMS
2142 kill_vms_processes ();
2143 #endif
2144
2145 #if 0 /* This triggers a bug in XCloseDisplay and is not needed. */
2146 #ifdef HAVE_X_WINDOWS
2147 /* It's not safe to call intern here. Maybe we are crashing. */
2148 if (!noninteractive && SYMBOLP (Vwindow_system)
2149 && SCHARS (SYMBOL_NAME (Vwindow_system)) == 1
2150 && SREF (SYMBOL_NAME (Vwindow_system), 0) == 'x'
2151 && ! no_x)
2152 Fx_close_current_connection ();
2153 #endif /* HAVE_X_WINDOWS */
2154 #endif
2155
2156 #ifdef SIGIO
2157 /* There is a tendency for a SIGIO signal to arrive within exit,
2158 and cause a SIGHUP because the input descriptor is already closed. */
2159 unrequest_sigio ();
2160 signal (SIGIO, SIG_IGN);
2161 #endif
2162
2163 #ifdef WINDOWSNT
2164 term_ntproc ();
2165 #endif
2166
2167 /* Do this only if terminating normally, we want glyph matrices
2168 etc. in a core dump. */
2169 if (sig == 0 || sig == SIGTERM)
2170 {
2171 check_glyph_memory ();
2172 check_message_stack ();
2173 }
2174
2175 #ifdef MSDOS
2176 dos_cleanup ();
2177 #endif
2178 }
2179
2180
2181 \f
2182 #ifndef CANNOT_DUMP
2183
2184 #ifdef HAVE_SHM
2185
2186 DEFUN ("dump-emacs-data", Fdump_emacs_data, Sdump_emacs_data, 1, 1, 0,
2187 doc: /* Dump current state of Emacs into data file FILENAME.
2188 This function exists on systems that use HAVE_SHM. */)
2189 (filename)
2190 Lisp_Object filename;
2191 {
2192 extern char my_edata[];
2193 Lisp_Object tem;
2194
2195 check_pure_size ();
2196 CHECK_STRING (filename);
2197 filename = Fexpand_file_name (filename, Qnil);
2198
2199 tem = Vpurify_flag;
2200 Vpurify_flag = Qnil;
2201
2202 fflush (stdout);
2203 /* Tell malloc where start of impure now is. */
2204 /* Also arrange for warnings when nearly out of space. */
2205 #ifndef SYSTEM_MALLOC
2206 memory_warnings (my_edata, malloc_warning);
2207 #endif
2208 map_out_data (SDATA (filename));
2209
2210 Vpurify_flag = tem;
2211
2212 return Qnil;
2213 }
2214
2215 #else /* not HAVE_SHM */
2216
2217 DEFUN ("dump-emacs", Fdump_emacs, Sdump_emacs, 2, 2, 0,
2218 doc: /* Dump current state of Emacs into executable file FILENAME.
2219 Take symbols from SYMFILE (presumably the file you executed to run Emacs).
2220 This is used in the file `loadup.el' when building Emacs.
2221
2222 You must run Emacs in batch mode in order to dump it. */)
2223 (filename, symfile)
2224 Lisp_Object filename, symfile;
2225 {
2226 extern char my_edata[];
2227 Lisp_Object tem;
2228 Lisp_Object symbol;
2229 int count = SPECPDL_INDEX ();
2230
2231 check_pure_size ();
2232
2233 if (! noninteractive)
2234 error ("Dumping Emacs works only in batch mode");
2235
2236 #ifdef __linux__
2237 if (heap_bss_diff > MAX_HEAP_BSS_DIFF)
2238 {
2239 fprintf (stderr, "**************************************************\n");
2240 fprintf (stderr, "Warning: Your system has a gap between BSS and the\n");
2241 fprintf (stderr, "heap (%lu byte). This usually means that exec-shield\n",
2242 heap_bss_diff);
2243 fprintf (stderr, "or something similar is in effect. The dump may\n");
2244 fprintf (stderr, "fail because of this. See the section about \n");
2245 fprintf (stderr, "exec-shield in etc/PROBLEMS for more information.\n");
2246 fprintf (stderr, "**************************************************\n");
2247 }
2248 #endif /* __linux__ */
2249
2250 /* Bind `command-line-processed' to nil before dumping,
2251 so that the dumped Emacs will process its command line
2252 and set up to work with X windows if appropriate. */
2253 symbol = intern ("command-line-processed");
2254 specbind (symbol, Qnil);
2255
2256 CHECK_STRING (filename);
2257 filename = Fexpand_file_name (filename, Qnil);
2258 if (!NILP (symfile))
2259 {
2260 CHECK_STRING (symfile);
2261 if (SCHARS (symfile))
2262 symfile = Fexpand_file_name (symfile, Qnil);
2263 }
2264
2265 tem = Vpurify_flag;
2266 Vpurify_flag = Qnil;
2267
2268 #ifdef HAVE_TZSET
2269 set_time_zone_rule (dump_tz);
2270 #ifndef LOCALTIME_CACHE
2271 /* Force a tz reload, since set_time_zone_rule doesn't. */
2272 tzset ();
2273 #endif
2274 #endif
2275
2276 fflush (stdout);
2277 #ifdef VMS
2278 mapout_data (SDATA (filename));
2279 #else
2280 /* Tell malloc where start of impure now is. */
2281 /* Also arrange for warnings when nearly out of space. */
2282 #ifndef SYSTEM_MALLOC
2283 #ifndef WINDOWSNT
2284 /* On Windows, this was done before dumping, and that once suffices.
2285 Meanwhile, my_edata is not valid on Windows. */
2286 memory_warnings (my_edata, malloc_warning);
2287 #endif /* not WINDOWSNT */
2288 #endif
2289 #if !defined (SYSTEM_MALLOC) && defined (HAVE_GTK_AND_PTHREAD) && !defined SYNC_INPUT
2290 /* Pthread may call malloc before main, and then we will get an endless
2291 loop, because pthread_self (see alloc.c) calls malloc the first time
2292 it is called on some systems. */
2293 reset_malloc_hooks ();
2294 #endif
2295 #ifdef DOUG_LEA_MALLOC
2296 malloc_state_ptr = malloc_get_state ();
2297 #endif
2298
2299 #ifdef USE_MMAP_FOR_BUFFERS
2300 mmap_set_vars (0);
2301 #endif
2302 unexec (SDATA (filename),
2303 !NILP (symfile) ? SDATA (symfile) : 0, my_edata, 0, 0);
2304 #ifdef USE_MMAP_FOR_BUFFERS
2305 mmap_set_vars (1);
2306 #endif
2307 #ifdef DOUG_LEA_MALLOC
2308 free (malloc_state_ptr);
2309 #endif
2310 #endif /* not VMS */
2311
2312 Vpurify_flag = tem;
2313
2314 return unbind_to (count, Qnil);
2315 }
2316
2317 #endif /* not HAVE_SHM */
2318
2319 #endif /* not CANNOT_DUMP */
2320 \f
2321 #if HAVE_SETLOCALE
2322 /* Recover from setlocale (LC_ALL, ""). */
2323 void
2324 fixup_locale ()
2325 {
2326 /* The Emacs Lisp reader needs LC_NUMERIC to be "C",
2327 so that numbers are read and printed properly for Emacs Lisp. */
2328 setlocale (LC_NUMERIC, "C");
2329 }
2330
2331 /* Set system locale CATEGORY, with previous locale *PLOCALE, to
2332 DESIRED_LOCALE. */
2333 static void
2334 synchronize_locale (category, plocale, desired_locale)
2335 int category;
2336 Lisp_Object *plocale;
2337 Lisp_Object desired_locale;
2338 {
2339 if (! EQ (*plocale, desired_locale))
2340 {
2341 *plocale = desired_locale;
2342 setlocale (category, (STRINGP (desired_locale)
2343 ? (char *) SDATA (desired_locale)
2344 : ""));
2345 }
2346 }
2347
2348 /* Set system time locale to match Vsystem_time_locale, if possible. */
2349 void
2350 synchronize_system_time_locale ()
2351 {
2352 synchronize_locale (LC_TIME, &Vprevious_system_time_locale,
2353 Vsystem_time_locale);
2354 }
2355
2356 /* Set system messages locale to match Vsystem_messages_locale, if
2357 possible. */
2358 void
2359 synchronize_system_messages_locale ()
2360 {
2361 #ifdef LC_MESSAGES
2362 synchronize_locale (LC_MESSAGES, &Vprevious_system_messages_locale,
2363 Vsystem_messages_locale);
2364 #endif
2365 }
2366 #endif /* HAVE_SETLOCALE */
2367 \f
2368 #ifndef SEPCHAR
2369 #define SEPCHAR ':'
2370 #endif
2371
2372 Lisp_Object
2373 decode_env_path (evarname, defalt)
2374 char *evarname, *defalt;
2375 {
2376 register char *path, *p;
2377 Lisp_Object lpath, element, tem;
2378
2379 /* It's okay to use getenv here, because this function is only used
2380 to initialize variables when Emacs starts up, and isn't called
2381 after that. */
2382 if (evarname != 0)
2383 path = (char *) getenv (evarname);
2384 else
2385 path = 0;
2386 if (!path)
2387 path = defalt;
2388 #ifdef DOS_NT
2389 /* Ensure values from the environment use the proper directory separator. */
2390 if (path)
2391 {
2392 p = alloca (strlen (path) + 1);
2393 strcpy (p, path);
2394 path = p;
2395
2396 if ('/' == DIRECTORY_SEP)
2397 dostounix_filename (path);
2398 else
2399 unixtodos_filename (path);
2400 }
2401 #endif
2402 lpath = Qnil;
2403 while (1)
2404 {
2405 p = index (path, SEPCHAR);
2406 if (!p) p = path + strlen (path);
2407 element = (p - path ? make_string (path, p - path)
2408 : build_string ("."));
2409
2410 /* Add /: to the front of the name
2411 if it would otherwise be treated as magic. */
2412 tem = Ffind_file_name_handler (element, Qt);
2413
2414 /* However, if the handler says "I'm safe",
2415 don't bother adding /:. */
2416 if (SYMBOLP (tem))
2417 {
2418 Lisp_Object prop;
2419 prop = Fget (tem, intern ("safe-magic"));
2420 if (! NILP (prop))
2421 tem = Qnil;
2422 }
2423
2424 if (! NILP (tem))
2425 element = concat2 (build_string ("/:"), element);
2426
2427 lpath = Fcons (element, lpath);
2428 if (*p)
2429 path = p + 1;
2430 else
2431 break;
2432 }
2433 return Fnreverse (lpath);
2434 }
2435
2436 void
2437 syms_of_emacs ()
2438 {
2439 Qfile_name_handler_alist = intern ("file-name-handler-alist");
2440 staticpro (&Qfile_name_handler_alist);
2441
2442 #ifndef CANNOT_DUMP
2443 #ifdef HAVE_SHM
2444 defsubr (&Sdump_emacs_data);
2445 #else
2446 defsubr (&Sdump_emacs);
2447 #endif
2448 #endif
2449
2450 defsubr (&Skill_emacs);
2451
2452 defsubr (&Sinvocation_name);
2453 defsubr (&Sinvocation_directory);
2454
2455 DEFVAR_LISP ("command-line-args", &Vcommand_line_args,
2456 doc: /* Args passed by shell to Emacs, as a list of strings.
2457 Many arguments are deleted from the list as they are processed. */);
2458
2459 DEFVAR_LISP ("system-type", &Vsystem_type,
2460 doc: /* Value is symbol indicating type of operating system you are using.
2461 Special values:
2462 `gnu/linux' compiled for a GNU/Linux system.
2463 `darwin' compiled for Darwin (GNU-Darwin, Mac OS X, ...).
2464 `macos' compiled for Mac OS 9.
2465 `ms-dos' compiled as an MS-DOS application.
2466 `windows-nt' compiled as a native W32 application.
2467 `cygwin' compiled using the Cygwin library.
2468 `vax-vms' or `axp-vms': compiled for a (Open)VMS system.
2469 Anything else indicates some sort of Unix system. */);
2470 Vsystem_type = intern (SYSTEM_TYPE);
2471
2472 DEFVAR_LISP ("system-configuration", &Vsystem_configuration,
2473 doc: /* Value is string indicating configuration Emacs was built for.
2474 On MS-Windows, the value reflects the OS flavor and version on which
2475 Emacs is running. */);
2476 Vsystem_configuration = build_string (EMACS_CONFIGURATION);
2477
2478 DEFVAR_LISP ("system-configuration-options", &Vsystem_configuration_options,
2479 doc: /* String containing the configuration options Emacs was built with. */);
2480 Vsystem_configuration_options = build_string (EMACS_CONFIG_OPTIONS);
2481
2482 DEFVAR_BOOL ("noninteractive", &noninteractive1,
2483 doc: /* Non-nil means Emacs is running without interactive terminal. */);
2484
2485 DEFVAR_LISP ("kill-emacs-hook", &Vkill_emacs_hook,
2486 doc: /* Hook to be run when kill-emacs is called.
2487 Since `kill-emacs' may be invoked when the terminal is disconnected (or
2488 in other similar situations), functions placed on this hook should not
2489 expect to be able to interact with the user. To ask for confirmation,
2490 see `kill-emacs-query-functions' instead.
2491
2492 The hook is not run in batch mode, i.e., if `noninteractive' is non-nil. */);
2493 Vkill_emacs_hook = Qnil;
2494
2495 empty_string = build_string ("");
2496 staticpro (&empty_string);
2497
2498 DEFVAR_INT ("emacs-priority", &emacs_priority,
2499 doc: /* Priority for Emacs to run at.
2500 This value is effective only if set before Emacs is dumped,
2501 and only if the Emacs executable is installed with setuid to permit
2502 it to change priority. (Emacs sets its uid back to the real uid.)
2503 Currently, you need to define SET_EMACS_PRIORITY in `config.h'
2504 before you compile Emacs, to enable the code for this feature. */);
2505 emacs_priority = 0;
2506
2507 DEFVAR_LISP ("path-separator", &Vpath_separator,
2508 doc: /* The directory separator in search paths, as a string. */);
2509 {
2510 char c = SEPCHAR;
2511 Vpath_separator = make_string (&c, 1);
2512 }
2513
2514 DEFVAR_LISP ("invocation-name", &Vinvocation_name,
2515 doc: /* The program name that was used to run Emacs.
2516 Any directory names are omitted. */);
2517
2518 DEFVAR_LISP ("invocation-directory", &Vinvocation_directory,
2519 doc: /* The directory in which the Emacs executable was found, to run it.
2520 The value is nil if that directory's name is not known. */);
2521
2522 DEFVAR_LISP ("installation-directory", &Vinstallation_directory,
2523 doc: /* A directory within which to look for the `lib-src' and `etc' directories.
2524 This is non-nil when we can't find those directories in their standard
2525 installed locations, but we can find them
2526 near where the Emacs executable was found. */);
2527 Vinstallation_directory = Qnil;
2528
2529 DEFVAR_LISP ("system-messages-locale", &Vsystem_messages_locale,
2530 doc: /* System locale for messages. */);
2531 Vsystem_messages_locale = Qnil;
2532
2533 DEFVAR_LISP ("previous-system-messages-locale",
2534 &Vprevious_system_messages_locale,
2535 doc: /* Most recently used system locale for messages. */);
2536 Vprevious_system_messages_locale = Qnil;
2537
2538 DEFVAR_LISP ("system-time-locale", &Vsystem_time_locale,
2539 doc: /* System locale for time. */);
2540 Vsystem_time_locale = Qnil;
2541
2542 DEFVAR_LISP ("previous-system-time-locale", &Vprevious_system_time_locale,
2543 doc: /* Most recently used system locale for time. */);
2544 Vprevious_system_time_locale = Qnil;
2545 }
2546
2547 /* arch-tag: 7bfd356a-c720-4612-8ab6-aa4222931c2e
2548 (do not change this comment) */