Merge from trunk.
[emacs.git] / src / emacs.c
blob83ad8d9515639e78c62998f817ceabf290f496e0
1 /* Fully extensible Emacs, running on Unix, intended for GNU.
3 Copyright (C) 1985-1987, 1993-1995, 1997-1999, 2001-2011
4 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>
30 #include <unistd.h>
32 #include "lisp.h"
34 #ifdef WINDOWSNT
35 #include <fcntl.h>
36 #include <windows.h> /* just for w32.h */
37 #include "w32.h"
38 #include "w32heap.h" /* for prototype of sbrk */
39 #endif
41 #ifdef NS_IMPL_GNUSTEP
42 /* At least under Debian, GSConfig is in a subdirectory. --Stef */
43 #include <GNUstepBase/GSConfig.h>
44 #endif
46 #include "commands.h"
47 #include "intervals.h"
48 #include "buffer.h"
49 #include "window.h"
51 #include "systty.h"
52 #include "blockinput.h"
53 #include "syssignal.h"
54 #include "process.h"
55 #include "frame.h"
56 #include "termhooks.h"
57 #include "keyboard.h"
58 #include "keymap.h"
60 #ifdef HAVE_GNUTLS
61 #include "gnutls.h"
62 #endif
64 #ifdef HAVE_NS
65 #include "nsterm.h"
66 #endif
68 #ifdef HAVE_X_WINDOWS
69 #include "xterm.h"
70 #endif
72 #ifdef HAVE_SETLOCALE
73 #include <locale.h>
74 #endif
76 #ifdef HAVE_SETRLIMIT
77 #include <sys/time.h>
78 #include <sys/resource.h>
79 #endif
81 #ifdef HAVE_PERSONALITY_LINUX32
82 #include <sys/personality.h>
83 #endif
85 #ifdef HAVE_LIBXML2
86 #include <libxml/parser.h>
87 #endif
89 #ifndef O_RDWR
90 #define O_RDWR 2
91 #endif
93 #ifdef HAVE_SETPGID
94 #if !defined (USG)
95 #undef setpgrp
96 #define setpgrp setpgid
97 #endif
98 #endif
100 static const char emacs_version[] = VERSION;
101 static const char emacs_copyright[] = "Copyright (C) 2011 Free Software Foundation, Inc.";
103 /* Make these values available in GDB, which doesn't see macros. */
105 #ifdef USE_LSB_TAG
106 int gdb_use_lsb EXTERNALLY_VISIBLE = 1;
107 #else
108 int gdb_use_lsb EXTERNALLY_VISIBLE = 0;
109 #endif
110 #ifndef USE_LISP_UNION_TYPE
111 int gdb_use_union EXTERNALLY_VISIBLE = 0;
112 #else
113 int gdb_use_union EXTERNALLY_VISIBLE = 1;
114 #endif
115 EMACS_INT gdb_valbits EXTERNALLY_VISIBLE = VALBITS;
116 EMACS_INT gdb_gctypebits EXTERNALLY_VISIBLE = GCTYPEBITS;
117 #if defined (DATA_SEG_BITS) && ! defined (USE_LSB_TAG)
118 EMACS_INT gdb_data_seg_bits EXTERNALLY_VISIBLE = DATA_SEG_BITS;
119 #else
120 EMACS_INT gdb_data_seg_bits EXTERNALLY_VISIBLE = 0;
121 #endif
122 EMACS_INT PVEC_FLAG EXTERNALLY_VISIBLE = PSEUDOVECTOR_FLAG;
123 EMACS_INT gdb_array_mark_flag EXTERNALLY_VISIBLE = ARRAY_MARK_FLAG;
124 /* GDB might say "No enum type named pvec_type" if we don't have at
125 least one symbol with that type, and then xbacktrace could fail. */
126 enum pvec_type gdb_pvec_type EXTERNALLY_VISIBLE = PVEC_TYPE_MASK;
128 /* Empty lisp strings. To avoid having to build any others. */
129 Lisp_Object empty_unibyte_string, empty_multibyte_string;
131 /* Set nonzero after Emacs has started up the first time.
132 Prevents reinitialization of the Lisp world and keymaps
133 on subsequent starts. */
134 int initialized;
136 #ifdef DARWIN_OS
137 extern void unexec_init_emacs_zone (void);
138 #endif
140 #ifdef DOUG_LEA_MALLOC
141 /* Preserves a pointer to the memory allocated that copies that
142 static data inside glibc's malloc. */
143 static void *malloc_state_ptr;
144 /* From glibc, a routine that returns a copy of the malloc internal state. */
145 extern void *malloc_get_state (void);
146 /* From glibc, a routine that overwrites the malloc internal state. */
147 extern int malloc_set_state (void*);
148 /* Non-zero if the MALLOC_CHECK_ environment variable was set while
149 dumping. Used to work around a bug in glibc's malloc. */
150 static int malloc_using_checking;
151 #endif
153 Lisp_Object Qfile_name_handler_alist;
155 Lisp_Object Qrisky_local_variable;
157 /* If non-zero, Emacs should not attempt to use a window-specific code,
158 but instead should use the virtual terminal under which it was started. */
159 int inhibit_window_system;
161 /* If non-zero, a filter or a sentinel is running. Tested to save the match
162 data on the first attempt to change it inside asynchronous code. */
163 int running_asynch_code;
165 #if defined(HAVE_X_WINDOWS) || defined(HAVE_NS)
166 /* If non-zero, -d was specified, meaning we're using some window system. */
167 int display_arg;
168 #endif
170 /* An address near the bottom of the stack.
171 Tells GC how to save a copy of the stack. */
172 char *stack_bottom;
174 /* The address where the heap starts (from the first sbrk (0) call). */
175 static void *my_heap_start;
177 #ifdef GNU_LINUX
178 /* The gap between BSS end and heap start as far as we can tell. */
179 static uprintmax_t heap_bss_diff;
180 #endif
182 /* Nonzero means running Emacs without interactive terminal. */
183 int noninteractive;
185 /* Nonzero means remove site-lisp directories from load-path. */
186 int no_site_lisp;
188 /* Name for the server started by the daemon.*/
189 static char *daemon_name;
191 /* Pipe used to send exit notification to the daemon parent at
192 startup. */
193 int daemon_pipe[2];
195 /* Save argv and argc. */
196 char **initial_argv;
197 int initial_argc;
199 static void sort_args (int argc, char **argv);
200 static void syms_of_emacs (void);
202 /* MSVC needs each string be shorter than 2048 bytes, so the usage
203 strings below are split to not overflow this limit. */
204 #define USAGE1 "\
205 Usage: %s [OPTION-OR-FILENAME]...\n\
207 Run Emacs, the extensible, customizable, self-documenting real-time\n\
208 display editor. The recommended way to start Emacs for normal editing\n\
209 is with no options at all.\n\
211 Run M-x info RET m emacs RET m emacs invocation RET inside Emacs to\n\
212 read the main documentation for these command-line arguments.\n\
214 Initialization options:\n\
216 --batch do not do interactive display; implies -q\n\
217 --chdir DIR change to directory DIR\n\
218 --daemon start a server in the background\n\
219 --debug-init enable Emacs Lisp debugger for init file\n\
220 --display, -d DISPLAY use X server DISPLAY\n\
221 --no-desktop do not load a saved desktop\n\
222 --no-init-file, -q load neither ~/.emacs nor default.el\n\
223 --no-shared-memory, -nl do not use shared memory\n\
224 --no-site-file do not load site-start.el\n\
225 --no-site-lisp, -nsl do not add site-lisp directories to load-path\n\
226 --no-splash do not display a splash screen on startup\n\
227 --no-window-system, -nw do not communicate with X, ignoring $DISPLAY\n\
228 --quick, -Q equivalent to:\n\
229 -q --no-site-file --no-site-lisp --no-splash\n\
230 --script FILE run FILE as an Emacs Lisp script\n\
231 --terminal, -t DEVICE use DEVICE for terminal I/O\n\
232 --user, -u USER load ~USER/.emacs instead of your own\n\
233 \n%s"
235 #define USAGE2 "\
236 Action options:\n\
238 FILE visit FILE using find-file\n\
239 +LINE go to line LINE in next FILE\n\
240 +LINE:COLUMN go to line LINE, column COLUMN, in next FILE\n\
241 --directory, -L DIR add DIR to variable load-path\n\
242 --eval EXPR evaluate Emacs Lisp expression EXPR\n\
243 --execute EXPR evaluate Emacs Lisp expression EXPR\n\
244 --file FILE visit FILE using find-file\n\
245 --find-file FILE visit FILE using find-file\n\
246 --funcall, -f FUNC call Emacs Lisp function FUNC with no arguments\n\
247 --insert FILE insert contents of FILE into current buffer\n\
248 --kill exit without asking for confirmation\n\
249 --load, -l FILE load Emacs Lisp FILE using the load function\n\
250 --visit FILE visit FILE using find-file\n\
253 #define USAGE3 "\
254 Display options:\n\
256 --background-color, -bg COLOR window background color\n\
257 --basic-display, -D disable many display features;\n\
258 used for debugging Emacs\n\
259 --border-color, -bd COLOR main border color\n\
260 --border-width, -bw WIDTH width of main border\n\
261 --color, --color=MODE override color mode for character terminals;\n\
262 MODE defaults to `auto', and\n\
263 can also be `never', `always',\n\
264 or a mode name like `ansi8'\n\
265 --cursor-color, -cr COLOR color of the Emacs cursor indicating point\n\
266 --font, -fn FONT default font; must be fixed-width\n\
267 --foreground-color, -fg COLOR window foreground color\n\
268 --fullheight, -fh make the first frame high as the screen\n\
269 --fullscreen, -fs make the first frame fullscreen\n\
270 --fullwidth, -fw make the first frame wide as the screen\n\
271 --maximized, -mm make the first frame maximized\n\
272 --geometry, -g GEOMETRY window geometry\n\
273 --no-bitmap-icon, -nbi do not use picture of gnu for Emacs icon\n\
274 --iconic start Emacs in iconified state\n\
275 --internal-border, -ib WIDTH width between text and main border\n\
276 --line-spacing, -lsp PIXELS additional space to put between lines\n\
277 --mouse-color, -ms COLOR mouse cursor color in Emacs window\n\
278 --name NAME title for initial Emacs frame\n\
279 --no-blinking-cursor, -nbc disable blinking cursor\n\
280 --reverse-video, -r, -rv switch foreground and background\n\
281 --title, -T TITLE title for initial Emacs frame\n\
282 --vertical-scroll-bars, -vb enable vertical scroll bars\n\
283 --xrm XRESOURCES set additional X resources\n\
284 --parent-id XID set parent window\n\
285 --help display this help and exit\n\
286 --version output version information and exit\n\
289 #define USAGE4 "\
290 You can generally also specify long option names with a single -; for\n\
291 example, -batch as well as --batch. You can use any unambiguous\n\
292 abbreviation for a --option.\n\
294 Various environment variables and window system resources also affect\n\
295 Emacs' operation. See the main documentation.\n\
297 Report bugs to bug-gnu-emacs@gnu.org. First, please see the Bugs\n\
298 section of the Emacs manual or the file BUGS.\n"
301 /* Signal code for the fatal signal that was received. */
302 static int fatal_error_code;
304 /* Nonzero if handling a fatal error already. */
305 int fatal_error_in_progress;
307 /* If non-null, call this function from fatal_error_signal before
308 committing suicide. */
310 static void (*fatal_error_signal_hook) (void);
312 #ifdef FORWARD_SIGNAL_TO_MAIN_THREAD
313 /* When compiled with GTK and running under Gnome,
314 multiple threads may be created. Keep track of our main
315 thread to make sure signals are delivered to it (see syssignal.h). */
317 pthread_t main_thread;
318 #endif
321 /* Handle bus errors, invalid instruction, etc. */
322 #ifndef FLOAT_CATCH_SIGILL
323 static
324 #endif
325 void
326 fatal_error_signal (int sig)
328 SIGNAL_THREAD_CHECK (sig);
329 fatal_error_code = sig;
330 signal (sig, SIG_DFL);
332 TOTALLY_UNBLOCK_INPUT;
334 /* If fatal error occurs in code below, avoid infinite recursion. */
335 if (! fatal_error_in_progress)
337 fatal_error_in_progress = 1;
339 if (sig == SIGTERM || sig == SIGHUP || sig == SIGINT)
340 Fkill_emacs (make_number (sig));
342 shut_down_emacs (sig, 0, Qnil);
345 /* Signal the same code; this time it will really be fatal.
346 Remember that since we're in a signal handler, the signal we're
347 going to send is probably blocked, so we have to unblock it if we
348 want to really receive it. */
349 #ifndef MSDOS
350 sigunblock (sigmask (fatal_error_code));
351 #endif
353 if (fatal_error_signal_hook)
354 fatal_error_signal_hook ();
356 kill (getpid (), fatal_error_code);
359 #ifdef SIGDANGER
361 /* Handler for SIGDANGER. */
362 void
363 memory_warning_signal (int sig)
365 signal (sig, memory_warning_signal);
366 SIGNAL_THREAD_CHECK (sig);
368 malloc_warning ("Operating system warns that virtual memory is running low.\n");
370 /* It might be unsafe to call do_auto_save now. */
371 force_auto_save_soon ();
373 #endif
375 /* We define abort, rather than using it from the library,
376 so that GDB can return from a breakpoint here.
377 MSDOS has its own definition in msdos.c. */
379 #if ! defined (DOS_NT) && ! defined (NO_ABORT)
381 void
382 abort (void)
384 kill (getpid (), SIGABRT);
385 /* This shouldn't be executed, but it prevents a warning. */
386 exit (1);
388 #endif
391 /* Code for dealing with Lisp access to the Unix command line. */
393 static void
394 init_cmdargs (int argc, char **argv, int skip_args)
396 register int i;
397 Lisp_Object name, dir, handler;
398 int count = SPECPDL_INDEX ();
399 Lisp_Object raw_name;
401 initial_argv = argv;
402 initial_argc = argc;
404 raw_name = build_string (argv[0]);
406 /* Add /: to the front of the name
407 if it would otherwise be treated as magic. */
408 handler = Ffind_file_name_handler (raw_name, Qt);
409 if (! NILP (handler))
410 raw_name = concat2 (build_string ("/:"), raw_name);
412 Vinvocation_name = Ffile_name_nondirectory (raw_name);
413 Vinvocation_directory = Ffile_name_directory (raw_name);
415 /* If we got no directory in argv[0], search PATH to find where
416 Emacs actually came from. */
417 if (NILP (Vinvocation_directory))
419 Lisp_Object found;
420 int yes = openp (Vexec_path, Vinvocation_name,
421 Vexec_suffixes, &found, make_number (X_OK));
422 if (yes == 1)
424 /* Add /: to the front of the name
425 if it would otherwise be treated as magic. */
426 handler = Ffind_file_name_handler (found, Qt);
427 if (! NILP (handler))
428 found = concat2 (build_string ("/:"), found);
429 Vinvocation_directory = Ffile_name_directory (found);
433 if (!NILP (Vinvocation_directory)
434 && NILP (Ffile_name_absolute_p (Vinvocation_directory)))
435 /* Emacs was started with relative path, like ./emacs.
436 Make it absolute. */
437 Vinvocation_directory = Fexpand_file_name (Vinvocation_directory, Qnil);
439 Vinstallation_directory = Qnil;
441 if (!NILP (Vinvocation_directory))
443 dir = Vinvocation_directory;
444 name = Fexpand_file_name (Vinvocation_name, dir);
445 while (1)
447 Lisp_Object tem, lib_src_exists;
448 Lisp_Object etc_exists, info_exists;
450 /* See if dir contains subdirs for use by Emacs.
451 Check for the ones that would exist in a build directory,
452 not including lisp and info. */
453 tem = Fexpand_file_name (build_string ("lib-src"), dir);
454 lib_src_exists = Ffile_exists_p (tem);
456 #ifdef MSDOS
457 /* MSDOS installations frequently remove lib-src, but we still
458 must set installation-directory, or else info won't find
459 its files (it uses the value of installation-directory). */
460 tem = Fexpand_file_name (build_string ("info"), dir);
461 info_exists = Ffile_exists_p (tem);
462 #else
463 info_exists = Qnil;
464 #endif
466 if (!NILP (lib_src_exists) || !NILP (info_exists))
468 tem = Fexpand_file_name (build_string ("etc"), dir);
469 etc_exists = Ffile_exists_p (tem);
470 if (!NILP (etc_exists))
472 Vinstallation_directory
473 = Ffile_name_as_directory (dir);
474 break;
478 /* See if dir's parent contains those subdirs. */
479 tem = Fexpand_file_name (build_string ("../lib-src"), dir);
480 lib_src_exists = Ffile_exists_p (tem);
483 #ifdef MSDOS
484 /* See the MSDOS commentary above. */
485 tem = Fexpand_file_name (build_string ("../info"), dir);
486 info_exists = Ffile_exists_p (tem);
487 #else
488 info_exists = Qnil;
489 #endif
491 if (!NILP (lib_src_exists) || !NILP (info_exists))
493 tem = Fexpand_file_name (build_string ("../etc"), dir);
494 etc_exists = Ffile_exists_p (tem);
495 if (!NILP (etc_exists))
497 tem = Fexpand_file_name (build_string (".."), dir);
498 Vinstallation_directory
499 = Ffile_name_as_directory (tem);
500 break;
504 /* If the Emacs executable is actually a link,
505 next try the dir that the link points into. */
506 tem = Ffile_symlink_p (name);
507 if (!NILP (tem))
509 name = Fexpand_file_name (tem, dir);
510 dir = Ffile_name_directory (name);
512 else
513 break;
517 Vcommand_line_args = Qnil;
519 for (i = argc - 1; i >= 0; i--)
521 if (i == 0 || i > skip_args)
522 /* For the moment, we keep arguments as is in unibyte strings.
523 They are decoded in the function command-line after we know
524 locale-coding-system. */
525 Vcommand_line_args
526 = Fcons (make_unibyte_string (argv[i], strlen (argv[i])),
527 Vcommand_line_args);
530 unbind_to (count, Qnil);
533 DEFUN ("invocation-name", Finvocation_name, Sinvocation_name, 0, 0, 0,
534 doc: /* Return the program name that was used to run Emacs.
535 Any directory names are omitted. */)
536 (void)
538 return Fcopy_sequence (Vinvocation_name);
541 DEFUN ("invocation-directory", Finvocation_directory, Sinvocation_directory,
542 0, 0, 0,
543 doc: /* Return the directory name in which the Emacs executable was located. */)
544 (void)
546 return Fcopy_sequence (Vinvocation_directory);
550 #ifdef HAVE_TZSET
551 /* A valid but unlikely value for the TZ environment value.
552 It is OK (though a bit slower) if the user actually chooses this value. */
553 static char dump_tz[] = "UtC0";
554 #endif
556 #ifndef ORDINARY_LINK
557 /* We don't include crtbegin.o and crtend.o in the link,
558 so these functions and variables might be missed.
559 Provide dummy definitions to avoid error.
560 (We don't have any real constructors or destructors.) */
561 #ifdef __GNUC__
563 /* Define a dummy function F. Declare F too, to pacify gcc
564 -Wmissing-prototypes. */
565 #define DEFINE_DUMMY_FUNCTION(f) \
566 void f (void) EXTERNALLY_VISIBLE; void f (void) {}
568 #ifndef GCC_CTORS_IN_LIBC
569 DEFINE_DUMMY_FUNCTION (__do_global_ctors)
570 DEFINE_DUMMY_FUNCTION (__do_global_ctors_aux)
571 DEFINE_DUMMY_FUNCTION (__do_global_dtors)
572 /* GNU/Linux has a bug in its library; avoid an error. */
573 #ifndef GNU_LINUX
574 char * __CTOR_LIST__[2] EXTERNALLY_VISIBLE = { (char *) (-1), 0 };
575 #endif
576 char * __DTOR_LIST__[2] EXTERNALLY_VISIBLE = { (char *) (-1), 0 };
577 #endif /* GCC_CTORS_IN_LIBC */
578 DEFINE_DUMMY_FUNCTION (__main)
579 #endif /* __GNUC__ */
580 #endif /* ORDINARY_LINK */
582 /* Test whether the next argument in ARGV matches SSTR or a prefix of
583 LSTR (at least MINLEN characters). If so, then if VALPTR is non-null
584 (the argument is supposed to have a value) store in *VALPTR either
585 the next argument or the portion of this one after the equal sign.
586 ARGV is read starting at position *SKIPPTR; this index is advanced
587 by the number of arguments used.
589 Too bad we can't just use getopt for all of this, but we don't have
590 enough information to do it right. */
592 static int
593 argmatch (char **argv, int argc, const char *sstr, const char *lstr,
594 int minlen, char **valptr, int *skipptr)
596 char *p = NULL;
597 ptrdiff_t arglen;
598 char *arg;
600 /* Don't access argv[argc]; give up in advance. */
601 if (argc <= *skipptr + 1)
602 return 0;
604 arg = argv[*skipptr+1];
605 if (arg == NULL)
606 return 0;
607 if (strcmp (arg, sstr) == 0)
609 if (valptr != NULL)
611 *valptr = argv[*skipptr+2];
612 *skipptr += 2;
614 else
615 *skipptr += 1;
616 return 1;
618 arglen = (valptr != NULL && (p = strchr (arg, '=')) != NULL
619 ? p - arg : strlen (arg));
620 if (lstr == 0 || arglen < minlen || strncmp (arg, lstr, arglen) != 0)
621 return 0;
622 else if (valptr == NULL)
624 *skipptr += 1;
625 return 1;
627 else if (p != NULL)
629 *valptr = p+1;
630 *skipptr += 1;
631 return 1;
633 else if (argv[*skipptr+2] != NULL)
635 *valptr = argv[*skipptr+2];
636 *skipptr += 2;
637 return 1;
639 else
641 return 0;
645 #ifdef DOUG_LEA_MALLOC
647 /* malloc can be invoked even before main (e.g. by the dynamic
648 linker), so the dumped malloc state must be restored as early as
649 possible using this special hook. */
651 static void
652 malloc_initialize_hook (void)
654 #ifndef USE_CRT_DLL
655 extern char **environ;
656 #endif
658 if (initialized)
660 if (!malloc_using_checking)
661 /* Work around a bug in glibc's malloc. MALLOC_CHECK_ must be
662 ignored if the heap to be restored was constructed without
663 malloc checking. Can't use unsetenv, since that calls malloc. */
665 char **p;
667 for (p = environ; p && *p; p++)
668 if (strncmp (*p, "MALLOC_CHECK_=", 14) == 0)
671 *p = p[1];
672 while (*++p);
673 break;
677 malloc_set_state (malloc_state_ptr);
678 #ifndef XMALLOC_OVERRUN_CHECK
679 free (malloc_state_ptr);
680 #endif
682 else
684 if (my_heap_start == 0)
685 my_heap_start = sbrk (0);
686 malloc_using_checking = getenv ("MALLOC_CHECK_") != NULL;
690 void (*__malloc_initialize_hook) (void) EXTERNALLY_VISIBLE = malloc_initialize_hook;
692 #endif /* DOUG_LEA_MALLOC */
695 /* ARGSUSED */
697 main (int argc, char **argv)
699 #if GC_MARK_STACK
700 Lisp_Object dummy;
701 #endif
702 char stack_bottom_variable;
703 int do_initial_setlocale;
704 int skip_args = 0;
705 #ifdef HAVE_SETRLIMIT
706 struct rlimit rlim;
707 #endif
708 int no_loadup = 0;
709 char *junk = 0;
710 char *dname_arg = 0;
711 #ifdef NS_IMPL_COCOA
712 char dname_arg2[80];
713 #endif
714 char *ch_to_dir;
716 #if GC_MARK_STACK
717 stack_base = &dummy;
718 #endif
720 #if defined (USE_GTK) && defined (G_SLICE_ALWAYS_MALLOC)
721 /* This is used by the Cygwin build. */
722 setenv ("G_SLICE", "always-malloc", 1);
723 #endif
725 #ifdef GNU_LINUX
726 if (!initialized)
728 extern char my_endbss[];
729 extern char *my_endbss_static;
731 if (my_heap_start == 0)
732 my_heap_start = sbrk (0);
734 heap_bss_diff = (char *)my_heap_start - max (my_endbss, my_endbss_static);
736 #endif
738 #ifdef RUN_TIME_REMAP
739 if (initialized)
740 run_time_remap (argv[0]);
741 #endif
743 /* If using unexmacosx.c (set by s/darwin.h), we must do this. */
744 #ifdef DARWIN_OS
745 if (!initialized)
746 unexec_init_emacs_zone ();
747 #endif
749 sort_args (argc, argv);
750 argc = 0;
751 while (argv[argc]) argc++;
753 if (argmatch (argv, argc, "-version", "--version", 3, NULL, &skip_args))
755 const char *version, *copyright;
756 if (initialized)
758 Lisp_Object tem, tem2;
759 tem = Fsymbol_value (intern_c_string ("emacs-version"));
760 tem2 = Fsymbol_value (intern_c_string ("emacs-copyright"));
761 if (!STRINGP (tem))
763 fprintf (stderr, "Invalid value of `emacs-version'\n");
764 exit (1);
766 if (!STRINGP (tem2))
768 fprintf (stderr, "Invalid value of `emacs-copyright'\n");
769 exit (1);
771 else
773 version = SSDATA (tem);
774 copyright = SSDATA (tem2);
777 else
779 version = emacs_version;
780 copyright = emacs_copyright;
782 printf ("GNU Emacs %s\n", version);
783 printf ("%s\n", copyright);
784 printf ("GNU Emacs comes with ABSOLUTELY NO WARRANTY.\n");
785 printf ("You may redistribute copies of Emacs\n");
786 printf ("under the terms of the GNU General Public License.\n");
787 printf ("For more information about these matters, ");
788 printf ("see the file named COPYING.\n");
789 exit (0);
792 if (argmatch (argv, argc, "-chdir", "--chdir", 4, &ch_to_dir, &skip_args))
793 if (chdir (ch_to_dir) == -1)
795 fprintf (stderr, "%s: Can't chdir to %s: %s\n",
796 argv[0], ch_to_dir, strerror (errno));
797 exit (1);
801 #ifdef HAVE_PERSONALITY_LINUX32
802 if (!initialized
803 && (strcmp (argv[argc-1], "dump") == 0
804 || strcmp (argv[argc-1], "bootstrap") == 0)
805 && ! getenv ("EMACS_HEAP_EXEC"))
807 static char heapexec[] = "EMACS_HEAP_EXEC=true";
808 /* Set this so we only do this once. */
809 putenv(heapexec);
811 /* A flag to turn off address randomization which is introduced
812 in linux kernel shipped with fedora core 4 */
813 #define ADD_NO_RANDOMIZE 0x0040000
814 personality (PER_LINUX32 | ADD_NO_RANDOMIZE);
815 #undef ADD_NO_RANDOMIZE
817 execvp (argv[0], argv);
819 /* If the exec fails, try to dump anyway. */
820 perror ("execvp");
822 #endif /* HAVE_PERSONALITY_LINUX32 */
824 #if defined (HAVE_SETRLIMIT) && defined (RLIMIT_STACK)
825 /* Extend the stack space available.
826 Don't do that if dumping, since some systems (e.g. DJGPP)
827 might define a smaller stack limit at that time. */
828 if (1
829 #ifndef CANNOT_DUMP
830 && (!noninteractive || initialized)
831 #endif
832 && !getrlimit (RLIMIT_STACK, &rlim))
834 long newlim;
835 extern size_t re_max_failures;
836 /* Approximate the amount regex.c needs per unit of re_max_failures. */
837 int ratio = 20 * sizeof (char *);
838 /* Then add 33% to cover the size of the smaller stacks that regex.c
839 successively allocates and discards, on its way to the maximum. */
840 ratio += ratio / 3;
841 /* Add in some extra to cover
842 what we're likely to use for other reasons. */
843 newlim = re_max_failures * ratio + 200000;
844 #ifdef __NetBSD__
845 /* NetBSD (at least NetBSD 1.2G and former) has a bug in its
846 stack allocation routine for new process that the allocation
847 fails if stack limit is not on page boundary. So, round up the
848 new limit to page boundary. */
849 newlim = (newlim + getpagesize () - 1) / getpagesize () * getpagesize();
850 #endif
851 if (newlim > rlim.rlim_max)
853 newlim = rlim.rlim_max;
854 /* Don't let regex.c overflow the stack we have. */
855 re_max_failures = (newlim - 200000) / ratio;
857 if (rlim.rlim_cur < newlim)
858 rlim.rlim_cur = newlim;
860 setrlimit (RLIMIT_STACK, &rlim);
862 #endif /* HAVE_SETRLIMIT and RLIMIT_STACK */
864 /* Record (approximately) where the stack begins. */
865 stack_bottom = &stack_bottom_variable;
867 clearerr (stdin);
869 #ifndef SYSTEM_MALLOC
870 /* Arrange to get warning messages as memory fills up. */
871 memory_warnings (0, malloc_warning);
873 /* Call malloc at least once, to run the initial __malloc_hook.
874 Also call realloc and free for consistency. */
875 free (realloc (malloc (4), 4));
877 # ifndef SYNC_INPUT
878 /* Arrange to disable interrupt input inside malloc etc. */
879 uninterrupt_malloc ();
880 # endif /* not SYNC_INPUT */
881 #endif /* not SYSTEM_MALLOC */
883 #ifdef FORWARD_SIGNAL_TO_MAIN_THREAD
884 main_thread = pthread_self ();
885 #endif /* FORWARD_SIGNAL_TO_MAIN_THREAD */
887 #if defined (MSDOS) || defined (WINDOWSNT)
888 /* We do all file input/output as binary files. When we need to translate
889 newlines, we do that manually. */
890 _fmode = O_BINARY;
891 #endif /* MSDOS || WINDOWSNT */
893 #ifdef MSDOS
894 if (!isatty (fileno (stdin)))
895 setmode (fileno (stdin), O_BINARY);
896 if (!isatty (fileno (stdout)))
898 fflush (stdout);
899 setmode (fileno (stdout), O_BINARY);
901 #endif /* MSDOS */
903 /* Skip initial setlocale if LC_ALL is "C", as it's not needed in that case.
904 The build procedure uses this while dumping, to ensure that the
905 dumped Emacs does not have its system locale tables initialized,
906 as that might cause screwups when the dumped Emacs starts up. */
908 char *lc_all = getenv ("LC_ALL");
909 do_initial_setlocale = ! lc_all || strcmp (lc_all, "C");
912 /* Set locale now, so that initial error messages are localized properly.
913 fixup_locale must wait until later, since it builds strings. */
914 if (do_initial_setlocale)
915 setlocale (LC_ALL, "");
917 inhibit_window_system = 0;
919 /* Handle the -t switch, which specifies filename to use as terminal. */
920 while (1)
922 char *term;
923 if (argmatch (argv, argc, "-t", "--terminal", 4, &term, &skip_args))
925 int result;
926 emacs_close (0);
927 emacs_close (1);
928 result = emacs_open (term, O_RDWR, 0);
929 if (result < 0 || dup (0) < 0)
931 char *errstring = strerror (errno);
932 fprintf (stderr, "%s: %s: %s\n", argv[0], term, errstring);
933 exit (1);
935 if (! isatty (0))
937 fprintf (stderr, "%s: %s: not a tty\n", argv[0], term);
938 exit (1);
940 fprintf (stderr, "Using %s\n", term);
941 #ifdef HAVE_WINDOW_SYSTEM
942 inhibit_window_system = 1; /* -t => -nw */
943 #endif
945 else
946 break;
949 /* Command line option --no-windows is deprecated and thus not mentioned
950 in the manual and usage informations. */
951 if (argmatch (argv, argc, "-nw", "--no-window-system", 6, NULL, &skip_args)
952 || argmatch (argv, argc, "-nw", "--no-windows", 6, NULL, &skip_args))
953 inhibit_window_system = 1;
955 /* Handle the -batch switch, which means don't do interactive display. */
956 noninteractive = 0;
957 if (argmatch (argv, argc, "-batch", "--batch", 5, NULL, &skip_args))
959 noninteractive = 1;
960 Vundo_outer_limit = Qnil;
962 if (argmatch (argv, argc, "-script", "--script", 3, &junk, &skip_args))
964 noninteractive = 1; /* Set batch mode. */
965 /* Convert --script to -scriptload, un-skip it, and sort again
966 so that it will be handled in proper sequence. */
967 /* FIXME broken for --script=FILE - is that supposed to work? */
968 argv[skip_args - 1] = (char *) "-scriptload";
969 skip_args -= 2;
970 sort_args (argc, argv);
973 /* Handle the --help option, which gives a usage message. */
974 if (argmatch (argv, argc, "-help", "--help", 3, NULL, &skip_args))
976 printf (USAGE1, argv[0], USAGE2);
977 printf (USAGE3);
978 printf (USAGE4);
979 exit (0);
982 if (argmatch (argv, argc, "-daemon", "--daemon", 5, NULL, &skip_args)
983 || argmatch (argv, argc, "-daemon", "--daemon", 5, &dname_arg, &skip_args))
985 #ifndef DOS_NT
986 pid_t f;
988 /* Start as a daemon: fork a new child process which will run the
989 rest of the initialization code, then exit.
991 Detaching a daemon requires the following steps:
992 - fork
993 - setsid
994 - exit the parent
995 - close the tty file-descriptors
997 We only want to do the last 2 steps once the daemon is ready to
998 serve requests, i.e. after loading .emacs (initialization).
999 OTOH initialization may start subprocesses (e.g. ispell) and these
1000 should be run from the proper process (the one that will end up
1001 running as daemon) and with the proper "session id" in order for
1002 them to keep working after detaching, so fork and setsid need to be
1003 performed before initialization.
1005 We want to avoid exiting before the server socket is ready, so
1006 use a pipe for synchronization. The parent waits for the child
1007 to close its end of the pipe (using `daemon-initialized')
1008 before exiting. */
1009 if (pipe (daemon_pipe) == -1)
1011 fprintf (stderr, "Cannot pipe!\n");
1012 exit (1);
1015 #ifndef NS_IMPL_COCOA
1016 #ifdef USE_GTK
1017 fprintf (stderr, "\nWarning: due to a long standing Gtk+ bug\nhttp://bugzilla.gnome.org/show_bug.cgi?id=85715\n\
1018 Emacs might crash when run in daemon mode and the X11 connection is unexpectedly lost.\n\
1019 Using an Emacs configured with --with-x-toolkit=lucid does not have this problem.\n");
1020 #endif
1021 f = fork ();
1022 #else /* NS_IMPL_COCOA */
1023 /* Under Cocoa we must do fork+exec as CoreFoundation lib fails in
1024 forked process: http://developer.apple.com/ReleaseNotes/
1025 CoreFoundation/CoreFoundation.html)
1026 We mark being in the exec'd process by a daemon name argument of
1027 form "--daemon=\nFD0,FD1\nNAME" where FD are the pipe file descriptors,
1028 NAME is the original daemon name, if any. */
1029 if (!dname_arg || !strchr (dname_arg, '\n'))
1030 f = fork (); /* in orig */
1031 else
1032 f = 0; /* in exec'd */
1033 #endif /* NS_IMPL_COCOA */
1034 if (f > 0)
1036 int retval;
1037 char buf[1];
1039 /* Close unused writing end of the pipe. */
1040 close (daemon_pipe[1]);
1042 /* Just wait for the child to close its end of the pipe. */
1045 retval = read (daemon_pipe[0], &buf, 1);
1047 while (retval == -1 && errno == EINTR);
1049 if (retval < 0)
1051 fprintf (stderr, "Error reading status from child\n");
1052 exit (1);
1054 else if (retval == 0)
1056 fprintf (stderr, "Error: server did not start correctly\n");
1057 exit (1);
1060 close (daemon_pipe[0]);
1061 exit (0);
1063 if (f < 0)
1065 fprintf (stderr, "Cannot fork!\n");
1066 exit (1);
1069 #ifdef NS_IMPL_COCOA
1071 /* In orig process, forked as child, OR in exec'd. */
1072 if (!dname_arg || !strchr (dname_arg, '\n'))
1073 { /* In orig, child: now exec w/special daemon name. */
1074 char fdStr[80];
1075 int fdStrlen =
1076 snprintf (fdStr, sizeof fdStr,
1077 "--daemon=\n%d,%d\n%s", daemon_pipe[0],
1078 daemon_pipe[1], dname_arg ? dname_arg : "");
1080 if (! (0 <= fdStrlen && fdStrlen < sizeof fdStr))
1082 fprintf (stderr, "daemon: child name too long\n");
1083 exit (1);
1086 argv[skip_args] = fdStr;
1088 execv (argv[0], argv);
1089 fprintf (stderr, "emacs daemon: exec failed: %d\n", errno);
1090 exit (1);
1093 /* In exec'd: parse special dname into pipe and name info. */
1094 if (!dname_arg || !strchr (dname_arg, '\n')
1095 || strlen (dname_arg) < 1 || strlen (dname_arg) > 70)
1097 fprintf (stderr, "emacs daemon: daemon name absent or too long\n");
1098 exit(1);
1100 dname_arg2[0] = '\0';
1101 sscanf (dname_arg, "\n%d,%d\n%s", &(daemon_pipe[0]), &(daemon_pipe[1]),
1102 dname_arg2);
1103 dname_arg = *dname_arg2 ? dname_arg2 : NULL;
1105 #endif /* NS_IMPL_COCOA */
1107 if (dname_arg)
1108 daemon_name = xstrdup (dname_arg);
1109 /* Close unused reading end of the pipe. */
1110 close (daemon_pipe[0]);
1111 /* Make sure that the used end of the pipe is closed on exec, so
1112 that it is not accessible to programs started from .emacs. */
1113 fcntl (daemon_pipe[1], F_SETFD, FD_CLOEXEC);
1115 #ifdef HAVE_SETSID
1116 setsid();
1117 #endif
1118 #else /* DOS_NT */
1119 fprintf (stderr, "This platform does not support the -daemon flag.\n");
1120 exit (1);
1121 #endif /* DOS_NT */
1124 if (! noninteractive)
1126 #if defined (USG5) && defined (INTERRUPT_INPUT)
1127 setpgrp ();
1128 #endif
1129 #if defined (HAVE_PTHREAD) && !defined (SYSTEM_MALLOC) && !defined (DOUG_LEA_MALLOC)
1131 extern void malloc_enable_thread (void);
1133 malloc_enable_thread ();
1135 #endif
1138 init_signals ();
1140 /* Don't catch SIGHUP if dumping. */
1141 if (1
1142 #ifndef CANNOT_DUMP
1143 && initialized
1144 #endif
1147 sigblock (sigmask (SIGHUP));
1148 /* In --batch mode, don't catch SIGHUP if already ignored.
1149 That makes nohup work. */
1150 if (! noninteractive
1151 || signal (SIGHUP, SIG_IGN) != SIG_IGN)
1152 signal (SIGHUP, fatal_error_signal);
1153 sigunblock (sigmask (SIGHUP));
1156 if (
1157 #ifndef CANNOT_DUMP
1158 ! noninteractive || initialized
1159 #else
1161 #endif
1164 /* Don't catch these signals in batch mode if dumping.
1165 On some machines, this sets static data that would make
1166 signal fail to work right when the dumped Emacs is run. */
1167 signal (SIGQUIT, fatal_error_signal);
1168 signal (SIGILL, fatal_error_signal);
1169 signal (SIGTRAP, fatal_error_signal);
1170 #ifdef SIGUSR1
1171 add_user_signal (SIGUSR1, "sigusr1");
1172 #endif
1173 #ifdef SIGUSR2
1174 add_user_signal (SIGUSR2, "sigusr2");
1175 #endif
1176 #ifdef SIGABRT
1177 signal (SIGABRT, fatal_error_signal);
1178 #endif
1179 #ifdef SIGHWE
1180 signal (SIGHWE, fatal_error_signal);
1181 #endif
1182 #ifdef SIGPRE
1183 signal (SIGPRE, fatal_error_signal);
1184 #endif
1185 #ifdef SIGORE
1186 signal (SIGORE, fatal_error_signal);
1187 #endif
1188 #ifdef SIGUME
1189 signal (SIGUME, fatal_error_signal);
1190 #endif
1191 #ifdef SIGDLK
1192 signal (SIGDLK, fatal_error_signal);
1193 #endif
1194 #ifdef SIGCPULIM
1195 signal (SIGCPULIM, fatal_error_signal);
1196 #endif
1197 #ifdef SIGIOT
1198 /* This is missing on some systems - OS/2, for example. */
1199 signal (SIGIOT, fatal_error_signal);
1200 #endif
1201 #ifdef SIGEMT
1202 signal (SIGEMT, fatal_error_signal);
1203 #endif
1204 signal (SIGFPE, fatal_error_signal);
1205 #ifdef SIGBUS
1206 signal (SIGBUS, fatal_error_signal);
1207 #endif
1208 signal (SIGSEGV, fatal_error_signal);
1209 #ifdef SIGSYS
1210 signal (SIGSYS, fatal_error_signal);
1211 #endif
1212 /* May need special treatment on MS-Windows. See
1213 http://lists.gnu.org/archive/html/emacs-devel/2010-09/msg01062.html
1214 Please update the doc of kill-emacs, kill-emacs-hook, and
1215 NEWS if you change this.
1217 if (noninteractive) signal (SIGINT, fatal_error_signal);
1218 signal (SIGTERM, fatal_error_signal);
1219 #ifdef SIGXCPU
1220 signal (SIGXCPU, fatal_error_signal);
1221 #endif
1222 #ifdef SIGXFSZ
1223 signal (SIGXFSZ, fatal_error_signal);
1224 #endif /* SIGXFSZ */
1226 #ifdef SIGDANGER
1227 /* This just means available memory is getting low. */
1228 signal (SIGDANGER, memory_warning_signal);
1229 #endif
1231 #ifdef AIX
1232 /* 20 is SIGCHLD, 21 is SIGTTIN, 22 is SIGTTOU. */
1233 signal (SIGXCPU, fatal_error_signal);
1234 signal (SIGIOINT, fatal_error_signal);
1235 signal (SIGGRANT, fatal_error_signal);
1236 signal (SIGRETRACT, fatal_error_signal);
1237 signal (SIGSOUND, fatal_error_signal);
1238 signal (SIGMSG, fatal_error_signal);
1239 #endif /* AIX */
1242 noninteractive1 = noninteractive;
1244 /* Perform basic initializations (not merely interning symbols). */
1246 if (!initialized)
1248 init_alloc_once ();
1249 init_obarray ();
1250 init_eval_once ();
1251 init_character_once ();
1252 init_charset_once ();
1253 init_coding_once ();
1254 init_syntax_once (); /* Create standard syntax table. */
1255 init_category_once (); /* Create standard category table. */
1256 /* Must be done before init_buffer. */
1257 init_casetab_once ();
1258 init_buffer_once (); /* Create buffer table and some buffers. */
1259 init_minibuf_once (); /* Create list of minibuffers. */
1260 /* Must precede init_window_once. */
1262 /* Call syms_of_xfaces before init_window_once because that
1263 function creates Vterminal_frame. Termcap frames now use
1264 faces, and the face implementation uses some symbols as
1265 face names. */
1266 syms_of_xfaces ();
1267 /* XXX syms_of_keyboard uses some symbols in keymap.c. It would
1268 be better to arrange things not to have this dependency. */
1269 syms_of_keymap ();
1270 /* Call syms_of_keyboard before init_window_once because
1271 keyboard sets up symbols that include some face names that
1272 the X support will want to use. This can happen when
1273 CANNOT_DUMP is defined. */
1274 syms_of_keyboard ();
1276 /* Called before syms_of_fileio, because it sets up Qerror_condition. */
1277 syms_of_data ();
1278 syms_of_fileio ();
1279 /* Before syms_of_coding to initialize Vgc_cons_threshold. */
1280 syms_of_alloc ();
1281 /* Before syms_of_coding because it initializes Qcharsetp. */
1282 syms_of_charset ();
1283 /* Before init_window_once, because it sets up the
1284 Vcoding_system_hash_table. */
1285 syms_of_coding (); /* This should be after syms_of_fileio. */
1287 init_window_once (); /* Init the window system. */
1288 #ifdef HAVE_WINDOW_SYSTEM
1289 init_fringe_once (); /* Swap bitmaps if necessary. */
1290 #endif /* HAVE_WINDOW_SYSTEM */
1293 init_alloc ();
1295 if (do_initial_setlocale)
1297 fixup_locale ();
1298 Vsystem_messages_locale = Vprevious_system_messages_locale;
1299 Vsystem_time_locale = Vprevious_system_time_locale;
1302 init_eval ();
1303 init_data ();
1304 #ifdef CLASH_DETECTION
1305 init_filelock ();
1306 #endif
1307 init_atimer ();
1308 running_asynch_code = 0;
1310 no_loadup
1311 = argmatch (argv, argc, "-nl", "--no-loadup", 6, NULL, &skip_args);
1313 no_site_lisp
1314 = argmatch (argv, argc, "-nsl", "--no-site-lisp", 11, NULL, &skip_args);
1316 #ifdef HAVE_NS
1317 ns_alloc_autorelease_pool();
1318 if (!noninteractive)
1320 #ifdef NS_IMPL_COCOA
1321 if (skip_args < argc)
1323 /* FIXME: Do the right thing if getenv returns NULL, or if
1324 chdir fails. */
1325 if (!strncmp(argv[skip_args], "-psn", 4))
1327 skip_args += 1;
1328 chdir (getenv ("HOME"));
1330 else if (skip_args+1 < argc && !strncmp(argv[skip_args+1], "-psn", 4))
1332 skip_args += 2;
1333 chdir (getenv ("HOME"));
1336 #endif /* COCOA */
1338 #endif /* HAVE_NS */
1340 #ifdef HAVE_X_WINDOWS
1341 /* Stupid kludge to catch command-line display spec. We can't
1342 handle this argument entirely in window system dependent code
1343 because we don't even know which window system dependent code
1344 to run until we've recognized this argument. */
1346 char *displayname = 0;
1347 int count_before = skip_args;
1349 /* Skip any number of -d options, but only use the last one. */
1350 while (1)
1352 int count_before_this = skip_args;
1354 if (argmatch (argv, argc, "-d", "--display", 3, &displayname, &skip_args))
1355 display_arg = 1;
1356 else if (argmatch (argv, argc, "-display", 0, 3, &displayname, &skip_args))
1357 display_arg = 1;
1358 else
1359 break;
1361 count_before = count_before_this;
1364 /* If we have the form --display=NAME,
1365 convert it into -d name.
1366 This requires inserting a new element into argv. */
1367 if (displayname && count_before < skip_args)
1369 if (skip_args == count_before + 1)
1371 memmove (argv + count_before + 3, argv + count_before + 2,
1372 (argc - (count_before + 2)) * sizeof *argv);
1373 argv[count_before + 2] = displayname;
1374 argc++;
1376 argv[count_before + 1] = (char *) "-d";
1379 if (! no_site_lisp)
1381 if (argmatch (argv, argc, "-Q", "--quick", 3, NULL, &skip_args)
1382 || argmatch (argv, argc, "-quick", 0, 2, NULL, &skip_args))
1383 no_site_lisp = 1;
1386 /* Don't actually discard this arg. */
1387 skip_args = count_before;
1389 #else /* !HAVE_X_WINDOWS */
1390 if (! no_site_lisp)
1392 int count_before = skip_args;
1394 if (argmatch (argv, argc, "-Q", "--quick", 3, NULL, &skip_args)
1395 || argmatch (argv, argc, "-quick", 0, 2, NULL, &skip_args))
1396 no_site_lisp = 1;
1398 skip_args = count_before;
1400 #endif
1402 /* argmatch must not be used after here,
1403 except when bulding temacs
1404 because the -d argument has not been skipped in skip_args. */
1406 #ifdef MSDOS
1407 /* Call early 'cause init_environment needs it. */
1408 init_dosfns ();
1409 /* Set defaults for several environment variables. */
1410 if (initialized)
1411 init_environment (argc, argv, skip_args);
1412 else
1413 tzset ();
1414 #endif /* MSDOS */
1416 #ifdef WINDOWSNT
1417 globals_of_w32 ();
1418 /* Initialize environment from registry settings. */
1419 init_environment (argv);
1420 init_ntproc (); /* must precede init_editfns. */
1421 #endif
1423 #ifdef HAVE_NS
1424 #ifndef CANNOT_DUMP
1425 if (initialized)
1426 #endif
1427 ns_init_paths ();
1428 #endif
1430 /* Initialize and GC-protect Vinitial_environment and
1431 Vprocess_environment before set_initial_environment fills them
1432 in. */
1433 if (!initialized)
1434 syms_of_callproc ();
1435 /* egetenv is a pretty low-level facility, which may get called in
1436 many circumstances; it seems flimsy to put off initializing it
1437 until calling init_callproc. Do not do it when dumping. */
1438 if (initialized || ((strcmp (argv[argc-1], "dump") != 0
1439 && strcmp (argv[argc-1], "bootstrap") != 0)))
1440 set_initial_environment ();
1442 /* AIX crashes are reported in system versions 3.2.3 and 3.2.4
1443 if this is not done. Do it after set_global_environment so that we
1444 don't pollute Vglobal_environment. */
1445 /* Setting LANG here will defeat the startup locale processing... */
1446 #ifdef AIX
1447 putenv ("LANG=C");
1448 #endif
1450 init_buffer (); /* Init default directory of main buffer. */
1452 init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */
1453 init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */
1455 if (initialized)
1457 /* Erase any pre-dump messages in the message log, to avoid confusion. */
1458 Lisp_Object old_log_max;
1459 old_log_max = Vmessage_log_max;
1460 XSETFASTINT (Vmessage_log_max, 0);
1461 message_dolog ("", 0, 1, 0);
1462 Vmessage_log_max = old_log_max;
1465 init_callproc (); /* Must follow init_cmdargs but not init_sys_modes. */
1466 init_lread ();
1468 /* Intern the names of all standard functions and variables;
1469 define standard keys. */
1471 if (!initialized)
1473 /* The basic levels of Lisp must come first. Note that
1474 syms_of_data and some others have already been called. */
1475 syms_of_chartab ();
1476 syms_of_lread ();
1477 syms_of_print ();
1478 syms_of_eval ();
1479 syms_of_fns ();
1480 syms_of_floatfns ();
1482 syms_of_buffer ();
1483 syms_of_bytecode ();
1484 syms_of_callint ();
1485 syms_of_casefiddle ();
1486 syms_of_casetab ();
1487 syms_of_category ();
1488 syms_of_ccl ();
1489 syms_of_character ();
1490 syms_of_cmds ();
1491 syms_of_dired ();
1492 syms_of_display ();
1493 syms_of_doc ();
1494 syms_of_editfns ();
1495 syms_of_emacs ();
1496 syms_of_filelock ();
1497 syms_of_indent ();
1498 syms_of_insdel ();
1499 /* syms_of_keymap (); */
1500 syms_of_macros ();
1501 syms_of_marker ();
1502 syms_of_minibuf ();
1503 syms_of_process ();
1504 syms_of_search ();
1505 syms_of_frame ();
1506 syms_of_syntax ();
1507 syms_of_terminal ();
1508 syms_of_term ();
1509 syms_of_undo ();
1510 #ifdef HAVE_SOUND
1511 syms_of_sound ();
1512 #endif
1513 syms_of_textprop ();
1514 syms_of_composite ();
1515 #ifdef WINDOWSNT
1516 syms_of_ntproc ();
1517 #endif /* WINDOWSNT */
1518 syms_of_window ();
1519 syms_of_xdisp ();
1520 syms_of_font ();
1521 #ifdef HAVE_WINDOW_SYSTEM
1522 syms_of_fringe ();
1523 syms_of_image ();
1524 #endif /* HAVE_WINDOW_SYSTEM */
1525 #ifdef HAVE_X_WINDOWS
1526 syms_of_xterm ();
1527 syms_of_xfns ();
1528 syms_of_xmenu ();
1529 syms_of_fontset ();
1530 syms_of_xsettings ();
1531 #ifdef HAVE_X_SM
1532 syms_of_xsmfns ();
1533 #endif
1534 #ifdef HAVE_X11
1535 syms_of_xselect ();
1536 #endif
1537 #endif /* HAVE_X_WINDOWS */
1539 #ifdef HAVE_LIBXML2
1540 syms_of_xml ();
1541 #endif
1543 syms_of_menu ();
1545 #ifdef HAVE_NTGUI
1546 syms_of_w32term ();
1547 syms_of_w32fns ();
1548 syms_of_w32select ();
1549 syms_of_w32menu ();
1550 syms_of_fontset ();
1551 #endif /* HAVE_NTGUI */
1553 #ifdef MSDOS
1554 syms_of_xmenu ();
1555 syms_of_dosfns();
1556 syms_of_msdos();
1557 syms_of_win16select();
1558 #endif /* MSDOS */
1560 #ifdef HAVE_NS
1561 syms_of_nsterm ();
1562 syms_of_nsfns ();
1563 syms_of_nsmenu ();
1564 syms_of_nsselect ();
1565 syms_of_fontset ();
1566 #endif /* HAVE_NS */
1568 #ifdef HAVE_GNUTLS
1569 syms_of_gnutls ();
1570 #endif
1572 #ifdef HAVE_DBUS
1573 syms_of_dbusbind ();
1574 #endif /* HAVE_DBUS */
1576 #ifdef WINDOWSNT
1577 syms_of_ntterm ();
1578 #endif /* WINDOWSNT */
1580 keys_of_casefiddle ();
1581 keys_of_cmds ();
1582 keys_of_buffer ();
1583 keys_of_keyboard ();
1584 keys_of_keymap ();
1585 keys_of_window ();
1587 else
1589 /* Initialization that must be done even if the global variable
1590 initialized is non zero. */
1591 #ifdef HAVE_NTGUI
1592 globals_of_w32fns ();
1593 globals_of_w32menu ();
1594 globals_of_w32select ();
1595 #endif /* HAVE_NTGUI */
1598 init_charset ();
1600 init_editfns (); /* init_process uses Voperating_system_release. */
1601 init_process (); /* init_display uses add_keyboard_wait_descriptor. */
1602 init_keyboard (); /* This too must precede init_sys_modes. */
1603 if (!noninteractive)
1604 init_display (); /* Determine terminal type. Calls init_sys_modes. */
1605 init_fns ();
1606 init_xdisp ();
1607 #ifdef HAVE_WINDOW_SYSTEM
1608 init_fringe ();
1609 init_image ();
1610 #endif /* HAVE_WINDOW_SYSTEM */
1611 init_macros ();
1612 init_floatfns ();
1613 #ifdef HAVE_SOUND
1614 init_sound ();
1615 #endif
1616 init_window ();
1617 init_font ();
1619 if (!initialized)
1621 char *file;
1622 /* Handle -l loadup, args passed by Makefile. */
1623 if (argmatch (argv, argc, "-l", "--load", 3, &file, &skip_args))
1624 Vtop_level = Fcons (intern_c_string ("load"),
1625 Fcons (build_string (file), Qnil));
1626 /* Unless next switch is -nl, load "loadup.el" first thing. */
1627 if (! no_loadup)
1628 Vtop_level = Fcons (intern_c_string ("load"),
1629 Fcons (build_string ("loadup.el"), Qnil));
1632 if (initialized)
1634 #ifdef HAVE_TZSET
1636 /* If the execution TZ happens to be the same as the dump TZ,
1637 change it to some other value and then change it back,
1638 to force the underlying implementation to reload the TZ info.
1639 This is needed on implementations that load TZ info from files,
1640 since the TZ file contents may differ between dump and execution. */
1641 char *tz = getenv ("TZ");
1642 if (tz && !strcmp (tz, dump_tz))
1644 ++*tz;
1645 tzset ();
1646 --*tz;
1649 #endif
1652 /* Set up for profiling. This is known to work on FreeBSD,
1653 GNU/Linux and MinGW. It might work on some other systems too.
1654 Give it a try and tell us if it works on your system. To compile
1655 for profiling, use the configure option --enable-profiling. */
1656 #if defined (__FreeBSD__) || defined (GNU_LINUX) || defined(__MINGW32__)
1657 #ifdef PROFILING
1658 if (initialized)
1660 extern void _mcleanup ();
1661 #ifdef __MINGW32__
1662 extern unsigned char etext asm ("etext");
1663 #else
1664 extern char etext;
1665 #endif
1666 #ifdef HAVE___EXECUTABLE_START
1667 /* This symbol is defined by GNU ld to the start of the text
1668 segment. */
1669 extern char __executable_start[];
1670 #else
1671 extern void safe_bcopy ();
1672 #endif
1674 atexit (_mcleanup);
1675 #ifdef HAVE___EXECUTABLE_START
1676 monstartup (__executable_start, &etext);
1677 #else
1678 /* This uses safe_bcopy because that function comes first in the
1679 Emacs executable. It might be better to use something that
1680 gives the start of the text segment, but start_of_text is not
1681 defined on all systems now. */
1682 /* FIXME: Does not work on architectures with function
1683 descriptors. */
1684 monstartup (safe_bcopy, &etext);
1685 #endif
1687 else
1688 moncontrol (0);
1689 #endif
1690 #endif
1692 initialized = 1;
1694 #ifdef LOCALTIME_CACHE
1695 /* Some versions of localtime have a bug. They cache the value of the time
1696 zone rather than looking it up every time. Since localtime() is
1697 called to bolt the undumping time into the undumped emacs, this
1698 results in localtime ignoring the TZ environment variable.
1699 This flushes the new TZ value into localtime. */
1700 tzset ();
1701 #endif /* defined (LOCALTIME_CACHE) */
1703 /* Enter editor command loop. This never returns. */
1704 Frecursive_edit ();
1705 /* NOTREACHED */
1706 return 0;
1709 /* Sort the args so we can find the most important ones
1710 at the beginning of argv. */
1712 /* First, here's a table of all the standard options. */
1714 struct standard_args
1716 const char *name;
1717 const char *longname;
1718 int priority;
1719 int nargs;
1722 static const struct standard_args standard_args[] =
1724 { "-version", "--version", 150, 0 },
1725 { "-chdir", "--chdir", 130, 1 },
1726 { "-t", "--terminal", 120, 1 },
1727 { "-nw", "--no-window-system", 110, 0 },
1728 { "-nw", "--no-windows", 110, 0 },
1729 { "-batch", "--batch", 100, 0 },
1730 { "-script", "--script", 100, 1 },
1731 { "-daemon", "--daemon", 99, 0 },
1732 { "-help", "--help", 90, 0 },
1733 { "-nl", "--no-loadup", 70, 0 },
1734 { "-nsl", "--no-site-lisp", 65, 0 },
1735 /* -d must come last before the options handled in startup.el. */
1736 { "-d", "--display", 60, 1 },
1737 { "-display", 0, 60, 1 },
1738 /* Now for the options handled in `command-line' (startup.el). */
1739 /* (Note that to imply -nsl, -Q is partially handled here.) */
1740 { "-Q", "--quick", 55, 0 },
1741 { "-quick", 0, 55, 0 },
1742 { "-q", "--no-init-file", 50, 0 },
1743 { "-no-init-file", 0, 50, 0 },
1744 { "-no-site-file", "--no-site-file", 40, 0 },
1745 { "-u", "--user", 30, 1 },
1746 { "-user", 0, 30, 1 },
1747 { "-debug-init", "--debug-init", 20, 0 },
1748 { "-iconic", "--iconic", 15, 0 },
1749 { "-D", "--basic-display", 12, 0},
1750 { "-basic-display", 0, 12, 0},
1751 { "-nbc", "--no-blinking-cursor", 12, 0 },
1752 /* Now for the options handled in `command-line-1' (startup.el). */
1753 { "-nbi", "--no-bitmap-icon", 10, 0 },
1754 { "-bg", "--background-color", 10, 1 },
1755 { "-background", 0, 10, 1 },
1756 { "-fg", "--foreground-color", 10, 1 },
1757 { "-foreground", 0, 10, 1 },
1758 { "-bd", "--border-color", 10, 1 },
1759 { "-bw", "--border-width", 10, 1 },
1760 { "-ib", "--internal-border", 10, 1 },
1761 { "-ms", "--mouse-color", 10, 1 },
1762 { "-cr", "--cursor-color", 10, 1 },
1763 { "-fn", "--font", 10, 1 },
1764 { "-font", 0, 10, 1 },
1765 { "-fs", "--fullscreen", 10, 0 },
1766 { "-fw", "--fullwidth", 10, 0 },
1767 { "-fh", "--fullheight", 10, 0 },
1768 { "-mm", "--maximized", 10, 0 },
1769 { "-g", "--geometry", 10, 1 },
1770 { "-geometry", 0, 10, 1 },
1771 { "-T", "--title", 10, 1 },
1772 { "-title", 0, 10, 1 },
1773 { "-name", "--name", 10, 1 },
1774 { "-xrm", "--xrm", 10, 1 },
1775 { "-parent-id", "--parent-id", 10, 1 },
1776 { "-r", "--reverse-video", 5, 0 },
1777 { "-rv", 0, 5, 0 },
1778 { "-reverse", 0, 5, 0 },
1779 { "-hb", "--horizontal-scroll-bars", 5, 0 },
1780 { "-vb", "--vertical-scroll-bars", 5, 0 },
1781 { "-color", "--color", 5, 0},
1782 { "-no-splash", "--no-splash", 3, 0 },
1783 { "-no-desktop", "--no-desktop", 3, 0 },
1784 #ifdef HAVE_NS
1785 { "-NSAutoLaunch", 0, 5, 1 },
1786 { "-NXAutoLaunch", 0, 5, 1 },
1787 { "-disable-font-backend", "--disable-font-backend", 65, 0 },
1788 { "-_NSMachLaunch", 0, 85, 1 },
1789 { "-MachLaunch", 0, 85, 1 },
1790 { "-macosx", 0, 85, 0 },
1791 { "-NSHost", 0, 85, 1 },
1792 #endif
1793 /* These have the same priority as ordinary file name args,
1794 so they are not reordered with respect to those. */
1795 { "-L", "--directory", 0, 1 },
1796 { "-directory", 0, 0, 1 },
1797 { "-l", "--load", 0, 1 },
1798 { "-load", 0, 0, 1 },
1799 /* This has no longname, because using --scriptload confuses sort_args,
1800 because then the --script long option seems to match twice; ie
1801 you can't have a long option which is a prefix of another long
1802 option. In any case, this is entirely an internal option. */
1803 { "-scriptload", NULL, 0, 1 },
1804 { "-f", "--funcall", 0, 1 },
1805 { "-funcall", 0, 0, 1 },
1806 { "-eval", "--eval", 0, 1 },
1807 { "-execute", "--execute", 0, 1 },
1808 { "-find-file", "--find-file", 0, 1 },
1809 { "-visit", "--visit", 0, 1 },
1810 { "-file", "--file", 0, 1 },
1811 { "-insert", "--insert", 0, 1 },
1812 #ifdef HAVE_NS
1813 { "-NXOpen", 0, 0, 1 },
1814 { "-NXOpenTemp", 0, 0, 1 },
1815 { "-NSOpen", 0, 0, 1 },
1816 { "-NSOpenTemp", 0, 0, 1 },
1817 { "-GSFilePath", 0, 0, 1 },
1818 #endif
1819 /* This should be processed after ordinary file name args and the like. */
1820 { "-kill", "--kill", -10, 0 },
1823 /* Reorder the elements of ARGV (assumed to have ARGC elements)
1824 so that the highest priority ones come first.
1825 Do not change the order of elements of equal priority.
1826 If an option takes an argument, keep it and its argument together.
1828 If an option that takes no argument appears more
1829 than once, eliminate all but one copy of it. */
1831 static void
1832 sort_args (int argc, char **argv)
1834 char **new = (char **) xmalloc (sizeof (char *) * argc);
1835 /* For each element of argv,
1836 the corresponding element of options is:
1837 0 for an option that takes no arguments,
1838 1 for an option that takes one argument, etc.
1839 -1 for an ordinary non-option argument. */
1840 int *options = xnmalloc (argc, sizeof *options);
1841 int *priority = xnmalloc (argc, sizeof *priority);
1842 int to = 1;
1843 int incoming_used = 1;
1844 int from;
1845 int i;
1847 /* Categorize all the options,
1848 and figure out which argv elts are option arguments. */
1849 for (from = 1; from < argc; from++)
1851 options[from] = -1;
1852 priority[from] = 0;
1853 if (argv[from][0] == '-')
1855 int match;
1857 /* If we have found "--", don't consider
1858 any more arguments as options. */
1859 if (argv[from][1] == '-' && argv[from][2] == 0)
1861 /* Leave the "--", and everything following it, at the end. */
1862 for (; from < argc; from++)
1864 priority[from] = -100;
1865 options[from] = -1;
1867 break;
1870 /* Look for a match with a known old-fashioned option. */
1871 for (i = 0; i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1872 if (!strcmp (argv[from], standard_args[i].name))
1874 options[from] = standard_args[i].nargs;
1875 priority[from] = standard_args[i].priority;
1876 if (from + standard_args[i].nargs >= argc)
1877 fatal ("Option `%s' requires an argument\n", argv[from]);
1878 from += standard_args[i].nargs;
1879 goto done;
1882 /* Look for a match with a known long option.
1883 MATCH is -1 if no match so far, -2 if two or more matches so far,
1884 >= 0 (the table index of the match) if just one match so far. */
1885 if (argv[from][1] == '-')
1887 char const *equals = strchr (argv[from], '=');
1888 ptrdiff_t thislen =
1889 equals ? equals - argv[from] : strlen (argv[from]);
1891 match = -1;
1893 for (i = 0;
1894 i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1895 if (standard_args[i].longname
1896 && !strncmp (argv[from], standard_args[i].longname,
1897 thislen))
1899 if (match == -1)
1900 match = i;
1901 else
1902 match = -2;
1905 /* If we found exactly one match, use that. */
1906 if (match >= 0)
1908 options[from] = standard_args[match].nargs;
1909 priority[from] = standard_args[match].priority;
1910 /* If --OPTION=VALUE syntax is used,
1911 this option uses just one argv element. */
1912 if (equals != 0)
1913 options[from] = 0;
1914 if (from + options[from] >= argc)
1915 fatal ("Option `%s' requires an argument\n", argv[from]);
1916 from += options[from];
1918 /* FIXME When match < 0, shouldn't there be some error,
1919 or at least indication to the user that there was a
1920 problem? */
1922 done: ;
1926 /* Copy the arguments, in order of decreasing priority, to NEW. */
1927 new[0] = argv[0];
1928 while (incoming_used < argc)
1930 int best = -1;
1931 int best_priority = -9999;
1933 /* Find the highest priority remaining option.
1934 If several have equal priority, take the first of them. */
1935 for (from = 1; from < argc; from++)
1937 if (argv[from] != 0 && priority[from] > best_priority)
1939 best_priority = priority[from];
1940 best = from;
1942 /* Skip option arguments--they are tied to the options. */
1943 if (options[from] > 0)
1944 from += options[from];
1947 if (best < 0)
1948 abort ();
1950 /* Copy the highest priority remaining option, with its args, to NEW.
1951 Unless it is a duplicate of the previous one. */
1952 if (! (options[best] == 0
1953 && ! strcmp (new[to - 1], argv[best])))
1955 new[to++] = argv[best];
1956 for (i = 0; i < options[best]; i++)
1957 new[to++] = argv[best + i + 1];
1960 incoming_used += 1 + (options[best] > 0 ? options[best] : 0);
1962 /* Clear out this option in ARGV. */
1963 argv[best] = 0;
1964 for (i = 0; i < options[best]; i++)
1965 argv[best + i + 1] = 0;
1968 /* If duplicate options were deleted, fill up extra space with null ptrs. */
1969 while (to < argc)
1970 new[to++] = 0;
1972 memcpy (argv, new, sizeof (char *) * argc);
1974 xfree (options);
1975 xfree (new);
1976 xfree (priority);
1979 DEFUN ("kill-emacs", Fkill_emacs, Skill_emacs, 0, 1, "P",
1980 doc: /* Exit the Emacs job and kill it.
1981 If ARG is an integer, return ARG as the exit program code.
1982 If ARG is a string, stuff it as keyboard input.
1984 This function is called upon receipt of the signals SIGTERM
1985 or SIGHUP, and upon SIGINT in batch mode.
1987 The value of `kill-emacs-hook', if not void,
1988 is a list of functions (of no args),
1989 all of which are called before Emacs is actually killed. */)
1990 (Lisp_Object arg)
1992 struct gcpro gcpro1;
1993 Lisp_Object hook;
1995 GCPRO1 (arg);
1997 if (feof (stdin))
1998 arg = Qt;
2000 hook = intern ("kill-emacs-hook");
2001 Frun_hooks (1, &hook);
2003 UNGCPRO;
2005 #ifdef HAVE_X_WINDOWS
2006 /* Transfer any clipboards we own to the clipboard manager. */
2007 x_clipboard_manager_save_all ();
2008 #endif
2010 shut_down_emacs (0, 0, STRINGP (arg) ? arg : Qnil);
2012 /* If we have an auto-save list file,
2013 kill it because we are exiting Emacs deliberately (not crashing).
2014 Do it after shut_down_emacs, which does an auto-save. */
2015 if (STRINGP (Vauto_save_list_file_name))
2016 unlink (SSDATA (Vauto_save_list_file_name));
2018 exit (INTEGERP (arg) ? XINT (arg) : EXIT_SUCCESS);
2022 /* Perform an orderly shutdown of Emacs. Autosave any modified
2023 buffers, kill any child processes, clean up the terminal modes (if
2024 we're in the foreground), and other stuff like that. Don't perform
2025 any redisplay; this may be called when Emacs is shutting down in
2026 the background, or after its X connection has died.
2028 If SIG is a signal number, print a message for it.
2030 This is called by fatal signal handlers, X protocol error handlers,
2031 and Fkill_emacs. */
2033 void
2034 shut_down_emacs (int sig, int no_x, Lisp_Object stuff)
2036 /* Prevent running of hooks from now on. */
2037 Vrun_hooks = Qnil;
2039 /* Don't update display from now on. */
2040 Vinhibit_redisplay = Qt;
2042 /* If we are controlling the terminal, reset terminal modes. */
2043 #ifndef DOS_NT
2045 int pgrp = EMACS_GETPGRP (0);
2046 int tpgrp = tcgetpgrp (0);
2047 if ((tpgrp != -1) && tpgrp == pgrp)
2049 reset_all_sys_modes ();
2050 if (sig && sig != SIGTERM)
2051 fprintf (stderr, "Fatal error (%d)", sig);
2054 #else
2055 fflush (stdout);
2056 reset_all_sys_modes ();
2057 #endif
2059 stuff_buffered_input (stuff);
2061 inhibit_sentinels = 1;
2062 kill_buffer_processes (Qnil);
2063 Fdo_auto_save (Qt, Qnil);
2065 #ifdef CLASH_DETECTION
2066 unlock_all_files ();
2067 #endif
2069 #if 0 /* This triggers a bug in XCloseDisplay and is not needed. */
2070 #ifdef HAVE_X_WINDOWS
2071 /* It's not safe to call intern here. Maybe we are crashing. */
2072 if (!noninteractive && SYMBOLP (Vinitial_window_system)
2073 && SCHARS (SYMBOL_NAME (Vinitial_window_system)) == 1
2074 && SREF (SYMBOL_NAME (Vinitial_window_system), 0) == 'x'
2075 && ! no_x)
2076 Fx_close_current_connection ();
2077 #endif /* HAVE_X_WINDOWS */
2078 #endif
2080 #ifdef SIGIO
2081 /* There is a tendency for a SIGIO signal to arrive within exit,
2082 and cause a SIGHUP because the input descriptor is already closed. */
2083 unrequest_sigio ();
2084 signal (SIGIO, SIG_IGN);
2085 #endif
2087 #ifdef WINDOWSNT
2088 term_ntproc ();
2089 #endif
2091 /* Do this only if terminating normally, we want glyph matrices
2092 etc. in a core dump. */
2093 if (sig == 0 || sig == SIGTERM)
2095 check_glyph_memory ();
2096 check_message_stack ();
2099 #ifdef MSDOS
2100 dos_cleanup ();
2101 #endif
2103 #ifdef HAVE_NS
2104 ns_term_shutdown (sig);
2105 #endif
2107 #ifdef HAVE_LIBXML2
2108 xmlCleanupParser ();
2109 #endif
2114 #ifndef CANNOT_DUMP
2116 #include "unexec.h"
2118 DEFUN ("dump-emacs", Fdump_emacs, Sdump_emacs, 2, 2, 0,
2119 doc: /* Dump current state of Emacs into executable file FILENAME.
2120 Take symbols from SYMFILE (presumably the file you executed to run Emacs).
2121 This is used in the file `loadup.el' when building Emacs.
2123 You must run Emacs in batch mode in order to dump it. */)
2124 (Lisp_Object filename, Lisp_Object symfile)
2126 Lisp_Object tem;
2127 Lisp_Object symbol;
2128 int count = SPECPDL_INDEX ();
2130 check_pure_size ();
2132 if (! noninteractive)
2133 error ("Dumping Emacs works only in batch mode");
2135 #ifdef GNU_LINUX
2137 /* Warn if the gap between BSS end and heap start is larger than this. */
2138 # define MAX_HEAP_BSS_DIFF (1024*1024)
2140 if (heap_bss_diff > MAX_HEAP_BSS_DIFF)
2142 fprintf (stderr, "**************************************************\n");
2143 fprintf (stderr, "Warning: Your system has a gap between BSS and the\n");
2144 fprintf (stderr, "heap (%"pMu" bytes). This usually means that exec-shield\n",
2145 heap_bss_diff);
2146 fprintf (stderr, "or something similar is in effect. The dump may\n");
2147 fprintf (stderr, "fail because of this. See the section about\n");
2148 fprintf (stderr, "exec-shield in etc/PROBLEMS for more information.\n");
2149 fprintf (stderr, "**************************************************\n");
2151 #endif /* GNU_LINUX */
2153 /* Bind `command-line-processed' to nil before dumping,
2154 so that the dumped Emacs will process its command line
2155 and set up to work with X windows if appropriate. */
2156 symbol = intern ("command-line-processed");
2157 specbind (symbol, Qnil);
2159 CHECK_STRING (filename);
2160 filename = Fexpand_file_name (filename, Qnil);
2161 if (!NILP (symfile))
2163 CHECK_STRING (symfile);
2164 if (SCHARS (symfile))
2165 symfile = Fexpand_file_name (symfile, Qnil);
2168 tem = Vpurify_flag;
2169 Vpurify_flag = Qnil;
2171 #ifdef HAVE_TZSET
2172 set_time_zone_rule (dump_tz);
2173 #ifndef LOCALTIME_CACHE
2174 /* Force a tz reload, since set_time_zone_rule doesn't. */
2175 tzset ();
2176 #endif
2177 #endif
2179 fflush (stdout);
2180 /* Tell malloc where start of impure now is. */
2181 /* Also arrange for warnings when nearly out of space. */
2182 #ifndef SYSTEM_MALLOC
2183 #ifndef WINDOWSNT
2184 /* On Windows, this was done before dumping, and that once suffices.
2185 Meanwhile, my_edata is not valid on Windows. */
2187 extern char my_edata[];
2188 memory_warnings (my_edata, malloc_warning);
2190 #endif /* not WINDOWSNT */
2191 #if defined (HAVE_PTHREAD) && !defined SYNC_INPUT
2192 /* Pthread may call malloc before main, and then we will get an endless
2193 loop, because pthread_self (see alloc.c) calls malloc the first time
2194 it is called on some systems. */
2195 reset_malloc_hooks ();
2196 #endif
2197 #endif /* not SYSTEM_MALLOC */
2198 #ifdef DOUG_LEA_MALLOC
2199 malloc_state_ptr = malloc_get_state ();
2200 #endif
2202 #ifdef USE_MMAP_FOR_BUFFERS
2203 mmap_set_vars (0);
2204 #endif
2205 unexec (SSDATA (filename), !NILP (symfile) ? SSDATA (symfile) : 0);
2206 #ifdef USE_MMAP_FOR_BUFFERS
2207 mmap_set_vars (1);
2208 #endif
2209 #ifdef DOUG_LEA_MALLOC
2210 free (malloc_state_ptr);
2211 #endif
2213 Vpurify_flag = tem;
2215 return unbind_to (count, Qnil);
2218 #endif /* not CANNOT_DUMP */
2220 #if HAVE_SETLOCALE
2221 /* Recover from setlocale (LC_ALL, ""). */
2222 void
2223 fixup_locale (void)
2225 /* The Emacs Lisp reader needs LC_NUMERIC to be "C",
2226 so that numbers are read and printed properly for Emacs Lisp. */
2227 setlocale (LC_NUMERIC, "C");
2230 /* Set system locale CATEGORY, with previous locale *PLOCALE, to
2231 DESIRED_LOCALE. */
2232 static void
2233 synchronize_locale (int category, Lisp_Object *plocale, Lisp_Object desired_locale)
2235 if (! EQ (*plocale, desired_locale))
2237 *plocale = desired_locale;
2238 setlocale (category, (STRINGP (desired_locale)
2239 ? SSDATA (desired_locale)
2240 : ""));
2244 /* Set system time locale to match Vsystem_time_locale, if possible. */
2245 void
2246 synchronize_system_time_locale (void)
2248 synchronize_locale (LC_TIME, &Vprevious_system_time_locale,
2249 Vsystem_time_locale);
2252 /* Set system messages locale to match Vsystem_messages_locale, if
2253 possible. */
2254 void
2255 synchronize_system_messages_locale (void)
2257 #ifdef LC_MESSAGES
2258 synchronize_locale (LC_MESSAGES, &Vprevious_system_messages_locale,
2259 Vsystem_messages_locale);
2260 #endif
2262 #endif /* HAVE_SETLOCALE */
2264 #ifndef SEPCHAR
2265 #define SEPCHAR ':'
2266 #endif
2268 Lisp_Object
2269 decode_env_path (const char *evarname, const char *defalt)
2271 const char *path, *p;
2272 Lisp_Object lpath, element, tem;
2274 /* It's okay to use getenv here, because this function is only used
2275 to initialize variables when Emacs starts up, and isn't called
2276 after that. */
2277 if (evarname != 0)
2278 path = getenv (evarname);
2279 else
2280 path = 0;
2281 if (!path)
2282 path = defalt;
2283 #ifdef DOS_NT
2284 /* Ensure values from the environment use the proper directory separator. */
2285 if (path)
2287 char *path_copy = alloca (strlen (path) + 1);
2288 strcpy (path_copy, path);
2289 dostounix_filename (path_copy);
2290 path = path_copy;
2292 #endif
2293 lpath = Qnil;
2294 while (1)
2296 p = strchr (path, SEPCHAR);
2297 if (!p)
2298 p = path + strlen (path);
2299 element = (p - path ? make_string (path, p - path)
2300 : build_string ("."));
2302 /* Add /: to the front of the name
2303 if it would otherwise be treated as magic. */
2304 tem = Ffind_file_name_handler (element, Qt);
2306 /* However, if the handler says "I'm safe",
2307 don't bother adding /:. */
2308 if (SYMBOLP (tem))
2310 Lisp_Object prop;
2311 prop = Fget (tem, intern ("safe-magic"));
2312 if (! NILP (prop))
2313 tem = Qnil;
2316 if (! NILP (tem))
2317 element = concat2 (build_string ("/:"), element);
2319 lpath = Fcons (element, lpath);
2320 if (*p)
2321 path = p + 1;
2322 else
2323 break;
2325 return Fnreverse (lpath);
2328 DEFUN ("daemonp", Fdaemonp, Sdaemonp, 0, 0, 0,
2329 doc: /* Return non-nil if the current emacs process is a daemon.
2330 If the daemon was given a name argument, return that name. */)
2331 (void)
2333 if (IS_DAEMON)
2334 if (daemon_name)
2335 return build_string (daemon_name);
2336 else
2337 return Qt;
2338 else
2339 return Qnil;
2342 DEFUN ("daemon-initialized", Fdaemon_initialized, Sdaemon_initialized, 0, 0, 0,
2343 doc: /* Mark the Emacs daemon as being initialized.
2344 This finishes the daemonization process by doing the other half of detaching
2345 from the parent process and its tty file descriptors. */)
2346 (void)
2348 int nfd;
2349 int err = 0;
2351 if (!IS_DAEMON)
2352 error ("This function can only be called if emacs is run as a daemon");
2354 if (daemon_pipe[1] < 0)
2355 error ("The daemon has already been initialized");
2357 if (NILP (Vafter_init_time))
2358 error ("This function can only be called after loading the init files");
2360 /* Get rid of stdin, stdout and stderr. */
2361 nfd = open ("/dev/null", O_RDWR);
2362 err |= nfd < 0;
2363 err |= dup2 (nfd, 0) < 0;
2364 err |= dup2 (nfd, 1) < 0;
2365 err |= dup2 (nfd, 2) < 0;
2366 err |= close (nfd) != 0;
2368 /* Closing the pipe will notify the parent that it can exit.
2369 FIXME: In case some other process inherited the pipe, closing it here
2370 won't notify the parent because it's still open elsewhere, so we
2371 additionally send a byte, just to make sure the parent really exits.
2372 Instead, we should probably close the pipe in start-process and
2373 call-process to make sure the pipe is never inherited by
2374 subprocesses. */
2375 err |= write (daemon_pipe[1], "\n", 1) < 0;
2376 err |= close (daemon_pipe[1]) != 0;
2377 /* Set it to an invalid value so we know we've already run this function. */
2378 daemon_pipe[1] = -1;
2380 if (err)
2381 error ("I/O error during daemon initialization");
2382 return Qt;
2385 void
2386 syms_of_emacs (void)
2388 DEFSYM (Qfile_name_handler_alist, "file-name-handler-alist");
2389 DEFSYM (Qrisky_local_variable, "risky-local-variable");
2391 #ifndef CANNOT_DUMP
2392 defsubr (&Sdump_emacs);
2393 #endif
2395 defsubr (&Skill_emacs);
2397 defsubr (&Sinvocation_name);
2398 defsubr (&Sinvocation_directory);
2399 defsubr (&Sdaemonp);
2400 defsubr (&Sdaemon_initialized);
2402 DEFVAR_LISP ("command-line-args", Vcommand_line_args,
2403 doc: /* Args passed by shell to Emacs, as a list of strings.
2404 Many arguments are deleted from the list as they are processed. */);
2406 DEFVAR_LISP ("system-type", Vsystem_type,
2407 doc: /* The value is a symbol indicating the type of operating system you are using.
2408 Special values:
2409 `gnu' compiled for a GNU Hurd system.
2410 `gnu/linux' compiled for a GNU/Linux system.
2411 `gnu/kfreebsd' compiled for a GNU system with a FreeBSD kernel.
2412 `darwin' compiled for Darwin (GNU-Darwin, Mac OS X, ...).
2413 `ms-dos' compiled as an MS-DOS application.
2414 `windows-nt' compiled as a native W32 application.
2415 `cygwin' compiled using the Cygwin library.
2416 Anything else (in Emacs 24.1, the possibilities are: aix, berkeley-unix,
2417 hpux, irix, usg-unix-v) indicates some sort of Unix system. */);
2418 Vsystem_type = intern_c_string (SYSTEM_TYPE);
2419 /* The above values are from SYSTEM_TYPE in include files under src/s. */
2421 DEFVAR_LISP ("system-configuration", Vsystem_configuration,
2422 doc: /* Value is string indicating configuration Emacs was built for.
2423 On MS-Windows, the value reflects the OS flavor and version on which
2424 Emacs is running. */);
2425 Vsystem_configuration = build_string (EMACS_CONFIGURATION);
2427 DEFVAR_LISP ("system-configuration-options", Vsystem_configuration_options,
2428 doc: /* String containing the configuration options Emacs was built with. */);
2429 Vsystem_configuration_options = build_string (EMACS_CONFIG_OPTIONS);
2431 DEFVAR_BOOL ("noninteractive", noninteractive1,
2432 doc: /* Non-nil means Emacs is running without interactive terminal. */);
2434 DEFVAR_LISP ("kill-emacs-hook", Vkill_emacs_hook,
2435 doc: /* Hook to be run when `kill-emacs' is called.
2436 Since `kill-emacs' may be invoked when the terminal is disconnected (or
2437 in other similar situations), functions placed on this hook should not
2438 expect to be able to interact with the user. To ask for confirmation,
2439 see `kill-emacs-query-functions' instead.
2441 Before Emacs 24.1, the hook was not run in batch mode, i.e., if
2442 `noninteractive' was non-nil. */);
2443 Vkill_emacs_hook = Qnil;
2445 DEFVAR_LISP ("path-separator", Vpath_separator,
2446 doc: /* String containing the character that separates directories in
2447 search paths, such as PATH and other similar environment variables. */);
2449 char c = SEPCHAR;
2450 Vpath_separator = make_string (&c, 1);
2453 DEFVAR_LISP ("invocation-name", Vinvocation_name,
2454 doc: /* The program name that was used to run Emacs.
2455 Any directory names are omitted. */);
2457 DEFVAR_LISP ("invocation-directory", Vinvocation_directory,
2458 doc: /* The directory in which the Emacs executable was found, to run it.
2459 The value is nil if that directory's name is not known. */);
2461 DEFVAR_LISP ("installation-directory", Vinstallation_directory,
2462 doc: /* A directory within which to look for the `lib-src' and `etc' directories.
2463 This is non-nil when we can't find those directories in their standard
2464 installed locations, but we can find them near where the Emacs executable
2465 was found. */);
2466 Vinstallation_directory = Qnil;
2468 DEFVAR_LISP ("system-messages-locale", Vsystem_messages_locale,
2469 doc: /* System locale for messages. */);
2470 Vsystem_messages_locale = Qnil;
2472 DEFVAR_LISP ("previous-system-messages-locale",
2473 Vprevious_system_messages_locale,
2474 doc: /* Most recently used system locale for messages. */);
2475 Vprevious_system_messages_locale = Qnil;
2477 DEFVAR_LISP ("system-time-locale", Vsystem_time_locale,
2478 doc: /* System locale for time. */);
2479 Vsystem_time_locale = Qnil;
2481 DEFVAR_LISP ("previous-system-time-locale", Vprevious_system_time_locale,
2482 doc: /* Most recently used system locale for time. */);
2483 Vprevious_system_time_locale = Qnil;
2485 DEFVAR_LISP ("before-init-time", Vbefore_init_time,
2486 doc: /* Value of `current-time' before Emacs begins initialization. */);
2487 Vbefore_init_time = Qnil;
2489 DEFVAR_LISP ("after-init-time", Vafter_init_time,
2490 doc: /* Value of `current-time' after loading the init files.
2491 This is nil during initialization. */);
2492 Vafter_init_time = Qnil;
2494 DEFVAR_BOOL ("inhibit-x-resources", inhibit_x_resources,
2495 doc: /* If non-nil, X resources, Windows Registry settings, and NS defaults are not used. */);
2496 inhibit_x_resources = 0;
2498 DEFVAR_LISP ("emacs-copyright", Vemacs_copyright,
2499 doc: /* Short copyright string for this version of Emacs. */);
2500 Vemacs_copyright = build_string (emacs_copyright);
2502 DEFVAR_LISP ("emacs-version", Vemacs_version,
2503 doc: /* Version numbers of this version of Emacs. */);
2504 Vemacs_version = build_string (emacs_version);
2506 DEFVAR_LISP ("dynamic-library-alist", Vdynamic_library_alist,
2507 doc: /* Alist of dynamic libraries vs external files implementing them.
2508 Each element is a list (LIBRARY FILE...), where the car is a symbol
2509 representing a supported external library, and the rest are strings giving
2510 alternate filenames for that library.
2512 Emacs tries to load the library from the files in the order they appear on
2513 the list; if none is loaded, the running session of Emacs won't have access
2514 to that library.
2516 Note that image types `pbm' and `xbm' do not need entries in this variable
2517 because they do not depend on external libraries and are always available.
2519 Also note that this is not a generic facility for accessing external
2520 libraries; only those already known by Emacs will be loaded. */);
2521 Vdynamic_library_alist = Qnil;
2522 Fput (intern_c_string ("dynamic-library-alist"), Qrisky_local_variable, Qt);
2524 /* Make sure IS_DAEMON starts up as false. */
2525 daemon_pipe[1] = 0;