Remove obsolete uses of HAVE_SHM.
[emacs.git] / src / emacs.c
blobdbaae9b040b7c7005e536e9f3cdb7269434381c0
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, 2006, 2007, 2008, 2009,
4 2010 Free Software Foundation, Inc.
6 This file is part of GNU Emacs.
8 GNU Emacs is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
13 GNU Emacs is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
22 #include <config.h>
23 #include <signal.h>
24 #include <errno.h>
25 #include <stdio.h>
27 #include <sys/types.h>
28 #include <sys/file.h>
29 #include <setjmp.h>
31 #ifdef HAVE_UNISTD_H
32 #include <unistd.h>
33 #endif
35 #ifdef BSD_SYSTEM
36 #include <sys/ioctl.h>
37 #endif
39 #ifdef WINDOWSNT
40 #include <fcntl.h>
41 #include <windows.h> /* just for w32.h */
42 #include "w32.h"
43 #include "w32heap.h" /* for prototype of sbrk */
44 #endif
46 #ifdef NS_IMPL_GNUSTEP
47 /* At least under Debian, GSConfig is in a subdirectory. --Stef */
48 #include <GNUstepBase/GSConfig.h>
49 #endif
51 #include "lisp.h"
52 #include "commands.h"
53 #include "intervals.h"
54 #include "buffer.h"
55 #include "window.h"
57 #include "systty.h"
58 #include "blockinput.h"
59 #include "syssignal.h"
60 #include "process.h"
61 #include "frame.h"
62 #include "termhooks.h"
63 #include "keyboard.h"
64 #include "keymap.h"
66 #ifdef HAVE_SETLOCALE
67 #include <locale.h>
68 #endif
70 #ifdef HAVE_SETRLIMIT
71 #include <sys/time.h>
72 #include <sys/resource.h>
73 #endif
75 #ifdef HAVE_PERSONALITY_LINUX32
76 #include <sys/personality.h>
77 #endif
79 #ifndef O_RDWR
80 #define O_RDWR 2
81 #endif
83 #ifdef HAVE_SETPGID
84 #if !defined (USG) || defined (BSD_PGRPS)
85 #undef setpgrp
86 #define setpgrp setpgid
87 #endif
88 #endif
90 extern void malloc_warning P_ ((char *));
91 extern void set_time_zone_rule P_ ((char *));
92 #ifdef HAVE_INDEX
93 extern char *index P_ ((const char *, int));
94 #endif
96 /* Make these values available in GDB, which doesn't see macros. */
98 #ifdef USE_LSB_TAG
99 int gdb_use_lsb = 1;
100 #else
101 int gdb_use_lsb = 0;
102 #endif
103 #ifndef USE_LISP_UNION_TYPE
104 int gdb_use_union = 0;
105 #else
106 int gdb_use_union = 1;
107 #endif
108 EMACS_INT gdb_valbits = VALBITS;
109 EMACS_INT gdb_gctypebits = GCTYPEBITS;
110 #if defined (DATA_SEG_BITS) && ! defined (USE_LSB_TAG)
111 EMACS_INT gdb_data_seg_bits = DATA_SEG_BITS;
112 #else
113 EMACS_INT gdb_data_seg_bits = 0;
114 #endif
115 EMACS_INT PVEC_FLAG = PSEUDOVECTOR_FLAG;
116 EMACS_INT gdb_array_mark_flag = ARRAY_MARK_FLAG;
117 /* GDB might say "No enum type named pvec_type" if we don't have at
118 least one symbol with that type, and then xbacktrace could fail. */
119 enum pvec_type gdb_pvec_type = PVEC_TYPE_MASK;
121 /* Command line args from shell, as list of strings. */
122 Lisp_Object Vcommand_line_args;
124 /* The name under which Emacs was invoked, with any leading directory
125 names discarded. */
126 Lisp_Object Vinvocation_name;
128 /* The directory name from which Emacs was invoked. */
129 Lisp_Object Vinvocation_directory;
131 /* The directory name in which to find subdirs such as lisp and etc.
132 nil means get them only from PATH_LOADSEARCH. */
133 Lisp_Object Vinstallation_directory;
135 /* The values of `current-time' before and after Emacs initialization. */
136 Lisp_Object Vbefore_init_time, Vafter_init_time;
138 /* Hook run by `kill-emacs' before it does really anything. */
139 Lisp_Object Vkill_emacs_hook;
141 /* Empty lisp strings. To avoid having to build any others. */
142 Lisp_Object empty_unibyte_string, empty_multibyte_string;
144 /* Search path separator. */
145 Lisp_Object Vpath_separator;
147 /* Set nonzero after Emacs has started up the first time.
148 Prevents reinitialization of the Lisp world and keymaps
149 on subsequent starts. */
150 int initialized;
152 #ifdef DOUG_LEA_MALLOC
153 /* Preserves a pointer to the memory allocated that copies that
154 static data inside glibc's malloc. */
155 void *malloc_state_ptr;
156 /* From glibc, a routine that returns a copy of the malloc internal state. */
157 extern void *malloc_get_state ();
158 /* From glibc, a routine that overwrites the malloc internal state. */
159 extern int malloc_set_state ();
160 /* Non-zero if the MALLOC_CHECK_ environment variable was set while
161 dumping. Used to work around a bug in glibc's malloc. */
162 int malloc_using_checking;
163 #endif
165 /* Variable whose value is symbol giving operating system type. */
166 Lisp_Object Vsystem_type;
168 /* Variable whose value is string giving configuration built for. */
169 Lisp_Object Vsystem_configuration;
171 /* Variable whose value is string giving configuration options,
172 for use when reporting bugs. */
173 Lisp_Object Vsystem_configuration_options;
175 Lisp_Object Qfile_name_handler_alist;
177 /* Current and previous system locales for messages and time. */
178 Lisp_Object Vsystem_messages_locale;
179 Lisp_Object Vprevious_system_messages_locale;
180 Lisp_Object Vsystem_time_locale;
181 Lisp_Object Vprevious_system_time_locale;
183 /* If non-zero, emacs should not attempt to use a window-specific code,
184 but instead should use the virtual terminal under which it was started. */
185 int inhibit_window_system;
187 /* If nonzero, set Emacs to run at this priority. This is also used
188 in child_setup and sys_suspend to make sure subshells run at normal
189 priority; those functions have their own extern declaration. */
190 EMACS_INT emacs_priority;
192 /* If non-zero, a filter or a sentinel is running. Tested to save the match
193 data on the first attempt to change it inside asynchronous code. */
194 int running_asynch_code;
196 #ifdef BSD_PGRPS
197 /* See sysdep.c. */
198 extern int inherited_pgroup;
199 #endif
201 #if defined(HAVE_X_WINDOWS) || defined(HAVE_NS)
202 /* If non-zero, -d was specified, meaning we're using some window system. */
203 int display_arg;
204 #endif
206 /* An address near the bottom of the stack.
207 Tells GC how to save a copy of the stack. */
208 char *stack_bottom;
210 /* The address where the heap starts (from the first sbrk (0) call). */
211 static void *my_heap_start;
213 /* The gap between BSS end and heap start as far as we can tell. */
214 static unsigned long heap_bss_diff;
216 /* If the gap between BSS end and heap start is larger than this
217 output a warning in dump-emacs. */
218 #define MAX_HEAP_BSS_DIFF (1024*1024)
221 #ifdef HAVE_WINDOW_SYSTEM
222 extern Lisp_Object Vinitial_window_system;
223 #endif /* HAVE_WINDOW_SYSTEM */
225 extern Lisp_Object Vauto_save_list_file_name;
227 extern Lisp_Object Vinhibit_redisplay;
229 /* Nonzero means running Emacs without interactive terminal. */
231 int noninteractive;
233 /* Value of Lisp variable `noninteractive'.
234 Normally same as C variable `noninteractive'
235 but nothing terrible happens if user sets this one. */
237 int noninteractive1;
239 /* Nonzero means Emacs was run in --quick mode. */
240 int inhibit_x_resources;
242 /* Name for the server started by the daemon.*/
243 static char *daemon_name;
245 /* Pipe used to send exit notification to the daemon parent at
246 startup. */
247 int daemon_pipe[2];
249 /* Save argv and argc. */
250 char **initial_argv;
251 int initial_argc;
253 static void sort_args ();
254 void syms_of_emacs ();
256 /* MSVC needs each string be shorter than 2048 bytes, so the usage
257 strings below are split to not overflow this limit. */
258 #define USAGE1 "\
259 Usage: %s [OPTION-OR-FILENAME]...\n\
261 Run Emacs, the extensible, customizable, self-documenting real-time\n\
262 display editor. The recommended way to start Emacs for normal editing\n\
263 is with no options at all.\n\
265 Run M-x info RET m emacs RET m emacs invocation RET inside Emacs to\n\
266 read the main documentation for these command-line arguments.\n\
268 Initialization options:\n\
270 --batch do not do interactive display; implies -q\n\
271 --daemon start a server in the background\n\
272 --debug-init enable Emacs Lisp debugger for init file\n\
273 --display, -d DISPLAY use X server DISPLAY\n\
274 --no-desktop do not load a saved desktop\n\
275 --no-init-file, -q load neither ~/.emacs nor default.el\n\
276 --no-shared-memory, -nl do not use shared memory\n\
277 --no-site-file do not load site-start.el\n\
278 --no-splash do not display a splash screen on startup\n\
279 --no-window-system, -nw do not communicate with X, ignoring $DISPLAY\n\
280 --quick, -Q equivalent to -q --no-site-file --no-splash\n\
281 --script FILE run FILE as an Emacs Lisp script\n\
282 --terminal, -t DEVICE use DEVICE for terminal I/O\n\
283 --user, -u USER load ~USER/.emacs instead of your own\n\
284 \n%s"
286 #define USAGE2 "\
287 Action options:\n\
289 FILE visit FILE using find-file\n\
290 +LINE go to line LINE in next FILE\n\
291 +LINE:COLUMN go to line LINE, column COLUMN, in next FILE\n\
292 --directory, -L DIR add DIR to variable load-path\n\
293 --eval EXPR evaluate Emacs Lisp expression EXPR\n\
294 --execute EXPR evaluate Emacs Lisp expression EXPR\n\
295 --file FILE visit FILE using find-file\n\
296 --find-file FILE visit FILE using find-file\n\
297 --funcall, -f FUNC call Emacs Lisp function FUNC with no arguments\n\
298 --insert FILE insert contents of FILE into current buffer\n\
299 --kill exit without asking for confirmation\n\
300 --load, -l FILE load Emacs Lisp FILE using the load function\n\
301 --visit FILE visit FILE using find-file\n\
304 #define USAGE3 "\
305 Display options:\n\
307 --background-color, -bg COLOR window background color\n\
308 --basic-display, -D disable many display features;\n\
309 used for debugging Emacs\n\
310 --border-color, -bd COLOR main border color\n\
311 --border-width, -bw WIDTH width of main border\n\
312 --color, --color=MODE override color mode for character terminals;\n\
313 MODE defaults to `auto', and can also\n\
314 be `never', `auto', `always',\n\
315 or a mode name like `ansi8'\n\
316 --cursor-color, -cr COLOR color of the Emacs cursor indicating point\n\
317 --font, -fn FONT default font; must be fixed-width\n\
318 --foreground-color, -fg COLOR window foreground color\n\
319 --fullheight, -fh make the first frame high as the screen\n\
320 --fullscreen, -fs make first frame fullscreen\n\
321 --fullwidth, -fw make the first frame wide as the screen\n\
322 --maximized, -mm make the first frame maximized\n\
323 --geometry, -g GEOMETRY window geometry\n\
324 --no-bitmap-icon, -nbi do not use picture of gnu for Emacs icon\n\
325 --iconic start Emacs in iconified state\n\
326 --internal-border, -ib WIDTH width between text and main border\n\
327 --line-spacing, -lsp PIXELS additional space to put between lines\n\
328 --mouse-color, -ms COLOR mouse cursor color in Emacs window\n\
329 --name NAME title for initial Emacs frame\n\
330 --no-blinking-cursor, -nbc disable blinking cursor\n\
331 --reverse-video, -r, -rv switch foreground and background\n\
332 --title, -T TITLE title for initial Emacs frame\n\
333 --vertical-scroll-bars, -vb enable vertical scroll bars\n\
334 --xrm XRESOURCES set additional X resources\n\
335 --parent-id XID set parent window\n\
336 --help display this help and exit\n\
337 --version output version information and exit\n\
340 #define USAGE4 "\
341 You can generally also specify long option names with a single -; for\n\
342 example, -batch as well as --batch. You can use any unambiguous\n\
343 abbreviation for a --option.\n\
345 Various environment variables and window system resources also affect\n\
346 Emacs' operation. See the main documentation.\n\
348 Report bugs to bug-gnu-emacs@gnu.org. First, please see the Bugs\n\
349 section of the Emacs manual or the file BUGS.\n"
352 /* Signal code for the fatal signal that was received. */
353 int fatal_error_code;
355 /* Nonzero if handling a fatal error already. */
356 int fatal_error_in_progress;
358 /* If non-null, call this function from fatal_error_signal before
359 committing suicide. */
361 void (*fatal_error_signal_hook) P_ ((void));
363 #ifdef FORWARD_SIGNAL_TO_MAIN_THREAD
364 /* When compiled with GTK and running under Gnome,
365 multiple threads may be created. Keep track of our main
366 thread to make sure signals are delivered to it (see syssignal.h). */
368 pthread_t main_thread;
369 #endif
372 /* Handle bus errors, invalid instruction, etc. */
373 SIGTYPE
374 fatal_error_signal (sig)
375 int sig;
377 SIGNAL_THREAD_CHECK (sig);
378 fatal_error_code = sig;
379 signal (sig, SIG_DFL);
381 TOTALLY_UNBLOCK_INPUT;
383 /* If fatal error occurs in code below, avoid infinite recursion. */
384 if (! fatal_error_in_progress)
386 fatal_error_in_progress = 1;
388 shut_down_emacs (sig, 0, Qnil);
391 /* Signal the same code; this time it will really be fatal.
392 Remember that since we're in a signal handler, the signal we're
393 going to send is probably blocked, so we have to unblock it if we
394 want to really receive it. */
395 #ifndef MSDOS
396 sigunblock (sigmask (fatal_error_code));
397 #endif
399 if (fatal_error_signal_hook)
400 fatal_error_signal_hook ();
402 kill (getpid (), fatal_error_code);
405 #ifdef SIGDANGER
407 /* Handler for SIGDANGER. */
408 SIGTYPE
409 memory_warning_signal (sig)
410 int sig;
412 signal (sig, memory_warning_signal);
413 SIGNAL_THREAD_CHECK (sig);
415 malloc_warning ("Operating system warns that virtual memory is running low.\n");
417 /* It might be unsafe to call do_auto_save now. */
418 force_auto_save_soon ();
420 #endif
422 /* We define abort, rather than using it from the library,
423 so that GDB can return from a breakpoint here.
424 MSDOS has its own definition in msdos.c. */
426 #if ! defined (DOS_NT) && ! defined (NO_ABORT)
428 void
429 abort ()
431 kill (getpid (), SIGABRT);
432 /* This shouldn't be executed, but it prevents a warning. */
433 exit (1);
435 #endif
438 /* Code for dealing with Lisp access to the Unix command line. */
440 static void
441 init_cmdargs (argc, argv, skip_args)
442 int argc;
443 char **argv;
444 int skip_args;
446 register int i;
447 Lisp_Object name, dir, tem;
448 int count = SPECPDL_INDEX ();
449 Lisp_Object raw_name;
451 initial_argv = argv;
452 initial_argc = argc;
454 raw_name = build_string (argv[0]);
456 /* Add /: to the front of the name
457 if it would otherwise be treated as magic. */
458 tem = Ffind_file_name_handler (raw_name, Qt);
459 if (! NILP (tem))
460 raw_name = concat2 (build_string ("/:"), raw_name);
462 Vinvocation_name = Ffile_name_nondirectory (raw_name);
463 Vinvocation_directory = Ffile_name_directory (raw_name);
465 /* If we got no directory in argv[0], search PATH to find where
466 Emacs actually came from. */
467 if (NILP (Vinvocation_directory))
469 Lisp_Object found;
470 int yes = openp (Vexec_path, Vinvocation_name,
471 Vexec_suffixes, &found, make_number (X_OK));
472 if (yes == 1)
474 /* Add /: to the front of the name
475 if it would otherwise be treated as magic. */
476 tem = Ffind_file_name_handler (found, Qt);
477 if (! NILP (tem))
478 found = concat2 (build_string ("/:"), found);
479 Vinvocation_directory = Ffile_name_directory (found);
483 if (!NILP (Vinvocation_directory)
484 && NILP (Ffile_name_absolute_p (Vinvocation_directory)))
485 /* Emacs was started with relative path, like ./emacs.
486 Make it absolute. */
487 Vinvocation_directory = Fexpand_file_name (Vinvocation_directory, Qnil);
489 Vinstallation_directory = Qnil;
491 if (!NILP (Vinvocation_directory))
493 dir = Vinvocation_directory;
494 name = Fexpand_file_name (Vinvocation_name, dir);
495 while (1)
497 Lisp_Object tem, lib_src_exists;
498 Lisp_Object etc_exists, info_exists;
500 /* See if dir contains subdirs for use by Emacs.
501 Check for the ones that would exist in a build directory,
502 not including lisp and info. */
503 tem = Fexpand_file_name (build_string ("lib-src"), dir);
504 lib_src_exists = Ffile_exists_p (tem);
506 #ifdef MSDOS
507 /* MSDOS installations frequently remove lib-src, but we still
508 must set installation-directory, or else info won't find
509 its files (it uses the value of installation-directory). */
510 tem = Fexpand_file_name (build_string ("info"), dir);
511 info_exists = Ffile_exists_p (tem);
512 #else
513 info_exists = Qnil;
514 #endif
516 if (!NILP (lib_src_exists) || !NILP (info_exists))
518 tem = Fexpand_file_name (build_string ("etc"), dir);
519 etc_exists = Ffile_exists_p (tem);
520 if (!NILP (etc_exists))
522 Vinstallation_directory
523 = Ffile_name_as_directory (dir);
524 break;
528 /* See if dir's parent contains those subdirs. */
529 tem = Fexpand_file_name (build_string ("../lib-src"), dir);
530 lib_src_exists = Ffile_exists_p (tem);
533 #ifdef MSDOS
534 /* See the MSDOS commentary above. */
535 tem = Fexpand_file_name (build_string ("../info"), dir);
536 info_exists = Ffile_exists_p (tem);
537 #else
538 info_exists = Qnil;
539 #endif
541 if (!NILP (lib_src_exists) || !NILP (info_exists))
543 tem = Fexpand_file_name (build_string ("../etc"), dir);
544 etc_exists = Ffile_exists_p (tem);
545 if (!NILP (etc_exists))
547 tem = Fexpand_file_name (build_string (".."), dir);
548 Vinstallation_directory
549 = Ffile_name_as_directory (tem);
550 break;
554 /* If the Emacs executable is actually a link,
555 next try the dir that the link points into. */
556 tem = Ffile_symlink_p (name);
557 if (!NILP (tem))
559 name = Fexpand_file_name (tem, dir);
560 dir = Ffile_name_directory (name);
562 else
563 break;
567 Vcommand_line_args = Qnil;
569 for (i = argc - 1; i >= 0; i--)
571 if (i == 0 || i > skip_args)
572 /* For the moment, we keep arguments as is in unibyte strings.
573 They are decoded in the function command-line after we know
574 locale-coding-system. */
575 Vcommand_line_args
576 = Fcons (make_unibyte_string (argv[i], strlen (argv[i])),
577 Vcommand_line_args);
580 unbind_to (count, Qnil);
583 DEFUN ("invocation-name", Finvocation_name, Sinvocation_name, 0, 0, 0,
584 doc: /* Return the program name that was used to run Emacs.
585 Any directory names are omitted. */)
588 return Fcopy_sequence (Vinvocation_name);
591 DEFUN ("invocation-directory", Finvocation_directory, Sinvocation_directory,
592 0, 0, 0,
593 doc: /* Return the directory name in which the Emacs executable was located. */)
596 return Fcopy_sequence (Vinvocation_directory);
600 #ifdef HAVE_TZSET
601 /* A valid but unlikely value for the TZ environment value.
602 It is OK (though a bit slower) if the user actually chooses this value. */
603 static char dump_tz[] = "UtC0";
604 #endif
606 #ifndef ORDINARY_LINK
607 /* We don't include crtbegin.o and crtend.o in the link,
608 so these functions and variables might be missed.
609 Provide dummy definitions to avoid error.
610 (We don't have any real constructors or destructors.) */
611 #ifdef __GNUC__
612 #ifndef GCC_CTORS_IN_LIBC
613 void __do_global_ctors ()
615 void __do_global_ctors_aux ()
617 void __do_global_dtors ()
619 /* GNU/Linux has a bug in its library; avoid an error. */
620 #ifndef GNU_LINUX
621 char * __CTOR_LIST__[2] = { (char *) (-1), 0 };
622 #endif
623 char * __DTOR_LIST__[2] = { (char *) (-1), 0 };
624 #endif /* GCC_CTORS_IN_LIBC */
625 void __main ()
627 #endif /* __GNUC__ */
628 #endif /* ORDINARY_LINK */
630 /* Test whether the next argument in ARGV matches SSTR or a prefix of
631 LSTR (at least MINLEN characters). If so, then if VALPTR is non-null
632 (the argument is supposed to have a value) store in *VALPTR either
633 the next argument or the portion of this one after the equal sign.
634 ARGV is read starting at position *SKIPPTR; this index is advanced
635 by the number of arguments used.
637 Too bad we can't just use getopt for all of this, but we don't have
638 enough information to do it right. */
640 static int
641 argmatch (argv, argc, sstr, lstr, minlen, valptr, skipptr)
642 char **argv;
643 int argc;
644 char *sstr;
645 char *lstr;
646 int minlen;
647 char **valptr;
648 int *skipptr;
650 char *p = NULL;
651 int arglen;
652 char *arg;
654 /* Don't access argv[argc]; give up in advance. */
655 if (argc <= *skipptr + 1)
656 return 0;
658 arg = argv[*skipptr+1];
659 if (arg == NULL)
660 return 0;
661 if (strcmp (arg, sstr) == 0)
663 if (valptr != NULL)
665 *valptr = argv[*skipptr+2];
666 *skipptr += 2;
668 else
669 *skipptr += 1;
670 return 1;
672 arglen = (valptr != NULL && (p = index (arg, '=')) != NULL
673 ? p - arg : strlen (arg));
674 if (lstr == 0 || arglen < minlen || strncmp (arg, lstr, arglen) != 0)
675 return 0;
676 else if (valptr == NULL)
678 *skipptr += 1;
679 return 1;
681 else if (p != NULL)
683 *valptr = p+1;
684 *skipptr += 1;
685 return 1;
687 else if (argv[*skipptr+2] != NULL)
689 *valptr = argv[*skipptr+2];
690 *skipptr += 2;
691 return 1;
693 else
695 return 0;
699 #ifdef DOUG_LEA_MALLOC
701 /* malloc can be invoked even before main (e.g. by the dynamic
702 linker), so the dumped malloc state must be restored as early as
703 possible using this special hook. */
705 static void
706 malloc_initialize_hook ()
708 #ifndef USE_CRT_DLL
709 extern char **environ;
710 #endif
712 if (initialized)
714 if (!malloc_using_checking)
715 /* Work around a bug in glibc's malloc. MALLOC_CHECK_ must be
716 ignored if the heap to be restored was constructed without
717 malloc checking. Can't use unsetenv, since that calls malloc. */
719 char **p;
721 for (p = environ; p && *p; p++)
722 if (strncmp (*p, "MALLOC_CHECK_=", 14) == 0)
725 *p = p[1];
726 while (*++p);
727 break;
731 malloc_set_state (malloc_state_ptr);
732 #ifndef XMALLOC_OVERRUN_CHECK
733 free (malloc_state_ptr);
734 #endif
736 else
738 if (my_heap_start == 0)
739 my_heap_start = sbrk (0);
740 malloc_using_checking = getenv ("MALLOC_CHECK_") != NULL;
744 void (*__malloc_initialize_hook) () = malloc_initialize_hook;
746 #endif /* DOUG_LEA_MALLOC */
749 /* ARGSUSED */
751 main (int argc, char **argv)
753 #if GC_MARK_STACK
754 Lisp_Object dummy;
755 #endif
756 char stack_bottom_variable;
757 int do_initial_setlocale;
758 int skip_args = 0;
759 #ifndef USE_CRT_DLL
760 extern int errno;
761 #endif
762 #ifdef HAVE_SETRLIMIT
763 struct rlimit rlim;
764 #endif
765 int no_loadup = 0;
766 char *junk = 0;
767 char *dname_arg = 0;
768 #ifdef NS_IMPL_COCOA
769 char dname_arg2[80];
770 #endif
772 #if GC_MARK_STACK
773 extern Lisp_Object *stack_base;
774 stack_base = &dummy;
775 #endif
777 #if defined (USE_GTK) && defined (G_SLICE_ALWAYS_MALLOC)
778 /* This is used by the Cygwin build. */
779 setenv ("G_SLICE", "always-malloc", 1);
780 #endif
782 if (!initialized)
784 extern char my_endbss[];
785 extern char *my_endbss_static;
787 if (my_heap_start == 0)
788 my_heap_start = sbrk (0);
790 heap_bss_diff = (char *)my_heap_start - max (my_endbss, my_endbss_static);
793 #ifdef LINUX_SBRK_BUG
794 /* This is only used GNU/LINUX running on alpha when using libc5 */
795 __sbrk (1);
796 #endif
798 #ifdef RUN_TIME_REMAP
799 if (initialized)
800 run_time_remap (argv[0]);
801 #endif
803 /* If using unexmacosx.c (set by s/darwin.h), we must do this. */
804 #ifdef DARWIN_OS
805 if (!initialized)
806 unexec_init_emacs_zone ();
807 #endif
809 sort_args (argc, argv);
810 argc = 0;
811 while (argv[argc]) argc++;
813 if (argmatch (argv, argc, "-version", "--version", 3, NULL, &skip_args)
814 /* We don't know the version number unless this is a dumped Emacs.
815 So ignore --version otherwise. */
816 && initialized)
818 Lisp_Object tem, tem2;
819 tem = Fsymbol_value (intern_c_string ("emacs-version"));
820 tem2 = Fsymbol_value (intern_c_string ("emacs-copyright"));
821 if (!STRINGP (tem))
823 fprintf (stderr, "Invalid value of `emacs-version'\n");
824 exit (1);
826 if (!STRINGP (tem2))
828 fprintf (stderr, "Invalid value of `emacs-copyright'\n");
829 exit (1);
831 else
833 printf ("GNU Emacs %s\n", SDATA (tem));
834 printf ("%s\n", SDATA(tem2));
835 printf ("GNU Emacs comes with ABSOLUTELY NO WARRANTY.\n");
836 printf ("You may redistribute copies of Emacs\n");
837 printf ("under the terms of the GNU General Public License.\n");
838 printf ("For more information about these matters, ");
839 printf ("see the file named COPYING.\n");
840 exit (0);
844 #ifdef HAVE_PERSONALITY_LINUX32
845 if (!initialized
846 && (strcmp (argv[argc-1], "dump") == 0
847 || strcmp (argv[argc-1], "bootstrap") == 0)
848 && ! getenv ("EMACS_HEAP_EXEC"))
850 /* Set this so we only do this once. */
851 putenv("EMACS_HEAP_EXEC=true");
853 /* A flag to turn off address randomization which is introduced
854 in linux kernel shipped with fedora core 4 */
855 #define ADD_NO_RANDOMIZE 0x0040000
856 personality (PER_LINUX32 | ADD_NO_RANDOMIZE);
857 #undef ADD_NO_RANDOMIZE
859 execvp (argv[0], argv);
861 /* If the exec fails, try to dump anyway. */
862 perror ("execvp");
864 #endif /* HAVE_PERSONALITY_LINUX32 */
867 /* Map in shared memory, if we are using that. */
868 #ifdef HAVE_SHM
869 if (argmatch (argv, argc, "-nl", "--no-shared-memory", 6, NULL, &skip_args))
871 map_in_data (0);
872 /* The shared memory was just restored, which clobbered this. */
873 skip_args = 1;
875 else
877 map_in_data (1);
878 /* The shared memory was just restored, which clobbered this. */
879 skip_args = 0;
881 #endif
883 #if defined (HAVE_SETRLIMIT) && defined (RLIMIT_STACK)
884 /* Extend the stack space available.
885 Don't do that if dumping, since some systems (e.g. DJGPP)
886 might define a smaller stack limit at that time. */
887 if (1
888 #ifndef CANNOT_DUMP
889 && (!noninteractive || initialized)
890 #endif
891 && !getrlimit (RLIMIT_STACK, &rlim))
893 long newlim;
894 extern size_t re_max_failures;
895 /* Approximate the amount regex.c needs per unit of re_max_failures. */
896 int ratio = 20 * sizeof (char *);
897 /* Then add 33% to cover the size of the smaller stacks that regex.c
898 successively allocates and discards, on its way to the maximum. */
899 ratio += ratio / 3;
900 /* Add in some extra to cover
901 what we're likely to use for other reasons. */
902 newlim = re_max_failures * ratio + 200000;
903 #ifdef __NetBSD__
904 /* NetBSD (at least NetBSD 1.2G and former) has a bug in its
905 stack allocation routine for new process that the allocation
906 fails if stack limit is not on page boundary. So, round up the
907 new limit to page boundary. */
908 newlim = (newlim + getpagesize () - 1) / getpagesize () * getpagesize();
909 #endif
910 if (newlim > rlim.rlim_max)
912 newlim = rlim.rlim_max;
913 /* Don't let regex.c overflow the stack we have. */
914 re_max_failures = (newlim - 200000) / ratio;
916 if (rlim.rlim_cur < newlim)
917 rlim.rlim_cur = newlim;
919 setrlimit (RLIMIT_STACK, &rlim);
921 #endif /* HAVE_SETRLIMIT and RLIMIT_STACK */
923 /* Record (approximately) where the stack begins. */
924 stack_bottom = &stack_bottom_variable;
926 clearerr (stdin);
928 #ifndef SYSTEM_MALLOC
929 /* Arrange to get warning messages as memory fills up. */
930 memory_warnings (0, malloc_warning);
932 /* Call malloc at least once, to run the initial __malloc_hook.
933 Also call realloc and free for consistency. */
934 free (realloc (malloc (4), 4));
936 # ifndef SYNC_INPUT
937 /* Arrange to disable interrupt input inside malloc etc. */
938 uninterrupt_malloc ();
939 # endif /* not SYNC_INPUT */
940 #endif /* not SYSTEM_MALLOC */
942 #ifdef FORWARD_SIGNAL_TO_MAIN_THREAD
943 main_thread = pthread_self ();
944 #endif /* FORWARD_SIGNAL_TO_MAIN_THREAD */
946 #if defined (MSDOS) || defined (WINDOWSNT)
947 /* We do all file input/output as binary files. When we need to translate
948 newlines, we do that manually. */
949 _fmode = O_BINARY;
950 #endif /* MSDOS || WINDOWSNT */
952 #ifdef MSDOS
953 #if __DJGPP__ >= 2
954 if (!isatty (fileno (stdin)))
955 setmode (fileno (stdin), O_BINARY);
956 if (!isatty (fileno (stdout)))
958 fflush (stdout);
959 setmode (fileno (stdout), O_BINARY);
961 #else /* not __DJGPP__ >= 2 */
962 (stdin)->_flag &= ~_IOTEXT;
963 (stdout)->_flag &= ~_IOTEXT;
964 (stderr)->_flag &= ~_IOTEXT;
965 #endif /* not __DJGPP__ >= 2 */
966 #endif /* MSDOS */
968 #ifdef SET_EMACS_PRIORITY
969 if (emacs_priority)
970 nice (emacs_priority);
971 setuid (getuid ());
972 #endif /* SET_EMACS_PRIORITY */
974 /* Skip initial setlocale if LC_ALL is "C", as it's not needed in that case.
975 The build procedure uses this while dumping, to ensure that the
976 dumped Emacs does not have its system locale tables initialized,
977 as that might cause screwups when the dumped Emacs starts up. */
979 char *lc_all = getenv ("LC_ALL");
980 do_initial_setlocale = ! lc_all || strcmp (lc_all, "C");
983 /* Set locale now, so that initial error messages are localized properly.
984 fixup_locale must wait until later, since it builds strings. */
985 if (do_initial_setlocale)
986 setlocale (LC_ALL, "");
988 inhibit_window_system = 0;
990 /* Handle the -t switch, which specifies filename to use as terminal. */
991 while (1)
993 char *term;
994 if (argmatch (argv, argc, "-t", "--terminal", 4, &term, &skip_args))
996 int result;
997 emacs_close (0);
998 emacs_close (1);
999 result = emacs_open (term, O_RDWR, 0);
1000 if (result < 0)
1002 char *errstring = strerror (errno);
1003 fprintf (stderr, "%s: %s: %s\n", argv[0], term, errstring);
1004 exit (1);
1006 dup (0);
1007 if (! isatty (0))
1009 fprintf (stderr, "%s: %s: not a tty\n", argv[0], term);
1010 exit (1);
1012 fprintf (stderr, "Using %s\n", term);
1013 #ifdef HAVE_WINDOW_SYSTEM
1014 inhibit_window_system = 1; /* -t => -nw */
1015 #endif
1017 else
1018 break;
1021 /* Command line option --no-windows is deprecated and thus not mentioned
1022 in the manual and usage informations. */
1023 if (argmatch (argv, argc, "-nw", "--no-window-system", 6, NULL, &skip_args)
1024 || argmatch (argv, argc, "-nw", "--no-windows", 6, NULL, &skip_args))
1025 inhibit_window_system = 1;
1027 /* Handle the -batch switch, which means don't do interactive display. */
1028 noninteractive = 0;
1029 if (argmatch (argv, argc, "-batch", "--batch", 5, NULL, &skip_args))
1031 noninteractive = 1;
1032 Vundo_outer_limit = Qnil;
1034 if (argmatch (argv, argc, "-script", "--script", 3, &junk, &skip_args))
1036 noninteractive = 1; /* Set batch mode. */
1037 /* Convert --script to -scriptload, un-skip it, and sort again
1038 so that it will be handled in proper sequence. */
1039 /* FIXME broken for --script=FILE - is that supposed to work? */
1040 argv[skip_args - 1] = "-scriptload";
1041 skip_args -= 2;
1042 sort_args (argc, argv);
1045 /* Handle the --help option, which gives a usage message. */
1046 if (argmatch (argv, argc, "-help", "--help", 3, NULL, &skip_args))
1048 printf (USAGE1, argv[0], USAGE2);
1049 printf (USAGE3);
1050 printf (USAGE4);
1051 exit (0);
1054 if (argmatch (argv, argc, "-daemon", "--daemon", 5, NULL, &skip_args)
1055 || argmatch (argv, argc, "-daemon", "--daemon", 5, &dname_arg, &skip_args))
1057 #ifndef DOS_NT
1058 pid_t f;
1060 /* Start as a daemon: fork a new child process which will run the
1061 rest of the initialization code, then exit.
1063 Detaching a daemon requires the following steps:
1064 - fork
1065 - setsid
1066 - exit the parent
1067 - close the tty file-descriptors
1069 We only want to do the last 2 steps once the daemon is ready to
1070 serve requests, i.e. after loading .emacs (initialization).
1071 OTOH initialization may start subprocesses (e.g. ispell) and these
1072 should be run from the proper process (the one that will end up
1073 running as daemon) and with the proper "session id" in order for
1074 them to keep working after detaching, so fork and setsid need to be
1075 performed before initialization.
1077 We want to avoid exiting before the server socket is ready, so
1078 use a pipe for synchronization. The parent waits for the child
1079 to close its end of the pipe (using `daemon-initialized')
1080 before exiting. */
1081 if (pipe (daemon_pipe) == -1)
1083 fprintf (stderr, "Cannot pipe!\n");
1084 exit (1);
1087 #ifndef NS_IMPL_COCOA
1088 f = fork ();
1089 #else /* NS_IMPL_COCOA */
1090 /* Under Cocoa we must do fork+exec as CoreFoundation lib fails in
1091 forked process: http://developer.apple.com/ReleaseNotes/
1092 CoreFoundation/CoreFoundation.html)
1093 We mark being in the exec'd process by a daemon name argument of
1094 form "--daemon=\nFD0,FD1\nNAME" where FD are the pipe file descriptors,
1095 NAME is the original daemon name, if any. */
1096 if (!dname_arg || !strchr (dname_arg, '\n'))
1097 f = fork (); /* in orig */
1098 else
1099 f = 0; /* in exec'd */
1100 #endif /* NS_IMPL_COCOA */
1101 if (f > 0)
1103 int retval;
1104 char buf[1];
1106 /* Close unused writing end of the pipe. */
1107 close (daemon_pipe[1]);
1109 /* Just wait for the child to close its end of the pipe. */
1112 retval = read (daemon_pipe[0], &buf, 1);
1114 while (retval == -1 && errno == EINTR);
1116 if (retval < 0)
1118 fprintf (stderr, "Error reading status from child\n");
1119 exit (1);
1121 else if (retval == 0)
1123 fprintf (stderr, "Error: server did not start correctly\n");
1124 exit (1);
1127 close (daemon_pipe[0]);
1128 exit (0);
1130 if (f < 0)
1132 fprintf (stderr, "Cannot fork!\n");
1133 exit (1);
1136 #ifdef NS_IMPL_COCOA
1138 /* In orig process, forked as child, OR in exec'd. */
1139 if (!dname_arg || !strchr (dname_arg, '\n'))
1140 { /* In orig, child: now exec w/special daemon name. */
1141 char fdStr[80];
1143 if (dname_arg && strlen (dname_arg) > 70)
1145 fprintf (stderr, "daemon: child name too long\n");
1146 exit (1);
1149 sprintf (fdStr, "--daemon=\n%d,%d\n%s", daemon_pipe[0],
1150 daemon_pipe[1], dname_arg ? dname_arg : "");
1151 argv[skip_args] = fdStr;
1153 execv (argv[0], argv);
1154 fprintf (stderr, "emacs daemon: exec failed: %d\n", errno);
1155 exit (1);
1158 /* In exec'd: parse special dname into pipe and name info. */
1159 if (!dname_arg || !strchr (dname_arg, '\n')
1160 || strlen (dname_arg) < 1 || strlen (dname_arg) > 70)
1162 fprintf (stderr, "emacs daemon: daemon name absent or too long\n");
1163 exit(1);
1165 dname_arg2[0] = '\0';
1166 sscanf (dname_arg, "\n%d,%d\n%s", &(daemon_pipe[0]), &(daemon_pipe[1]),
1167 dname_arg2);
1168 dname_arg = strlen (dname_arg2) ? dname_arg2 : NULL;
1170 #endif /* NS_IMPL_COCOA */
1172 if (dname_arg)
1173 daemon_name = xstrdup (dname_arg);
1174 /* Close unused reading end of the pipe. */
1175 close (daemon_pipe[0]);
1176 /* Make sure that the used end of the pipe is closed on exec, so
1177 that it is not accessible to programs started from .emacs. */
1178 fcntl (daemon_pipe[1], F_SETFD, FD_CLOEXEC);
1180 #ifdef HAVE_SETSID
1181 setsid();
1182 #endif
1183 #else /* DOS_NT */
1184 fprintf (stderr, "This platform does not support the -daemon flag.\n");
1185 exit (1);
1186 #endif /* DOS_NT */
1189 if (! noninteractive)
1191 #ifdef BSD_PGRPS
1192 if (initialized)
1194 inherited_pgroup = EMACS_GETPGRP (0);
1195 setpgrp (0, getpid ());
1197 #else
1198 #if defined (USG5) && defined (INTERRUPT_INPUT)
1199 setpgrp ();
1200 #endif
1201 #endif
1202 #if defined (HAVE_GTK_AND_PTHREAD) && !defined (SYSTEM_MALLOC) && !defined (DOUG_LEA_MALLOC)
1204 extern void malloc_enable_thread P_ ((void));
1206 malloc_enable_thread ();
1208 #endif
1211 init_signals ();
1213 /* Don't catch SIGHUP if dumping. */
1214 if (1
1215 #ifndef CANNOT_DUMP
1216 && initialized
1217 #endif
1220 sigblock (sigmask (SIGHUP));
1221 /* In --batch mode, don't catch SIGHUP if already ignored.
1222 That makes nohup work. */
1223 if (! noninteractive
1224 || signal (SIGHUP, SIG_IGN) != SIG_IGN)
1225 signal (SIGHUP, fatal_error_signal);
1226 sigunblock (sigmask (SIGHUP));
1229 if (
1230 #ifndef CANNOT_DUMP
1231 ! noninteractive || initialized
1232 #else
1234 #endif
1237 /* Don't catch these signals in batch mode if dumping.
1238 On some machines, this sets static data that would make
1239 signal fail to work right when the dumped Emacs is run. */
1240 signal (SIGQUIT, fatal_error_signal);
1241 signal (SIGILL, fatal_error_signal);
1242 signal (SIGTRAP, fatal_error_signal);
1243 #ifdef SIGUSR1
1244 add_user_signal (SIGUSR1, "sigusr1");
1245 #endif
1246 #ifdef SIGUSR2
1247 add_user_signal (SIGUSR2, "sigusr2");
1248 #endif
1249 #ifdef SIGABRT
1250 signal (SIGABRT, fatal_error_signal);
1251 #endif
1252 #ifdef SIGHWE
1253 signal (SIGHWE, fatal_error_signal);
1254 #endif
1255 #ifdef SIGPRE
1256 signal (SIGPRE, fatal_error_signal);
1257 #endif
1258 #ifdef SIGORE
1259 signal (SIGORE, fatal_error_signal);
1260 #endif
1261 #ifdef SIGUME
1262 signal (SIGUME, fatal_error_signal);
1263 #endif
1264 #ifdef SIGDLK
1265 signal (SIGDLK, fatal_error_signal);
1266 #endif
1267 #ifdef SIGCPULIM
1268 signal (SIGCPULIM, fatal_error_signal);
1269 #endif
1270 #ifdef SIGIOT
1271 /* This is missing on some systems - OS/2, for example. */
1272 signal (SIGIOT, fatal_error_signal);
1273 #endif
1274 #ifdef SIGEMT
1275 signal (SIGEMT, fatal_error_signal);
1276 #endif
1277 signal (SIGFPE, fatal_error_signal);
1278 #ifdef SIGBUS
1279 signal (SIGBUS, fatal_error_signal);
1280 #endif
1281 signal (SIGSEGV, fatal_error_signal);
1282 #ifdef SIGSYS
1283 signal (SIGSYS, fatal_error_signal);
1284 #endif
1285 signal (SIGTERM, fatal_error_signal);
1286 #ifdef SIGXCPU
1287 signal (SIGXCPU, fatal_error_signal);
1288 #endif
1289 #ifdef SIGXFSZ
1290 signal (SIGXFSZ, fatal_error_signal);
1291 #endif /* SIGXFSZ */
1293 #ifdef SIGDANGER
1294 /* This just means available memory is getting low. */
1295 signal (SIGDANGER, memory_warning_signal);
1296 #endif
1298 #ifdef AIX
1299 /* 20 is SIGCHLD, 21 is SIGTTIN, 22 is SIGTTOU. */
1300 signal (SIGXCPU, fatal_error_signal);
1301 #ifndef _I386
1302 signal (SIGIOINT, fatal_error_signal);
1303 #endif
1304 signal (SIGGRANT, fatal_error_signal);
1305 signal (SIGRETRACT, fatal_error_signal);
1306 signal (SIGSOUND, fatal_error_signal);
1307 signal (SIGMSG, fatal_error_signal);
1308 #endif /* AIX */
1311 noninteractive1 = noninteractive;
1313 /* Perform basic initializations (not merely interning symbols). */
1315 if (!initialized)
1317 init_alloc_once ();
1318 init_obarray ();
1319 init_eval_once ();
1320 init_character_once ();
1321 init_charset_once ();
1322 init_coding_once ();
1323 init_syntax_once (); /* Create standard syntax table. */
1324 init_category_once (); /* Create standard category table. */
1325 /* Must be done before init_buffer. */
1326 init_casetab_once ();
1327 init_buffer_once (); /* Create buffer table and some buffers. */
1328 init_minibuf_once (); /* Create list of minibuffers. */
1329 /* Must precede init_window_once. */
1331 /* Call syms_of_xfaces before init_window_once because that
1332 function creates Vterminal_frame. Termcap frames now use
1333 faces, and the face implementation uses some symbols as
1334 face names. */
1335 syms_of_xfaces ();
1336 /* XXX syms_of_keyboard uses some symbols in keymap.c. It would
1337 be better to arrange things not to have this dependency. */
1338 syms_of_keymap ();
1339 /* Call syms_of_keyboard before init_window_once because
1340 keyboard sets up symbols that include some face names that
1341 the X support will want to use. This can happen when
1342 CANNOT_DUMP is defined. */
1343 syms_of_keyboard ();
1345 /* Called before syms_of_fileio, because it sets up Qerror_condition. */
1346 syms_of_data ();
1347 syms_of_fileio ();
1348 /* Before syms_of_coding to initialize Vgc_cons_threshold. */
1349 syms_of_alloc ();
1350 /* Before syms_of_coding because it initializes Qcharsetp. */
1351 syms_of_charset ();
1352 /* Before init_window_once, because it sets up the
1353 Vcoding_system_hash_table. */
1354 syms_of_coding (); /* This should be after syms_of_fileio. */
1356 init_window_once (); /* Init the window system. */
1357 #ifdef HAVE_WINDOW_SYSTEM
1358 init_fringe_once (); /* Swap bitmaps if necessary. */
1359 #endif /* HAVE_WINDOW_SYSTEM */
1362 init_alloc ();
1364 if (do_initial_setlocale)
1366 fixup_locale ();
1367 Vsystem_messages_locale = Vprevious_system_messages_locale;
1368 Vsystem_time_locale = Vprevious_system_time_locale;
1371 init_eval ();
1372 init_data ();
1373 #ifdef CLASH_DETECTION
1374 init_filelock ();
1375 #endif
1376 init_atimer ();
1377 running_asynch_code = 0;
1379 /* Handle --unibyte and the EMACS_UNIBYTE envvar,
1380 but not while dumping. */
1381 if (1)
1383 int inhibit_unibyte = 0;
1385 /* --multibyte overrides EMACS_UNIBYTE. */
1386 if (argmatch (argv, argc, "-no-unibyte", "--no-unibyte", 4, NULL, &skip_args)
1387 || argmatch (argv, argc, "-multibyte", "--multibyte", 4, NULL, &skip_args)
1388 /* Ignore EMACS_UNIBYTE before dumping. */
1389 || (!initialized && noninteractive))
1390 inhibit_unibyte = 1;
1392 /* --unibyte requests that we set up to do everything with single-byte
1393 buffers and strings. We need to handle this before calling
1394 init_lread, init_editfns and other places that generate Lisp strings
1395 from text in the environment. */
1396 /* Actually this shouldn't be needed as of 20.4 in a generally
1397 unibyte environment. As handa says, environment values
1398 aren't now decoded; also existing buffers are now made
1399 unibyte during startup if .emacs sets unibyte. Tested with
1400 8-bit data in environment variables and /etc/passwd, setting
1401 unibyte and Latin-1 in .emacs. -- Dave Love */
1402 if (argmatch (argv, argc, "-unibyte", "--unibyte", 4, NULL, &skip_args)
1403 || argmatch (argv, argc, "-no-multibyte", "--no-multibyte", 4, NULL, &skip_args)
1404 || (getenv ("EMACS_UNIBYTE") && !inhibit_unibyte))
1406 Lisp_Object old_log_max;
1407 Lisp_Object symbol, tail;
1409 symbol = intern_c_string ("enable-multibyte-characters");
1410 Fset_default (symbol, Qnil);
1412 if (initialized)
1414 /* Erase pre-dump messages in *Messages* now so no abort. */
1415 old_log_max = Vmessage_log_max;
1416 XSETFASTINT (Vmessage_log_max, 0);
1417 message_dolog ("", 0, 1, 0);
1418 Vmessage_log_max = old_log_max;
1421 for (tail = Vbuffer_alist; CONSP (tail);
1422 tail = XCDR (tail))
1424 Lisp_Object buffer;
1426 buffer = Fcdr (XCAR (tail));
1427 /* Make a multibyte buffer unibyte. */
1428 if (BUF_Z_BYTE (XBUFFER (buffer)) > BUF_Z (XBUFFER (buffer)))
1430 struct buffer *current = current_buffer;
1432 set_buffer_temp (XBUFFER (buffer));
1433 Fset_buffer_multibyte (Qnil);
1434 set_buffer_temp (current);
1437 message ("Warning: unibyte sessions are obsolete and will disappear");
1441 no_loadup
1442 = argmatch (argv, argc, "-nl", "--no-loadup", 6, NULL, &skip_args);
1444 #ifdef HAVE_NS
1445 ns_alloc_autorelease_pool();
1446 if (!noninteractive)
1448 #ifdef NS_IMPL_COCOA
1449 if (skip_args < argc)
1451 if (!strncmp(argv[skip_args], "-psn", 4))
1453 skip_args += 1;
1454 chdir (getenv ("HOME"));
1456 else if (skip_args+1 < argc && !strncmp(argv[skip_args+1], "-psn", 4))
1458 skip_args += 2;
1459 chdir (getenv ("HOME"));
1462 #endif /* COCOA */
1464 #endif /* HAVE_NS */
1466 #ifdef HAVE_X_WINDOWS
1467 /* Stupid kludge to catch command-line display spec. We can't
1468 handle this argument entirely in window system dependent code
1469 because we don't even know which window system dependent code
1470 to run until we've recognized this argument. */
1472 char *displayname = 0;
1473 int count_before = skip_args;
1475 /* Skip any number of -d options, but only use the last one. */
1476 while (1)
1478 int count_before_this = skip_args;
1480 if (argmatch (argv, argc, "-d", "--display", 3, &displayname, &skip_args))
1481 display_arg = 1;
1482 else if (argmatch (argv, argc, "-display", 0, 3, &displayname, &skip_args))
1483 display_arg = 1;
1484 else
1485 break;
1487 count_before = count_before_this;
1490 /* If we have the form --display=NAME,
1491 convert it into -d name.
1492 This requires inserting a new element into argv. */
1493 if (displayname != 0 && skip_args - count_before == 1)
1495 char **new = (char **) xmalloc (sizeof (char *) * (argc + 2));
1496 int j;
1498 for (j = 0; j < count_before + 1; j++)
1499 new[j] = argv[j];
1500 new[count_before + 1] = "-d";
1501 new[count_before + 2] = displayname;
1502 for (j = count_before + 2; j <argc; j++)
1503 new[j + 1] = argv[j];
1504 argv = new;
1505 argc++;
1507 /* Change --display to -d, when its arg is separate. */
1508 else if (displayname != 0 && skip_args > count_before
1509 && argv[count_before + 1][1] == '-')
1510 argv[count_before + 1] = "-d";
1512 /* Don't actually discard this arg. */
1513 skip_args = count_before;
1515 #endif
1517 /* argmatch must not be used after here,
1518 except when bulding temacs
1519 because the -d argument has not been skipped in skip_args. */
1521 #ifdef MSDOS
1522 /* Call early 'cause init_environment needs it. */
1523 init_dosfns ();
1524 /* Set defaults for several environment variables. */
1525 if (initialized)
1526 init_environment (argc, argv, skip_args);
1527 else
1528 tzset ();
1529 #endif /* MSDOS */
1531 #ifdef WINDOWSNT
1532 globals_of_w32 ();
1533 /* Initialize environment from registry settings. */
1534 init_environment (argv);
1535 init_ntproc (); /* must precede init_editfns. */
1536 #endif
1538 #ifdef HAVE_NS
1539 #ifndef CANNOT_DUMP
1540 if (initialized)
1541 #endif
1542 ns_init_paths ();
1543 #endif
1545 /* egetenv is a pretty low-level facility, which may get called in
1546 many circumstances; it seems flimsy to put off initializing it
1547 until calling init_callproc. */
1548 set_initial_environment ();
1549 /* AIX crashes are reported in system versions 3.2.3 and 3.2.4
1550 if this is not done. Do it after set_global_environment so that we
1551 don't pollute Vglobal_environment. */
1552 /* Setting LANG here will defeat the startup locale processing... */
1553 #ifdef AIX
1554 putenv ("LANG=C");
1555 #endif
1557 init_buffer (); /* Init default directory of main buffer. */
1559 init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */
1560 init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */
1562 if (initialized)
1564 /* Erase any pre-dump messages in the message log, to avoid confusion. */
1565 Lisp_Object old_log_max;
1566 old_log_max = Vmessage_log_max;
1567 XSETFASTINT (Vmessage_log_max, 0);
1568 message_dolog ("", 0, 1, 0);
1569 Vmessage_log_max = old_log_max;
1572 init_callproc (); /* Must follow init_cmdargs but not init_sys_modes. */
1573 init_lread ();
1575 /* Intern the names of all standard functions and variables;
1576 define standard keys. */
1578 if (!initialized)
1580 /* The basic levels of Lisp must come first. Note that
1581 syms_of_data and some others have already been called. */
1582 syms_of_chartab ();
1583 syms_of_lread ();
1584 syms_of_print ();
1585 syms_of_eval ();
1586 syms_of_fns ();
1587 syms_of_floatfns ();
1589 syms_of_buffer ();
1590 syms_of_bytecode ();
1591 syms_of_callint ();
1592 syms_of_casefiddle ();
1593 syms_of_casetab ();
1594 syms_of_callproc ();
1595 syms_of_category ();
1596 syms_of_ccl ();
1597 syms_of_character ();
1598 syms_of_cmds ();
1599 #ifndef NO_DIR_LIBRARY
1600 syms_of_dired ();
1601 #endif /* not NO_DIR_LIBRARY */
1602 syms_of_display ();
1603 syms_of_doc ();
1604 syms_of_editfns ();
1605 syms_of_emacs ();
1606 #ifdef CLASH_DETECTION
1607 syms_of_filelock ();
1608 #endif /* CLASH_DETECTION */
1609 syms_of_indent ();
1610 syms_of_insdel ();
1611 /* syms_of_keymap (); */
1612 syms_of_macros ();
1613 syms_of_marker ();
1614 syms_of_minibuf ();
1615 syms_of_process ();
1616 syms_of_search ();
1617 syms_of_frame ();
1618 syms_of_syntax ();
1619 syms_of_terminal ();
1620 syms_of_term ();
1621 syms_of_undo ();
1622 #ifdef HAVE_SOUND
1623 syms_of_sound ();
1624 #endif
1625 syms_of_textprop ();
1626 syms_of_composite ();
1627 #ifdef WINDOWSNT
1628 syms_of_ntproc ();
1629 #endif /* WINDOWSNT */
1630 syms_of_window ();
1631 syms_of_xdisp ();
1632 syms_of_font ();
1633 #ifdef HAVE_WINDOW_SYSTEM
1634 syms_of_fringe ();
1635 syms_of_image ();
1636 #endif /* HAVE_WINDOW_SYSTEM */
1637 #ifdef HAVE_X_WINDOWS
1638 syms_of_xterm ();
1639 syms_of_xfns ();
1640 syms_of_xmenu ();
1641 syms_of_fontset ();
1642 syms_of_xsettings ();
1643 #ifdef HAVE_X_SM
1644 syms_of_xsmfns ();
1645 #endif
1646 #ifdef HAVE_X11
1647 syms_of_xselect ();
1648 #endif
1649 #endif /* HAVE_X_WINDOWS */
1651 syms_of_menu ();
1653 #ifdef HAVE_NTGUI
1654 syms_of_w32term ();
1655 syms_of_w32fns ();
1656 syms_of_w32select ();
1657 syms_of_w32menu ();
1658 syms_of_fontset ();
1659 #endif /* HAVE_NTGUI */
1661 #ifdef MSDOS
1662 syms_of_xmenu ();
1663 #endif /* MSDOS */
1665 #ifdef HAVE_NS
1666 syms_of_nsterm ();
1667 syms_of_nsfns ();
1668 syms_of_nsmenu ();
1669 syms_of_nsselect ();
1670 syms_of_fontset ();
1671 #endif /* HAVE_NS */
1673 #ifdef HAVE_DBUS
1674 syms_of_dbusbind ();
1675 #endif /* HAVE_DBUS */
1677 #ifdef SYMS_SYSTEM
1678 SYMS_SYSTEM;
1679 #endif
1681 #ifdef SYMS_MACHINE
1682 SYMS_MACHINE;
1683 #endif
1685 keys_of_casefiddle ();
1686 keys_of_cmds ();
1687 keys_of_buffer ();
1688 keys_of_keyboard ();
1689 keys_of_keymap ();
1690 keys_of_window ();
1692 else
1694 /* Initialization that must be done even if the global variable
1695 initialized is non zero. */
1696 #ifdef HAVE_NTGUI
1697 globals_of_w32fns ();
1698 globals_of_w32menu ();
1699 globals_of_w32select ();
1700 #endif /* HAVE_NTGUI */
1703 init_charset ();
1705 init_editfns (); /* init_process uses Voperating_system_release. */
1706 init_process (); /* init_display uses add_keyboard_wait_descriptor. */
1707 init_keyboard (); /* This too must precede init_sys_modes. */
1708 if (!noninteractive)
1709 init_display (); /* Determine terminal type. Calls init_sys_modes. */
1710 init_fns ();
1711 init_xdisp ();
1712 #ifdef HAVE_WINDOW_SYSTEM
1713 init_fringe ();
1714 init_image ();
1715 #endif /* HAVE_WINDOW_SYSTEM */
1716 init_macros ();
1717 init_floatfns ();
1718 #ifdef HAVE_SOUND
1719 init_sound ();
1720 #endif
1721 init_window ();
1722 init_font ();
1724 if (!initialized)
1726 char *file;
1727 /* Handle -l loadup, args passed by Makefile. */
1728 if (argmatch (argv, argc, "-l", "--load", 3, &file, &skip_args))
1729 Vtop_level = Fcons (intern_c_string ("load"),
1730 Fcons (build_string (file), Qnil));
1731 /* Unless next switch is -nl, load "loadup.el" first thing. */
1732 if (! no_loadup)
1733 Vtop_level = Fcons (intern_c_string ("load"),
1734 Fcons (build_string ("loadup.el"), Qnil));
1737 if (initialized)
1739 #ifdef HAVE_TZSET
1741 /* If the execution TZ happens to be the same as the dump TZ,
1742 change it to some other value and then change it back,
1743 to force the underlying implementation to reload the TZ info.
1744 This is needed on implementations that load TZ info from files,
1745 since the TZ file contents may differ between dump and execution. */
1746 char *tz = getenv ("TZ");
1747 if (tz && !strcmp (tz, dump_tz))
1749 ++*tz;
1750 tzset ();
1751 --*tz;
1754 #endif
1757 /* Set up for profiling. This is known to work on FreeBSD,
1758 GNU/Linux and MinGW. It might work on some other systems too.
1759 Give it a try and tell us if it works on your system. To compile
1760 for profiling, use the configure option --enable-profiling. */
1761 #if defined (__FreeBSD__) || defined (GNU_LINUX) || defined(__MINGW32__)
1762 #ifdef PROFILING
1763 if (initialized)
1765 extern void _mcleanup ();
1766 #ifdef __MINGW32__
1767 extern unsigned char etext asm ("etext");
1768 #else
1769 extern char etext;
1770 #endif
1771 extern void safe_bcopy ();
1772 extern void dump_opcode_frequencies ();
1774 atexit (_mcleanup);
1775 /* This uses safe_bcopy because that function comes first in the
1776 Emacs executable. It might be better to use something that
1777 gives the start of the text segment, but start_of_text is not
1778 defined on all systems now. */
1779 monstartup (safe_bcopy, &etext);
1781 else
1782 moncontrol (0);
1783 #endif
1784 #endif
1786 initialized = 1;
1788 #ifdef LOCALTIME_CACHE
1789 /* Some versions of localtime have a bug. They cache the value of the time
1790 zone rather than looking it up every time. Since localtime() is
1791 called to bolt the undumping time into the undumped emacs, this
1792 results in localtime ignoring the TZ environment variable.
1793 This flushes the new TZ value into localtime. */
1794 tzset ();
1795 #endif /* defined (LOCALTIME_CACHE) */
1797 /* Enter editor command loop. This never returns. */
1798 Frecursive_edit ();
1799 /* NOTREACHED */
1800 return 0;
1803 /* Sort the args so we can find the most important ones
1804 at the beginning of argv. */
1806 /* First, here's a table of all the standard options. */
1808 struct standard_args
1810 const char *name;
1811 const char *longname;
1812 int priority;
1813 int nargs;
1816 const struct standard_args standard_args[] =
1818 { "-version", "--version", 150, 0 },
1819 { "-t", "--terminal", 120, 1 },
1820 { "-nw", "--no-window-system", 110, 0 },
1821 { "-nw", "--no-windows", 110, 0 },
1822 { "-batch", "--batch", 100, 0 },
1823 { "-script", "--script", 100, 1 },
1824 { "-daemon", "--daemon", 99, 0 },
1825 { "-help", "--help", 90, 0 },
1826 { "-no-unibyte", "--no-unibyte", 83, 0 },
1827 { "-multibyte", "--multibyte", 82, 0 },
1828 { "-unibyte", "--unibyte", 81, 0 },
1829 { "-no-multibyte", "--no-multibyte", 80, 0 },
1830 { "-nl", "--no-loadup", 70, 0 },
1831 /* -d must come last before the options handled in startup.el. */
1832 { "-d", "--display", 60, 1 },
1833 { "-display", 0, 60, 1 },
1834 /* Now for the options handled in `command-line' (startup.el). */
1835 { "-Q", "--quick", 55, 0 },
1836 { "-quick", 0, 55, 0 },
1837 { "-q", "--no-init-file", 50, 0 },
1838 { "-no-init-file", 0, 50, 0 },
1839 { "-no-site-file", "--no-site-file", 40, 0 },
1840 { "-u", "--user", 30, 1 },
1841 { "-user", 0, 30, 1 },
1842 { "-debug-init", "--debug-init", 20, 0 },
1843 { "-iconic", "--iconic", 15, 0 },
1844 { "-D", "--basic-display", 12, 0},
1845 { "-basic-display", 0, 12, 0},
1846 { "-nbc", "--no-blinking-cursor", 12, 0 },
1847 /* Now for the options handled in `command-line-1' (startup.el). */
1848 { "-nbi", "--no-bitmap-icon", 10, 0 },
1849 { "-bg", "--background-color", 10, 1 },
1850 { "-background", 0, 10, 1 },
1851 { "-fg", "--foreground-color", 10, 1 },
1852 { "-foreground", 0, 10, 1 },
1853 { "-bd", "--border-color", 10, 1 },
1854 { "-bw", "--border-width", 10, 1 },
1855 { "-ib", "--internal-border", 10, 1 },
1856 { "-ms", "--mouse-color", 10, 1 },
1857 { "-cr", "--cursor-color", 10, 1 },
1858 { "-fn", "--font", 10, 1 },
1859 { "-font", 0, 10, 1 },
1860 { "-fs", "--fullscreen", 10, 0 },
1861 { "-fw", "--fullwidth", 10, 0 },
1862 { "-fh", "--fullheight", 10, 0 },
1863 { "-mm", "--maximized", 10, 0 },
1864 { "-g", "--geometry", 10, 1 },
1865 { "-geometry", 0, 10, 1 },
1866 { "-T", "--title", 10, 1 },
1867 { "-title", 0, 10, 1 },
1868 { "-name", "--name", 10, 1 },
1869 { "-xrm", "--xrm", 10, 1 },
1870 { "-parent-id", "--parent-id", 10, 1 },
1871 { "-r", "--reverse-video", 5, 0 },
1872 { "-rv", 0, 5, 0 },
1873 { "-reverse", 0, 5, 0 },
1874 { "-hb", "--horizontal-scroll-bars", 5, 0 },
1875 { "-vb", "--vertical-scroll-bars", 5, 0 },
1876 { "-color", "--color", 5, 0},
1877 { "-no-splash", "--no-splash", 3, 0 },
1878 { "-no-desktop", "--no-desktop", 3, 0 },
1879 #ifdef HAVE_NS
1880 { "-NSAutoLaunch", 0, 5, 1 },
1881 { "-NXAutoLaunch", 0, 5, 1 },
1882 { "-disable-font-backend", "--disable-font-backend", 65, 0 },
1883 { "-_NSMachLaunch", 0, 85, 1 },
1884 { "-MachLaunch", 0, 85, 1 },
1885 { "-macosx", 0, 85, 0 },
1886 { "-NSHost", 0, 85, 1 },
1887 #endif
1888 /* These have the same priority as ordinary file name args,
1889 so they are not reordered with respect to those. */
1890 { "-L", "--directory", 0, 1 },
1891 { "-directory", 0, 0, 1 },
1892 { "-l", "--load", 0, 1 },
1893 { "-load", 0, 0, 1 },
1894 /* This has no longname, because using --scriptload confuses sort_args,
1895 because then the --script long option seems to match twice; ie
1896 you can't have a long option which is a prefix of another long
1897 option. In any case, this is entirely an internal option. */
1898 { "-scriptload", NULL, 0, 1 },
1899 { "-f", "--funcall", 0, 1 },
1900 { "-funcall", 0, 0, 1 },
1901 { "-eval", "--eval", 0, 1 },
1902 { "-execute", "--execute", 0, 1 },
1903 { "-find-file", "--find-file", 0, 1 },
1904 { "-visit", "--visit", 0, 1 },
1905 { "-file", "--file", 0, 1 },
1906 { "-insert", "--insert", 0, 1 },
1907 #ifdef HAVE_NS
1908 { "-NXOpen", 0, 0, 1 },
1909 { "-NXOpenTemp", 0, 0, 1 },
1910 { "-NSOpen", 0, 0, 1 },
1911 { "-NSOpenTemp", 0, 0, 1 },
1912 { "-GSFilePath", 0, 0, 1 },
1913 #endif
1914 /* This should be processed after ordinary file name args and the like. */
1915 { "-kill", "--kill", -10, 0 },
1918 /* Reorder the elements of ARGV (assumed to have ARGC elements)
1919 so that the highest priority ones come first.
1920 Do not change the order of elements of equal priority.
1921 If an option takes an argument, keep it and its argument together.
1923 If an option that takes no argument appears more
1924 than once, eliminate all but one copy of it. */
1926 static void
1927 sort_args (argc, argv)
1928 int argc;
1929 char **argv;
1931 char **new = (char **) xmalloc (sizeof (char *) * argc);
1932 /* For each element of argv,
1933 the corresponding element of options is:
1934 0 for an option that takes no arguments,
1935 1 for an option that takes one argument, etc.
1936 -1 for an ordinary non-option argument. */
1937 int *options = (int *) xmalloc (sizeof (int) * argc);
1938 int *priority = (int *) xmalloc (sizeof (int) * argc);
1939 int to = 1;
1940 int incoming_used = 1;
1941 int from;
1942 int i;
1944 /* Categorize all the options,
1945 and figure out which argv elts are option arguments. */
1946 for (from = 1; from < argc; from++)
1948 options[from] = -1;
1949 priority[from] = 0;
1950 if (argv[from][0] == '-')
1952 int match, thislen;
1953 char *equals;
1955 /* If we have found "--", don't consider
1956 any more arguments as options. */
1957 if (argv[from][1] == '-' && argv[from][2] == 0)
1959 /* Leave the "--", and everything following it, at the end. */
1960 for (; from < argc; from++)
1962 priority[from] = -100;
1963 options[from] = -1;
1965 break;
1968 /* Look for a match with a known old-fashioned option. */
1969 for (i = 0; i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1970 if (!strcmp (argv[from], standard_args[i].name))
1972 options[from] = standard_args[i].nargs;
1973 priority[from] = standard_args[i].priority;
1974 if (from + standard_args[i].nargs >= argc)
1975 fatal ("Option `%s' requires an argument\n", argv[from]);
1976 from += standard_args[i].nargs;
1977 goto done;
1980 /* Look for a match with a known long option.
1981 MATCH is -1 if no match so far, -2 if two or more matches so far,
1982 >= 0 (the table index of the match) if just one match so far. */
1983 if (argv[from][1] == '-')
1985 match = -1;
1986 thislen = strlen (argv[from]);
1987 equals = index (argv[from], '=');
1988 if (equals != 0)
1989 thislen = equals - argv[from];
1991 for (i = 0;
1992 i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1993 if (standard_args[i].longname
1994 && !strncmp (argv[from], standard_args[i].longname,
1995 thislen))
1997 if (match == -1)
1998 match = i;
1999 else
2000 match = -2;
2003 /* If we found exactly one match, use that. */
2004 if (match >= 0)
2006 options[from] = standard_args[match].nargs;
2007 priority[from] = standard_args[match].priority;
2008 /* If --OPTION=VALUE syntax is used,
2009 this option uses just one argv element. */
2010 if (equals != 0)
2011 options[from] = 0;
2012 if (from + options[from] >= argc)
2013 fatal ("Option `%s' requires an argument\n", argv[from]);
2014 from += options[from];
2016 /* FIXME When match < 0, shouldn't there be some error,
2017 or at least indication to the user that there was a
2018 problem? */
2020 done: ;
2024 /* Copy the arguments, in order of decreasing priority, to NEW. */
2025 new[0] = argv[0];
2026 while (incoming_used < argc)
2028 int best = -1;
2029 int best_priority = -9999;
2031 /* Find the highest priority remaining option.
2032 If several have equal priority, take the first of them. */
2033 for (from = 1; from < argc; from++)
2035 if (argv[from] != 0 && priority[from] > best_priority)
2037 best_priority = priority[from];
2038 best = from;
2040 /* Skip option arguments--they are tied to the options. */
2041 if (options[from] > 0)
2042 from += options[from];
2045 if (best < 0)
2046 abort ();
2048 /* Copy the highest priority remaining option, with its args, to NEW.
2049 Unless it is a duplicate of the previous one. */
2050 if (! (options[best] == 0
2051 && ! strcmp (new[to - 1], argv[best])))
2053 new[to++] = argv[best];
2054 for (i = 0; i < options[best]; i++)
2055 new[to++] = argv[best + i + 1];
2058 incoming_used += 1 + (options[best] > 0 ? options[best] : 0);
2060 /* Clear out this option in ARGV. */
2061 argv[best] = 0;
2062 for (i = 0; i < options[best]; i++)
2063 argv[best + i + 1] = 0;
2066 /* If duplicate options were deleted, fill up extra space with null ptrs. */
2067 while (to < argc)
2068 new[to++] = 0;
2070 bcopy (new, argv, sizeof (char *) * argc);
2072 xfree (options);
2073 xfree (new);
2074 xfree (priority);
2077 DEFUN ("kill-emacs", Fkill_emacs, Skill_emacs, 0, 1, "P",
2078 doc: /* Exit the Emacs job and kill it.
2079 If ARG is an integer, return ARG as the exit program code.
2080 If ARG is a string, stuff it as keyboard input.
2082 The value of `kill-emacs-hook', if not void,
2083 is a list of functions (of no args),
2084 all of which are called before Emacs is actually killed. */)
2085 (arg)
2086 Lisp_Object arg;
2088 struct gcpro gcpro1;
2090 GCPRO1 (arg);
2092 if (feof (stdin))
2093 arg = Qt;
2095 if (!NILP (Vrun_hooks) && !noninteractive)
2096 call1 (Vrun_hooks, intern ("kill-emacs-hook"));
2098 UNGCPRO;
2100 shut_down_emacs (0, 0, STRINGP (arg) ? arg : Qnil);
2102 /* If we have an auto-save list file,
2103 kill it because we are exiting Emacs deliberately (not crashing).
2104 Do it after shut_down_emacs, which does an auto-save. */
2105 if (STRINGP (Vauto_save_list_file_name))
2106 unlink (SDATA (Vauto_save_list_file_name));
2108 exit (INTEGERP (arg) ? XINT (arg) : EXIT_SUCCESS);
2109 /* NOTREACHED */
2110 return Qnil;
2114 /* Perform an orderly shutdown of Emacs. Autosave any modified
2115 buffers, kill any child processes, clean up the terminal modes (if
2116 we're in the foreground), and other stuff like that. Don't perform
2117 any redisplay; this may be called when Emacs is shutting down in
2118 the background, or after its X connection has died.
2120 If SIG is a signal number, print a message for it.
2122 This is called by fatal signal handlers, X protocol error handlers,
2123 and Fkill_emacs. */
2125 void
2126 shut_down_emacs (sig, no_x, stuff)
2127 int sig, no_x;
2128 Lisp_Object stuff;
2130 /* Prevent running of hooks from now on. */
2131 Vrun_hooks = Qnil;
2133 /* Don't update display from now on. */
2134 Vinhibit_redisplay = Qt;
2136 /* If we are controlling the terminal, reset terminal modes. */
2137 #ifdef EMACS_HAVE_TTY_PGRP
2139 int pgrp = EMACS_GETPGRP (0);
2141 int tpgrp;
2142 if (EMACS_GET_TTY_PGRP (0, &tpgrp) != -1
2143 && tpgrp == pgrp)
2145 reset_all_sys_modes ();
2146 if (sig && sig != SIGTERM)
2147 fprintf (stderr, "Fatal error (%d)", sig);
2150 #else
2151 fflush (stdout);
2152 reset_all_sys_modes ();
2153 #endif
2155 stuff_buffered_input (stuff);
2157 #ifdef subprocesses
2158 inhibit_sentinels = 1;
2159 #endif
2160 kill_buffer_processes (Qnil);
2161 Fdo_auto_save (Qt, Qnil);
2163 #ifdef CLASH_DETECTION
2164 unlock_all_files ();
2165 #endif
2167 #if 0 /* This triggers a bug in XCloseDisplay and is not needed. */
2168 #ifdef HAVE_X_WINDOWS
2169 /* It's not safe to call intern here. Maybe we are crashing. */
2170 if (!noninteractive && SYMBOLP (Vinitial_window_system)
2171 && SCHARS (SYMBOL_NAME (Vinitial_window_system)) == 1
2172 && SREF (SYMBOL_NAME (Vinitial_window_system), 0) == 'x'
2173 && ! no_x)
2174 Fx_close_current_connection ();
2175 #endif /* HAVE_X_WINDOWS */
2176 #endif
2178 #ifdef SIGIO
2179 /* There is a tendency for a SIGIO signal to arrive within exit,
2180 and cause a SIGHUP because the input descriptor is already closed. */
2181 unrequest_sigio ();
2182 signal (SIGIO, SIG_IGN);
2183 #endif
2185 #ifdef WINDOWSNT
2186 term_ntproc ();
2187 #endif
2189 /* Do this only if terminating normally, we want glyph matrices
2190 etc. in a core dump. */
2191 if (sig == 0 || sig == SIGTERM)
2193 check_glyph_memory ();
2194 check_message_stack ();
2197 #ifdef MSDOS
2198 dos_cleanup ();
2199 #endif
2201 #ifdef HAVE_NS
2202 ns_term_shutdown (sig);
2203 #endif
2208 #ifndef CANNOT_DUMP
2210 DEFUN ("dump-emacs", Fdump_emacs, Sdump_emacs, 2, 2, 0,
2211 doc: /* Dump current state of Emacs into executable file FILENAME.
2212 Take symbols from SYMFILE (presumably the file you executed to run Emacs).
2213 This is used in the file `loadup.el' when building Emacs.
2215 You must run Emacs in batch mode in order to dump it. */)
2216 (filename, symfile)
2217 Lisp_Object filename, symfile;
2219 extern char my_edata[];
2220 Lisp_Object tem;
2221 Lisp_Object symbol;
2222 int count = SPECPDL_INDEX ();
2224 check_pure_size ();
2226 if (! noninteractive)
2227 error ("Dumping Emacs works only in batch mode");
2229 #ifdef GNU_LINUX
2230 if (heap_bss_diff > MAX_HEAP_BSS_DIFF)
2232 fprintf (stderr, "**************************************************\n");
2233 fprintf (stderr, "Warning: Your system has a gap between BSS and the\n");
2234 fprintf (stderr, "heap (%lu bytes). This usually means that exec-shield\n",
2235 heap_bss_diff);
2236 fprintf (stderr, "or something similar is in effect. The dump may\n");
2237 fprintf (stderr, "fail because of this. See the section about\n");
2238 fprintf (stderr, "exec-shield in etc/PROBLEMS for more information.\n");
2239 fprintf (stderr, "**************************************************\n");
2241 #endif /* GNU_LINUX */
2243 /* Bind `command-line-processed' to nil before dumping,
2244 so that the dumped Emacs will process its command line
2245 and set up to work with X windows if appropriate. */
2246 symbol = intern ("command-line-processed");
2247 specbind (symbol, Qnil);
2249 CHECK_STRING (filename);
2250 filename = Fexpand_file_name (filename, Qnil);
2251 if (!NILP (symfile))
2253 CHECK_STRING (symfile);
2254 if (SCHARS (symfile))
2255 symfile = Fexpand_file_name (symfile, Qnil);
2258 tem = Vpurify_flag;
2259 Vpurify_flag = Qnil;
2261 #ifdef HAVE_TZSET
2262 set_time_zone_rule (dump_tz);
2263 #ifndef LOCALTIME_CACHE
2264 /* Force a tz reload, since set_time_zone_rule doesn't. */
2265 tzset ();
2266 #endif
2267 #endif
2269 fflush (stdout);
2270 /* Tell malloc where start of impure now is. */
2271 /* Also arrange for warnings when nearly out of space. */
2272 #ifndef SYSTEM_MALLOC
2273 #ifndef WINDOWSNT
2274 /* On Windows, this was done before dumping, and that once suffices.
2275 Meanwhile, my_edata is not valid on Windows. */
2276 memory_warnings (my_edata, malloc_warning);
2277 #endif /* not WINDOWSNT */
2278 #endif
2279 #if !defined (SYSTEM_MALLOC) && defined (HAVE_GTK_AND_PTHREAD) && !defined SYNC_INPUT
2280 /* Pthread may call malloc before main, and then we will get an endless
2281 loop, because pthread_self (see alloc.c) calls malloc the first time
2282 it is called on some systems. */
2283 reset_malloc_hooks ();
2284 #endif
2285 #ifdef DOUG_LEA_MALLOC
2286 malloc_state_ptr = malloc_get_state ();
2287 #endif
2289 #ifdef USE_MMAP_FOR_BUFFERS
2290 mmap_set_vars (0);
2291 #endif
2292 unexec (SDATA (filename),
2293 !NILP (symfile) ? SDATA (symfile) : 0, my_edata, 0, 0);
2294 #ifdef USE_MMAP_FOR_BUFFERS
2295 mmap_set_vars (1);
2296 #endif
2297 #ifdef DOUG_LEA_MALLOC
2298 free (malloc_state_ptr);
2299 #endif
2301 Vpurify_flag = tem;
2303 return unbind_to (count, Qnil);
2306 #endif /* not CANNOT_DUMP */
2308 #if HAVE_SETLOCALE
2309 /* Recover from setlocale (LC_ALL, ""). */
2310 void
2311 fixup_locale ()
2313 /* The Emacs Lisp reader needs LC_NUMERIC to be "C",
2314 so that numbers are read and printed properly for Emacs Lisp. */
2315 setlocale (LC_NUMERIC, "C");
2318 /* Set system locale CATEGORY, with previous locale *PLOCALE, to
2319 DESIRED_LOCALE. */
2320 static void
2321 synchronize_locale (category, plocale, desired_locale)
2322 int category;
2323 Lisp_Object *plocale;
2324 Lisp_Object desired_locale;
2326 if (! EQ (*plocale, desired_locale))
2328 *plocale = desired_locale;
2329 setlocale (category, (STRINGP (desired_locale)
2330 ? (char *) SDATA (desired_locale)
2331 : ""));
2335 /* Set system time locale to match Vsystem_time_locale, if possible. */
2336 void
2337 synchronize_system_time_locale ()
2339 synchronize_locale (LC_TIME, &Vprevious_system_time_locale,
2340 Vsystem_time_locale);
2343 /* Set system messages locale to match Vsystem_messages_locale, if
2344 possible. */
2345 void
2346 synchronize_system_messages_locale ()
2348 #ifdef LC_MESSAGES
2349 synchronize_locale (LC_MESSAGES, &Vprevious_system_messages_locale,
2350 Vsystem_messages_locale);
2351 #endif
2353 #endif /* HAVE_SETLOCALE */
2355 #ifndef SEPCHAR
2356 #define SEPCHAR ':'
2357 #endif
2359 Lisp_Object
2360 decode_env_path (evarname, defalt)
2361 char *evarname, *defalt;
2363 register char *path, *p;
2364 Lisp_Object lpath, element, tem;
2366 /* It's okay to use getenv here, because this function is only used
2367 to initialize variables when Emacs starts up, and isn't called
2368 after that. */
2369 if (evarname != 0)
2370 path = (char *) getenv (evarname);
2371 else
2372 path = 0;
2373 if (!path)
2374 path = defalt;
2375 #ifdef DOS_NT
2376 /* Ensure values from the environment use the proper directory separator. */
2377 if (path)
2379 p = alloca (strlen (path) + 1);
2380 strcpy (p, path);
2381 path = p;
2383 if ('/' == DIRECTORY_SEP)
2384 dostounix_filename (path);
2385 else
2386 unixtodos_filename (path);
2388 #endif
2389 lpath = Qnil;
2390 while (1)
2392 p = index (path, SEPCHAR);
2393 if (!p) p = path + strlen (path);
2394 element = (p - path ? make_string (path, p - path)
2395 : build_string ("."));
2397 /* Add /: to the front of the name
2398 if it would otherwise be treated as magic. */
2399 tem = Ffind_file_name_handler (element, Qt);
2401 /* However, if the handler says "I'm safe",
2402 don't bother adding /:. */
2403 if (SYMBOLP (tem))
2405 Lisp_Object prop;
2406 prop = Fget (tem, intern ("safe-magic"));
2407 if (! NILP (prop))
2408 tem = Qnil;
2411 if (! NILP (tem))
2412 element = concat2 (build_string ("/:"), element);
2414 lpath = Fcons (element, lpath);
2415 if (*p)
2416 path = p + 1;
2417 else
2418 break;
2420 return Fnreverse (lpath);
2423 DEFUN ("daemonp", Fdaemonp, Sdaemonp, 0, 0, 0,
2424 doc: /* Return non-nil if the current emacs process is a daemon.
2425 If the daemon was given a name argument, return that name. */)
2428 if (IS_DAEMON)
2429 if (daemon_name)
2430 return build_string (daemon_name);
2431 else
2432 return Qt;
2433 else
2434 return Qnil;
2437 DEFUN ("daemon-initialized", Fdaemon_initialized, Sdaemon_initialized, 0, 0, 0,
2438 doc: /* Mark the Emacs daemon as being initialized.
2439 This finishes the daemonization process by doing the other half of detaching
2440 from the parent process and its tty file descriptors. */)
2443 int nfd;
2445 if (!IS_DAEMON)
2446 error ("This function can only be called if emacs is run as a daemon");
2448 if (daemon_pipe[1] < 0)
2449 error ("The daemon has already been initialized");
2451 if (NILP (Vafter_init_time))
2452 error ("This function can only be called after loading the init files");
2454 /* Get rid of stdin, stdout and stderr. */
2455 nfd = open ("/dev/null", O_RDWR);
2456 dup2 (nfd, 0);
2457 dup2 (nfd, 1);
2458 dup2 (nfd, 2);
2459 close (nfd);
2461 /* Closing the pipe will notify the parent that it can exit.
2462 FIXME: In case some other process inherited the pipe, closing it here
2463 won't notify the parent because it's still open elsewhere, so we
2464 additionally send a byte, just to make sure the parent really exits.
2465 Instead, we should probably close the pipe in start-process and
2466 call-process to make sure the pipe is never inherited by
2467 subprocesses. */
2468 write (daemon_pipe[1], "\n", 1);
2469 close (daemon_pipe[1]);
2470 /* Set it to an invalid value so we know we've already run this function. */
2471 daemon_pipe[1] = -1;
2472 return Qt;
2475 void
2476 syms_of_emacs ()
2478 Qfile_name_handler_alist = intern_c_string ("file-name-handler-alist");
2479 staticpro (&Qfile_name_handler_alist);
2481 #ifndef CANNOT_DUMP
2482 defsubr (&Sdump_emacs);
2483 #endif
2485 defsubr (&Skill_emacs);
2487 defsubr (&Sinvocation_name);
2488 defsubr (&Sinvocation_directory);
2489 defsubr (&Sdaemonp);
2490 defsubr (&Sdaemon_initialized);
2492 DEFVAR_LISP ("command-line-args", &Vcommand_line_args,
2493 doc: /* Args passed by shell to Emacs, as a list of strings.
2494 Many arguments are deleted from the list as they are processed. */);
2496 DEFVAR_LISP ("system-type", &Vsystem_type,
2497 doc: /* The value is a symbol indicating the type of operating system you are using.
2498 Special values:
2499 `gnu' compiled for a GNU Hurd system.
2500 `gnu/linux' compiled for a GNU/Linux system.
2501 `gnu/kfreebsd' compiled for a GNU system with a FreeBSD kernel.
2502 `darwin' compiled for Darwin (GNU-Darwin, Mac OS X, ...).
2503 `ms-dos' compiled as an MS-DOS application.
2504 `windows-nt' compiled as a native W32 application.
2505 `cygwin' compiled using the Cygwin library.
2506 Anything else (in Emacs 23.1, the possibilities are: aix, berkeley-unix,
2507 hpux, irix, lynxos 3.0.1, usg-unix-v) indicates some sort of Unix system. */);
2508 Vsystem_type = intern_c_string (SYSTEM_TYPE);
2510 DEFVAR_LISP ("system-configuration", &Vsystem_configuration,
2511 doc: /* Value is string indicating configuration Emacs was built for.
2512 On MS-Windows, the value reflects the OS flavor and version on which
2513 Emacs is running. */);
2514 Vsystem_configuration = build_string (EMACS_CONFIGURATION);
2516 DEFVAR_LISP ("system-configuration-options", &Vsystem_configuration_options,
2517 doc: /* String containing the configuration options Emacs was built with. */);
2518 Vsystem_configuration_options = build_string (EMACS_CONFIG_OPTIONS);
2520 DEFVAR_BOOL ("noninteractive", &noninteractive1,
2521 doc: /* Non-nil means Emacs is running without interactive terminal. */);
2523 DEFVAR_LISP ("kill-emacs-hook", &Vkill_emacs_hook,
2524 doc: /* Hook to be run when `kill-emacs' is called.
2525 Since `kill-emacs' may be invoked when the terminal is disconnected (or
2526 in other similar situations), functions placed on this hook should not
2527 expect to be able to interact with the user. To ask for confirmation,
2528 see `kill-emacs-query-functions' instead.
2530 The hook is not run in batch mode, i.e., if `noninteractive' is non-nil. */);
2531 Vkill_emacs_hook = Qnil;
2533 DEFVAR_INT ("emacs-priority", &emacs_priority,
2534 doc: /* Priority for Emacs to run at.
2535 This value is effective only if set before Emacs is dumped,
2536 and only if the Emacs executable is installed with setuid to permit
2537 it to change priority. (Emacs sets its uid back to the real uid.)
2538 Currently, you need to define SET_EMACS_PRIORITY in `config.h'
2539 before you compile Emacs, to enable the code for this feature. */);
2540 emacs_priority = 0;
2542 DEFVAR_LISP ("path-separator", &Vpath_separator,
2543 doc: /* String containing the character that separates directories in
2544 search paths, such as PATH and other similar environment variables. */);
2546 char c = SEPCHAR;
2547 Vpath_separator = make_string (&c, 1);
2550 DEFVAR_LISP ("invocation-name", &Vinvocation_name,
2551 doc: /* The program name that was used to run Emacs.
2552 Any directory names are omitted. */);
2554 DEFVAR_LISP ("invocation-directory", &Vinvocation_directory,
2555 doc: /* The directory in which the Emacs executable was found, to run it.
2556 The value is nil if that directory's name is not known. */);
2558 DEFVAR_LISP ("installation-directory", &Vinstallation_directory,
2559 doc: /* A directory within which to look for the `lib-src' and `etc' directories.
2560 This is non-nil when we can't find those directories in their standard
2561 installed locations, but we can find them near where the Emacs executable
2562 was found. */);
2563 Vinstallation_directory = Qnil;
2565 DEFVAR_LISP ("system-messages-locale", &Vsystem_messages_locale,
2566 doc: /* System locale for messages. */);
2567 Vsystem_messages_locale = Qnil;
2569 DEFVAR_LISP ("previous-system-messages-locale",
2570 &Vprevious_system_messages_locale,
2571 doc: /* Most recently used system locale for messages. */);
2572 Vprevious_system_messages_locale = Qnil;
2574 DEFVAR_LISP ("system-time-locale", &Vsystem_time_locale,
2575 doc: /* System locale for time. */);
2576 Vsystem_time_locale = Qnil;
2578 DEFVAR_LISP ("previous-system-time-locale", &Vprevious_system_time_locale,
2579 doc: /* Most recently used system locale for time. */);
2580 Vprevious_system_time_locale = Qnil;
2582 DEFVAR_LISP ("before-init-time", &Vbefore_init_time,
2583 doc: /* Value of `current-time' before Emacs begins initialization. */);
2584 Vbefore_init_time = Qnil;
2586 DEFVAR_LISP ("after-init-time", &Vafter_init_time,
2587 doc: /* Value of `current-time' after loading the init files.
2588 This is nil during initialization. */);
2589 Vafter_init_time = Qnil;
2591 DEFVAR_BOOL ("inhibit-x-resources", &inhibit_x_resources,
2592 doc: /* If non-nil, X resources, Windows Registry settings, and NS defaults are not used. */);
2593 inhibit_x_resources = 0;
2595 /* Make sure IS_DAEMON starts up as false. */
2596 daemon_pipe[1] = 0;
2599 /* arch-tag: 7bfd356a-c720-4612-8ab6-aa4222931c2e
2600 (do not change this comment) */