New function `locate-user-emacs-file'.
[emacs.git] / src / emacs.c
blob4712e9c1d0be1aa1e104387e1ca9b53f4bcbddc3
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
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>
30 #ifdef HAVE_UNISTD_H
31 #include <unistd.h>
32 #endif
34 #ifdef BSD_SYSTEM
35 #include <sys/ioctl.h>
36 #endif
38 #ifdef WINDOWSNT
39 #include <fcntl.h>
40 #include <windows.h> /* just for w32.h */
41 #include "w32.h"
42 #include "w32heap.h" /* for prototype of sbrk */
43 #endif
45 #ifdef NS_IMPL_GNUSTEP
46 /* At least under Debian, GSConfig is in a subdirectory. --Stef */
47 #include <GNUstepBase/GSConfig.h>
48 #endif
50 #include "lisp.h"
51 #include "commands.h"
52 #include "intervals.h"
53 #include "buffer.h"
54 #include "window.h"
56 #include "systty.h"
57 #include "blockinput.h"
58 #include "syssignal.h"
59 #include "process.h"
60 #include "frame.h"
61 #include "termhooks.h"
62 #include "keyboard.h"
63 #include "keymap.h"
65 #ifdef HAVE_SETLOCALE
66 #include <locale.h>
67 #endif
69 #ifdef HAVE_SETRLIMIT
70 #include <sys/time.h>
71 #include <sys/resource.h>
72 #endif
74 #ifdef HAVE_PERSONALITY_LINUX32
75 #include <sys/personality.h>
76 #endif
78 #ifndef O_RDWR
79 #define O_RDWR 2
80 #endif
82 #ifdef HAVE_SETPGID
83 #if !defined (USG) || defined (BSD_PGRPS)
84 #undef setpgrp
85 #define setpgrp setpgid
86 #endif
87 #endif
89 extern void malloc_warning P_ ((char *));
90 extern void set_time_zone_rule P_ ((char *));
91 #ifdef HAVE_INDEX
92 extern char *index P_ ((const char *, int));
93 #endif
95 /* Make these values available in GDB, which doesn't see macros. */
97 #ifdef USE_LSB_TAG
98 int gdb_use_lsb = 1;
99 #else
100 int gdb_use_lsb = 0;
101 #endif
102 #ifndef USE_LISP_UNION_TYPE
103 int gdb_use_union = 0;
104 #else
105 int gdb_use_union = 1;
106 #endif
107 EMACS_INT gdb_valbits = VALBITS;
108 EMACS_INT gdb_gctypebits = GCTYPEBITS;
109 #ifdef DATA_SEG_BITS
110 EMACS_INT gdb_data_seg_bits = DATA_SEG_BITS;
111 #else
112 EMACS_INT gdb_data_seg_bits = 0;
113 #endif
114 EMACS_INT PVEC_FLAG = PSEUDOVECTOR_FLAG;
115 EMACS_INT gdb_array_mark_flag = ARRAY_MARK_FLAG;
116 /* GDB might say "No enum type named pvec_type" if we don't have at
117 least one symbol with that type, and then xbacktrace could fail. */
118 enum pvec_type gdb_pvec_type = PVEC_TYPE_MASK;
120 /* Command line args from shell, as list of strings. */
121 Lisp_Object Vcommand_line_args;
123 /* The name under which Emacs was invoked, with any leading directory
124 names discarded. */
125 Lisp_Object Vinvocation_name;
127 /* The directory name from which Emacs was invoked. */
128 Lisp_Object Vinvocation_directory;
130 /* The directory name in which to find subdirs such as lisp and etc.
131 nil means get them only from PATH_LOADSEARCH. */
132 Lisp_Object Vinstallation_directory;
134 /* The values of `current-time' before and after Emacs initialization. */
135 Lisp_Object Vbefore_init_time, Vafter_init_time;
137 /* Hook run by `kill-emacs' before it does really anything. */
138 Lisp_Object Vkill_emacs_hook;
140 /* Empty lisp strings. To avoid having to build any others. */
141 Lisp_Object empty_unibyte_string, empty_multibyte_string;
143 /* Search path separator. */
144 Lisp_Object Vpath_separator;
146 /* Set nonzero after Emacs has started up the first time.
147 Prevents reinitialization of the Lisp world and keymaps
148 on subsequent starts. */
149 int initialized;
151 #ifdef DOUG_LEA_MALLOC
152 /* Preserves a pointer to the memory allocated that copies that
153 static data inside glibc's malloc. */
154 void *malloc_state_ptr;
155 /* From glibc, a routine that returns a copy of the malloc internal state. */
156 extern void *malloc_get_state ();
157 /* From glibc, a routine that overwrites the malloc internal state. */
158 extern int malloc_set_state ();
159 /* Non-zero if the MALLOC_CHECK_ enviroment variable was set while
160 dumping. Used to work around a bug in glibc's malloc. */
161 int malloc_using_checking;
162 #endif
164 /* Variable whose value is symbol giving operating system type. */
165 Lisp_Object Vsystem_type;
167 /* Variable whose value is string giving configuration built for. */
168 Lisp_Object Vsystem_configuration;
170 /* Variable whose value is string giving configuration options,
171 for use when reporting bugs. */
172 Lisp_Object Vsystem_configuration_options;
174 Lisp_Object Qfile_name_handler_alist;
176 /* Current and previous system locales for messages and time. */
177 Lisp_Object Vsystem_messages_locale;
178 Lisp_Object Vprevious_system_messages_locale;
179 Lisp_Object Vsystem_time_locale;
180 Lisp_Object Vprevious_system_time_locale;
182 /* If non-zero, emacs should not attempt to use a window-specific code,
183 but instead should use the virtual terminal under which it was started. */
184 int inhibit_window_system;
186 /* If nonzero, set Emacs to run at this priority. This is also used
187 in child_setup and sys_suspend to make sure subshells run at normal
188 priority; those functions have their own extern declaration. */
189 EMACS_INT emacs_priority;
191 /* If non-zero, a filter or a sentinel is running. Tested to save the match
192 data on the first attempt to change it inside asynchronous code. */
193 int running_asynch_code;
195 #ifdef BSD_PGRPS
196 /* See sysdep.c. */
197 extern int inherited_pgroup;
198 #endif
200 #if defined(HAVE_X_WINDOWS) || defined(HAVE_NS)
201 /* If non-zero, -d was specified, meaning we're using some window system. */
202 int display_arg;
203 #endif
205 /* An address near the bottom of the stack.
206 Tells GC how to save a copy of the stack. */
207 char *stack_bottom;
209 /* The address where the heap starts (from the first sbrk (0) call). */
210 static void *my_heap_start;
212 /* The gap between BSS end and heap start as far as we can tell. */
213 static unsigned long heap_bss_diff;
215 /* If the gap between BSS end and heap start is larger than this
216 output a warning in dump-emacs. */
217 #define MAX_HEAP_BSS_DIFF (1024*1024)
220 #ifdef HAVE_WINDOW_SYSTEM
221 extern Lisp_Object Vinitial_window_system;
222 #endif /* HAVE_WINDOW_SYSTEM */
224 extern Lisp_Object Vauto_save_list_file_name;
226 extern Lisp_Object Vinhibit_redisplay;
228 /* Nonzero means running Emacs without interactive terminal. */
230 int noninteractive;
232 /* Value of Lisp variable `noninteractive'.
233 Normally same as C variable `noninteractive'
234 but nothing terrible happens if user sets this one. */
236 int noninteractive1;
238 /* Nonzero means Emacs was started as a daemon. */
239 int is_daemon = 0;
241 /* Save argv and argc. */
242 char **initial_argv;
243 int initial_argc;
245 static void sort_args ();
246 void syms_of_emacs ();
248 /* MSVC needs each string be shorter than 2048 bytes, so the usage
249 strings below are split to not overflow this limit. */
250 #define USAGE1 "\
251 Usage: %s [OPTION-OR-FILENAME]...\n\
253 Run Emacs, the extensible, customizable, self-documenting real-time\n\
254 display editor. The recommended way to start Emacs for normal editing\n\
255 is with no options at all.\n\
257 Run M-x info RET m emacs RET m emacs invocation RET inside Emacs to\n\
258 read the main documentation for these command-line arguments.\n\
260 Initialization options:\n\
262 --batch do not do interactive display; implies -q\n\
263 --daemon start a server in the background\n\
264 --debug-init enable Emacs Lisp debugger for init file\n\
265 --display, -d DISPLAY use X server DISPLAY\n\
266 --multibyte, --no-unibyte inhibit the effect of EMACS_UNIBYTE\n\
267 --no-desktop do not load a saved desktop\n\
268 --no-init-file, -q load neither ~/.emacs nor default.el\n\
269 --no-shared-memory, -nl do not use shared memory\n\
270 --no-site-file do not load site-start.el\n\
271 --no-splash do not display a splash screen on startup\n\
272 --no-window-system, -nw do not communicate with X, ignoring $DISPLAY\n\
273 --quick, -Q equivalent to -q --no-site-file --no-splash\n\
274 --script FILE run FILE as an Emacs Lisp script\n\
275 --terminal, -t DEVICE use DEVICE for terminal I/O\n\
276 --unibyte, --no-multibyte run Emacs in unibyte mode\n\
277 --user, -u USER load ~USER/.emacs instead of your own\n\
278 \n%s"
280 #define USAGE2 "\
281 Action options:\n\
283 FILE visit FILE using find-file\n\
284 +LINE go to line LINE in next FILE\n\
285 +LINE:COLUMN go to line LINE, column COLUMN, in next FILE\n\
286 --directory, -L DIR add DIR to variable load-path\n\
287 --eval EXPR evaluate Emacs Lisp expression EXPR\n\
288 --execute EXPR evaluate Emacs Lisp expression EXPR\n\
289 --file FILE visit FILE using find-file\n\
290 --find-file FILE visit FILE using find-file\n\
291 --funcall, -f FUNC call Emacs Lisp function FUNC with no arguments\n\
292 --insert FILE insert contents of FILE into current buffer\n\
293 --kill exit without asking for confirmation\n\
294 --load, -l FILE load Emacs Lisp FILE using the load function\n\
295 --visit FILE visit FILE using find-file\n\
298 #define USAGE3 "\
299 Display options:\n\
301 --background-color, -bg COLOR window background color\n\
302 --basic-display, -D disable many display features;\n\
303 used for debugging Emacs\n\
304 --border-color, -bd COLOR main border color\n\
305 --border-width, -bw WIDTH width of main border\n\
306 --color, --color=MODE override color mode for character terminals;\n\
307 MODE defaults to `auto', and can also\n\
308 be `never', `auto', `always',\n\
309 or a mode name like `ansi8'\n\
310 --cursor-color, -cr COLOR color of the Emacs cursor indicating point\n\
311 --font, -fn FONT default font; must be fixed-width\n\
312 --foreground-color, -fg COLOR window foreground color\n\
313 --fullheight, -fh make the first frame high as the screen\n\
314 --fullscreen, -fs make first frame fullscreen\n\
315 --fullwidth, -fw make the first frame wide as the screen\n\
316 --geometry, -g GEOMETRY window geometry\n\
317 --no-bitmap-icon, -nbi do not use picture of gnu for Emacs icon\n\
318 --iconic start Emacs in iconified state\n\
319 --internal-border, -ib WIDTH width between text and main border\n\
320 --line-spacing, -lsp PIXELS additional space to put between lines\n\
321 --mouse-color, -ms COLOR mouse cursor color in Emacs window\n\
322 --name NAME title for initial Emacs frame\n\
323 --no-blinking-cursor, -nbc disable blinking cursor\n\
324 --reverse-video, -r, -rv switch foreground and background\n\
325 --title, -T TITLE title for initial Emacs frame\n\
326 --vertical-scroll-bars, -vb enable vertical scroll bars\n\
327 --xrm XRESOURCES set additional X resources\n\
328 --parent-id XID set parent window\n\
329 --help display this help and exit\n\
330 --version output version information and exit\n\
333 #define USAGE4 "\
334 You can generally also specify long option names with a single -; for\n\
335 example, -batch as well as --batch. You can use any unambiguous\n\
336 abbreviation for a --option.\n\
338 Various environment variables and window system resources also affect\n\
339 Emacs' operation. See the main documentation.\n\
341 Report bugs to %s. First, please see the Bugs\n\
342 section of the Emacs manual or the file BUGS.\n"
345 /* Signal code for the fatal signal that was received. */
346 int fatal_error_code;
348 /* Nonzero if handling a fatal error already. */
349 int fatal_error_in_progress;
351 /* If non-null, call this function from fatal_error_signal before
352 committing suicide. */
354 void (*fatal_error_signal_hook) P_ ((void));
356 #ifdef FORWARD_SIGNAL_TO_MAIN_THREAD
357 /* When compiled with GTK and running under Gnome,
358 multiple threads may be created. Keep track of our main
359 thread to make sure signals are delivered to it (see syssignal.h). */
361 pthread_t main_thread;
362 #endif
365 /* Handle bus errors, invalid instruction, etc. */
366 SIGTYPE
367 fatal_error_signal (sig)
368 int sig;
370 SIGNAL_THREAD_CHECK (sig);
371 fatal_error_code = sig;
372 signal (sig, SIG_DFL);
374 TOTALLY_UNBLOCK_INPUT;
376 /* If fatal error occurs in code below, avoid infinite recursion. */
377 if (! fatal_error_in_progress)
379 fatal_error_in_progress = 1;
381 shut_down_emacs (sig, 0, Qnil);
384 /* Signal the same code; this time it will really be fatal.
385 Remember that since we're in a signal handler, the signal we're
386 going to send is probably blocked, so we have to unblock it if we
387 want to really receive it. */
388 #ifndef MSDOS
389 sigunblock (sigmask (fatal_error_code));
390 #endif
392 if (fatal_error_signal_hook)
393 fatal_error_signal_hook ();
395 kill (getpid (), fatal_error_code);
398 #ifdef SIGDANGER
400 /* Handler for SIGDANGER. */
401 SIGTYPE
402 memory_warning_signal (sig)
403 int sig;
405 signal (sig, memory_warning_signal);
406 SIGNAL_THREAD_CHECK (sig);
408 malloc_warning ("Operating system warns that virtual memory is running low.\n");
410 /* It might be unsafe to call do_auto_save now. */
411 force_auto_save_soon ();
413 #endif
415 /* We define abort, rather than using it from the library,
416 so that GDB can return from a breakpoint here.
417 MSDOS has its own definition in msdos.c. */
419 #if ! defined (DOS_NT) && ! defined (NO_ABORT)
421 void
422 abort ()
424 kill (getpid (), SIGABRT);
425 /* This shouldn't be executed, but it prevents a warning. */
426 exit (1);
428 #endif
431 /* Code for dealing with Lisp access to the Unix command line. */
433 static void
434 init_cmdargs (argc, argv, skip_args)
435 int argc;
436 char **argv;
437 int skip_args;
439 register int i;
440 Lisp_Object name, dir, tem;
441 int count = SPECPDL_INDEX ();
442 Lisp_Object raw_name;
444 initial_argv = argv;
445 initial_argc = argc;
447 raw_name = build_string (argv[0]);
449 /* Add /: to the front of the name
450 if it would otherwise be treated as magic. */
451 tem = Ffind_file_name_handler (raw_name, Qt);
452 if (! NILP (tem))
453 raw_name = concat2 (build_string ("/:"), raw_name);
455 Vinvocation_name = Ffile_name_nondirectory (raw_name);
456 Vinvocation_directory = Ffile_name_directory (raw_name);
458 /* If we got no directory in argv[0], search PATH to find where
459 Emacs actually came from. */
460 if (NILP (Vinvocation_directory))
462 Lisp_Object found;
463 int yes = openp (Vexec_path, Vinvocation_name,
464 Vexec_suffixes, &found, make_number (X_OK));
465 if (yes == 1)
467 /* Add /: to the front of the name
468 if it would otherwise be treated as magic. */
469 tem = Ffind_file_name_handler (found, Qt);
470 if (! NILP (tem))
471 found = concat2 (build_string ("/:"), found);
472 Vinvocation_directory = Ffile_name_directory (found);
476 if (!NILP (Vinvocation_directory)
477 && NILP (Ffile_name_absolute_p (Vinvocation_directory)))
478 /* Emacs was started with relative path, like ./emacs.
479 Make it absolute. */
480 Vinvocation_directory = Fexpand_file_name (Vinvocation_directory, Qnil);
482 Vinstallation_directory = Qnil;
484 if (!NILP (Vinvocation_directory))
486 dir = Vinvocation_directory;
487 name = Fexpand_file_name (Vinvocation_name, dir);
488 while (1)
490 Lisp_Object tem, lib_src_exists;
491 Lisp_Object etc_exists, info_exists;
493 /* See if dir contains subdirs for use by Emacs.
494 Check for the ones that would exist in a build directory,
495 not including lisp and info. */
496 tem = Fexpand_file_name (build_string ("lib-src"), dir);
497 lib_src_exists = Ffile_exists_p (tem);
499 #ifdef MSDOS
500 /* MSDOS installations frequently remove lib-src, but we still
501 must set installation-directory, or else info won't find
502 its files (it uses the value of installation-directory). */
503 tem = Fexpand_file_name (build_string ("info"), dir);
504 info_exists = Ffile_exists_p (tem);
505 #else
506 info_exists = Qnil;
507 #endif
509 if (!NILP (lib_src_exists) || !NILP (info_exists))
511 tem = Fexpand_file_name (build_string ("etc"), dir);
512 etc_exists = Ffile_exists_p (tem);
513 if (!NILP (etc_exists))
515 Vinstallation_directory
516 = Ffile_name_as_directory (dir);
517 break;
521 /* See if dir's parent contains those subdirs. */
522 tem = Fexpand_file_name (build_string ("../lib-src"), dir);
523 lib_src_exists = Ffile_exists_p (tem);
526 #ifdef MSDOS
527 /* See the MSDOS commentary above. */
528 tem = Fexpand_file_name (build_string ("../info"), dir);
529 info_exists = Ffile_exists_p (tem);
530 #else
531 info_exists = Qnil;
532 #endif
534 if (!NILP (lib_src_exists) || !NILP (info_exists))
536 tem = Fexpand_file_name (build_string ("../etc"), dir);
537 etc_exists = Ffile_exists_p (tem);
538 if (!NILP (etc_exists))
540 tem = Fexpand_file_name (build_string (".."), dir);
541 Vinstallation_directory
542 = Ffile_name_as_directory (tem);
543 break;
547 /* If the Emacs executable is actually a link,
548 next try the dir that the link points into. */
549 tem = Ffile_symlink_p (name);
550 if (!NILP (tem))
552 name = Fexpand_file_name (tem, dir);
553 dir = Ffile_name_directory (name);
555 else
556 break;
560 Vcommand_line_args = Qnil;
562 for (i = argc - 1; i >= 0; i--)
564 if (i == 0 || i > skip_args)
565 /* For the moment, we keep arguments as is in unibyte strings.
566 They are decoded in the function command-line after we know
567 locale-coding-system. */
568 Vcommand_line_args
569 = Fcons (make_unibyte_string (argv[i], strlen (argv[i])),
570 Vcommand_line_args);
573 unbind_to (count, Qnil);
576 DEFUN ("invocation-name", Finvocation_name, Sinvocation_name, 0, 0, 0,
577 doc: /* Return the program name that was used to run Emacs.
578 Any directory names are omitted. */)
581 return Fcopy_sequence (Vinvocation_name);
584 DEFUN ("invocation-directory", Finvocation_directory, Sinvocation_directory,
585 0, 0, 0,
586 doc: /* Return the directory name in which the Emacs executable was located. */)
589 return Fcopy_sequence (Vinvocation_directory);
593 #ifdef HAVE_TZSET
594 /* A valid but unlikely value for the TZ environment value.
595 It is OK (though a bit slower) if the user actually chooses this value. */
596 static char dump_tz[] = "UtC0";
597 #endif
599 #ifndef ORDINARY_LINK
600 /* We don't include crtbegin.o and crtend.o in the link,
601 so these functions and variables might be missed.
602 Provide dummy definitions to avoid error.
603 (We don't have any real constructors or destructors.) */
604 #ifdef __GNUC__
605 #ifndef GCC_CTORS_IN_LIBC
606 void __do_global_ctors ()
608 void __do_global_ctors_aux ()
610 void __do_global_dtors ()
612 /* GNU/Linux has a bug in its library; avoid an error. */
613 #ifndef GNU_LINUX
614 char * __CTOR_LIST__[2] = { (char *) (-1), 0 };
615 #endif
616 char * __DTOR_LIST__[2] = { (char *) (-1), 0 };
617 #endif /* GCC_CTORS_IN_LIBC */
618 void __main ()
620 #endif /* __GNUC__ */
621 #endif /* ORDINARY_LINK */
623 /* Test whether the next argument in ARGV matches SSTR or a prefix of
624 LSTR (at least MINLEN characters). If so, then if VALPTR is non-null
625 (the argument is supposed to have a value) store in *VALPTR either
626 the next argument or the portion of this one after the equal sign.
627 ARGV is read starting at position *SKIPPTR; this index is advanced
628 by the number of arguments used.
630 Too bad we can't just use getopt for all of this, but we don't have
631 enough information to do it right. */
633 static int
634 argmatch (argv, argc, sstr, lstr, minlen, valptr, skipptr)
635 char **argv;
636 int argc;
637 char *sstr;
638 char *lstr;
639 int minlen;
640 char **valptr;
641 int *skipptr;
643 char *p = NULL;
644 int arglen;
645 char *arg;
647 /* Don't access argv[argc]; give up in advance. */
648 if (argc <= *skipptr + 1)
649 return 0;
651 arg = argv[*skipptr+1];
652 if (arg == NULL)
653 return 0;
654 if (strcmp (arg, sstr) == 0)
656 if (valptr != NULL)
658 *valptr = argv[*skipptr+2];
659 *skipptr += 2;
661 else
662 *skipptr += 1;
663 return 1;
665 arglen = (valptr != NULL && (p = index (arg, '=')) != NULL
666 ? p - arg : strlen (arg));
667 if (lstr == 0 || arglen < minlen || strncmp (arg, lstr, arglen) != 0)
668 return 0;
669 else if (valptr == NULL)
671 *skipptr += 1;
672 return 1;
674 else if (p != NULL)
676 *valptr = p+1;
677 *skipptr += 1;
678 return 1;
680 else if (argv[*skipptr+2] != NULL)
682 *valptr = argv[*skipptr+2];
683 *skipptr += 2;
684 return 1;
686 else
688 return 0;
692 #ifdef DOUG_LEA_MALLOC
694 /* malloc can be invoked even before main (e.g. by the dynamic
695 linker), so the dumped malloc state must be restored as early as
696 possible using this special hook. */
698 static void
699 malloc_initialize_hook ()
701 #ifndef USE_CRT_DLL
702 extern char **environ;
703 #endif
705 if (initialized)
707 if (!malloc_using_checking)
708 /* Work around a bug in glibc's malloc. MALLOC_CHECK_ must be
709 ignored if the heap to be restored was constructed without
710 malloc checking. Can't use unsetenv, since that calls malloc. */
712 char **p;
714 for (p = environ; p && *p; p++)
715 if (strncmp (*p, "MALLOC_CHECK_=", 14) == 0)
718 *p = p[1];
719 while (*++p);
720 break;
724 malloc_set_state (malloc_state_ptr);
725 #ifndef XMALLOC_OVERRUN_CHECK
726 free (malloc_state_ptr);
727 #endif
729 else
731 if (my_heap_start == 0)
732 my_heap_start = sbrk (0);
733 malloc_using_checking = getenv ("MALLOC_CHECK_") != NULL;
737 void (*__malloc_initialize_hook) () = malloc_initialize_hook;
739 #endif /* DOUG_LEA_MALLOC */
742 #define REPORT_EMACS_BUG_ADDRESS "bug-gnu-emacs@gnu.org"
743 #define REPORT_EMACS_BUG_PRETEST_ADDRESS "emacs-pretest-bug@gnu.org"
745 /* This function is used to determine an address to which bug report should
746 be sent. */
748 char *
749 bug_reporting_address ()
751 int count = 0;
752 Lisp_Object temp;
753 char *string;
755 temp = Fsymbol_value (intern ("emacs-version"));
757 /* When `emacs-version' is invalid, use normal address. */
758 if (!STRINGP(temp))
759 return REPORT_EMACS_BUG_ADDRESS;
761 string = SDATA (temp);
763 /* Count dots in `emacs-version'. */
764 while (*string)
766 if (*string == '.')
767 count++;
768 string++;
771 /* When `emacs-version' has at least three dots, it is development or
772 pretest version of Emacs. */
773 return count >= 3 ? REPORT_EMACS_BUG_PRETEST_ADDRESS : REPORT_EMACS_BUG_ADDRESS;
777 /* ARGSUSED */
779 main (int argc, char **argv)
781 #if GC_MARK_STACK
782 Lisp_Object dummy;
783 #endif
784 char stack_bottom_variable;
785 int do_initial_setlocale;
786 int skip_args = 0;
787 #ifndef USE_CRT_DLL
788 extern int errno;
789 #endif
790 #ifdef HAVE_SETRLIMIT
791 struct rlimit rlim;
792 #endif
793 int no_loadup = 0;
794 char *junk = 0;
796 #if GC_MARK_STACK
797 extern Lisp_Object *stack_base;
798 stack_base = &dummy;
799 #endif
801 if (!initialized)
803 extern char my_endbss[];
804 extern char *my_endbss_static;
806 if (my_heap_start == 0)
807 my_heap_start = sbrk (0);
809 heap_bss_diff = (char *)my_heap_start - max (my_endbss, my_endbss_static);
812 #ifdef LINUX_SBRK_BUG
813 /* This is only used GNU/LINUX running on alpha when using libc5 */
814 __sbrk (1);
815 #endif
817 #ifdef RUN_TIME_REMAP
818 if (initialized)
819 run_time_remap (argv[0]);
820 #endif
822 /* If using unexmacosx.c (set by s/darwin.h), we must do this. */
823 #ifdef DARWIN_OS
824 if (!initialized)
825 unexec_init_emacs_zone ();
826 #endif
828 sort_args (argc, argv);
829 argc = 0;
830 while (argv[argc]) argc++;
832 if (argmatch (argv, argc, "-version", "--version", 3, NULL, &skip_args)
833 /* We don't know the version number unless this is a dumped Emacs.
834 So ignore --version otherwise. */
835 && initialized)
837 Lisp_Object tem, tem2;
838 tem = Fsymbol_value (intern ("emacs-version"));
839 tem2 = Fsymbol_value (intern ("emacs-copyright"));
840 if (!STRINGP (tem))
842 fprintf (stderr, "Invalid value of `emacs-version'\n");
843 exit (1);
845 if (!STRINGP (tem2))
847 fprintf (stderr, "Invalid value of `emacs-copyright'\n");
848 exit (1);
850 else
852 printf ("GNU Emacs %s\n", SDATA (tem));
853 printf ("%s\n", SDATA(tem2));
854 printf ("GNU Emacs comes with ABSOLUTELY NO WARRANTY.\n");
855 printf ("You may redistribute copies of Emacs\n");
856 printf ("under the terms of the GNU General Public License.\n");
857 printf ("For more information about these matters, ");
858 printf ("see the file named COPYING.\n");
859 exit (0);
863 #ifdef HAVE_PERSONALITY_LINUX32
864 if (!initialized
865 && (strcmp (argv[argc-1], "dump") == 0
866 || strcmp (argv[argc-1], "bootstrap") == 0)
867 && ! getenv ("EMACS_HEAP_EXEC"))
869 /* Set this so we only do this once. */
870 putenv("EMACS_HEAP_EXEC=true");
872 /* A flag to turn off address randomization which is introduced
873 in linux kernel shipped with fedora core 4 */
874 #define ADD_NO_RANDOMIZE 0x0040000
875 personality (PER_LINUX32 | ADD_NO_RANDOMIZE);
876 #undef ADD_NO_RANDOMIZE
878 execvp (argv[0], argv);
880 /* If the exec fails, try to dump anyway. */
881 perror ("execvp");
883 #endif /* HAVE_PERSONALITY_LINUX32 */
886 /* Map in shared memory, if we are using that. */
887 #ifdef HAVE_SHM
888 if (argmatch (argv, argc, "-nl", "--no-shared-memory", 6, NULL, &skip_args))
890 map_in_data (0);
891 /* The shared memory was just restored, which clobbered this. */
892 skip_args = 1;
894 else
896 map_in_data (1);
897 /* The shared memory was just restored, which clobbered this. */
898 skip_args = 0;
900 #endif
902 #if defined (HAVE_SETRLIMIT) && defined (RLIMIT_STACK)
903 /* Extend the stack space available.
904 Don't do that if dumping, since some systems (e.g. DJGPP)
905 might define a smaller stack limit at that time. */
906 if (1
907 #ifndef CANNOT_DUMP
908 && (!noninteractive || initialized)
909 #endif
910 && !getrlimit (RLIMIT_STACK, &rlim))
912 long newlim;
913 extern size_t re_max_failures;
914 /* Approximate the amount regex.c needs per unit of re_max_failures. */
915 int ratio = 20 * sizeof (char *);
916 /* Then add 33% to cover the size of the smaller stacks that regex.c
917 successively allocates and discards, on its way to the maximum. */
918 ratio += ratio / 3;
919 /* Add in some extra to cover
920 what we're likely to use for other reasons. */
921 newlim = re_max_failures * ratio + 200000;
922 #ifdef __NetBSD__
923 /* NetBSD (at least NetBSD 1.2G and former) has a bug in its
924 stack allocation routine for new process that the allocation
925 fails if stack limit is not on page boundary. So, round up the
926 new limit to page boundary. */
927 newlim = (newlim + getpagesize () - 1) / getpagesize () * getpagesize();
928 #endif
929 if (newlim > rlim.rlim_max)
931 newlim = rlim.rlim_max;
932 /* Don't let regex.c overflow the stack we have. */
933 re_max_failures = (newlim - 200000) / ratio;
935 if (rlim.rlim_cur < newlim)
936 rlim.rlim_cur = newlim;
938 setrlimit (RLIMIT_STACK, &rlim);
940 #endif /* HAVE_SETRLIMIT and RLIMIT_STACK */
942 /* Record (approximately) where the stack begins. */
943 stack_bottom = &stack_bottom_variable;
945 clearerr (stdin);
947 #ifndef SYSTEM_MALLOC
948 /* Arrange to get warning messages as memory fills up. */
949 memory_warnings (0, malloc_warning);
951 /* Call malloc at least once, to run the initial __malloc_hook.
952 Also call realloc and free for consistency. */
953 free (realloc (malloc (4), 4));
955 # ifndef SYNC_INPUT
956 /* Arrange to disable interrupt input inside malloc etc. */
957 uninterrupt_malloc ();
958 # endif /* not SYNC_INPUT */
959 #endif /* not SYSTEM_MALLOC */
961 #ifdef FORWARD_SIGNAL_TO_MAIN_THREAD
962 main_thread = pthread_self ();
963 #endif /* FORWARD_SIGNAL_TO_MAIN_THREAD */
965 #if defined (MSDOS) || defined (WINDOWSNT)
966 /* We do all file input/output as binary files. When we need to translate
967 newlines, we do that manually. */
968 _fmode = O_BINARY;
969 #endif /* MSDOS || WINDOWSNT */
971 #ifdef MSDOS
972 #if __DJGPP__ >= 2
973 if (!isatty (fileno (stdin)))
974 setmode (fileno (stdin), O_BINARY);
975 if (!isatty (fileno (stdout)))
977 fflush (stdout);
978 setmode (fileno (stdout), O_BINARY);
980 #else /* not __DJGPP__ >= 2 */
981 (stdin)->_flag &= ~_IOTEXT;
982 (stdout)->_flag &= ~_IOTEXT;
983 (stderr)->_flag &= ~_IOTEXT;
984 #endif /* not __DJGPP__ >= 2 */
985 #endif /* MSDOS */
987 #ifdef SET_EMACS_PRIORITY
988 if (emacs_priority)
989 nice (emacs_priority);
990 setuid (getuid ());
991 #endif /* SET_EMACS_PRIORITY */
993 /* Skip initial setlocale if LC_ALL is "C", as it's not needed in that case.
994 The build procedure uses this while dumping, to ensure that the
995 dumped Emacs does not have its system locale tables initialized,
996 as that might cause screwups when the dumped Emacs starts up. */
998 char *lc_all = getenv ("LC_ALL");
999 do_initial_setlocale = ! lc_all || strcmp (lc_all, "C");
1002 /* Set locale now, so that initial error messages are localized properly.
1003 fixup_locale must wait until later, since it builds strings. */
1004 if (do_initial_setlocale)
1005 setlocale (LC_ALL, "");
1007 inhibit_window_system = 0;
1009 /* Handle the -t switch, which specifies filename to use as terminal. */
1010 while (1)
1012 char *term;
1013 if (argmatch (argv, argc, "-t", "--terminal", 4, &term, &skip_args))
1015 int result;
1016 emacs_close (0);
1017 emacs_close (1);
1018 result = emacs_open (term, O_RDWR, 0);
1019 if (result < 0)
1021 char *errstring = strerror (errno);
1022 fprintf (stderr, "%s: %s: %s\n", argv[0], term, errstring);
1023 exit (1);
1025 dup (0);
1026 if (! isatty (0))
1028 fprintf (stderr, "%s: %s: not a tty\n", argv[0], term);
1029 exit (1);
1031 fprintf (stderr, "Using %s\n", term);
1032 #ifdef HAVE_WINDOW_SYSTEM
1033 inhibit_window_system = 1; /* -t => -nw */
1034 #endif
1036 else
1037 break;
1040 /* Command line option --no-windows is deprecated and thus not mentioned
1041 in the manual and usage informations. */
1042 if (argmatch (argv, argc, "-nw", "--no-window-system", 6, NULL, &skip_args)
1043 || argmatch (argv, argc, "-nw", "--no-windows", 6, NULL, &skip_args))
1044 inhibit_window_system = 1;
1046 /* Handle the -batch switch, which means don't do interactive display. */
1047 noninteractive = 0;
1048 if (argmatch (argv, argc, "-batch", "--batch", 5, NULL, &skip_args))
1050 noninteractive = 1;
1051 Vundo_outer_limit = Qnil;
1053 if (argmatch (argv, argc, "-script", "--script", 3, &junk, &skip_args))
1055 noninteractive = 1; /* Set batch mode. */
1056 /* Convert --script to -scriptload, un-skip it, and sort again
1057 so that it will be handled in proper sequence. */
1058 /* FIXME broken for --script=FILE - is that supposed to work? */
1059 argv[skip_args - 1] = "-scriptload";
1060 skip_args -= 2;
1061 sort_args (argc, argv);
1064 /* Handle the --help option, which gives a usage message. */
1065 if (argmatch (argv, argc, "-help", "--help", 3, NULL, &skip_args))
1067 printf (USAGE1, argv[0], USAGE2);
1068 printf (USAGE3);
1069 printf (USAGE4, bug_reporting_address ());
1070 exit (0);
1073 if (argmatch (argv, argc, "-daemon", "--daemon", 5, NULL, &skip_args))
1075 #ifndef DOS_NT
1076 pid_t f = fork ();
1077 int nfd;
1078 if (f > 0)
1079 exit (0);
1080 if (f < 0)
1082 fprintf (stderr, "Cannot fork!\n");
1083 exit (1);
1086 nfd = open ("/dev/null", O_RDWR);
1087 dup2 (nfd, 0);
1088 dup2 (nfd, 1);
1089 dup2 (nfd, 2);
1090 close (nfd);
1091 is_daemon = 1;
1092 #ifdef HAVE_SETSID
1093 setsid();
1094 #endif
1095 #else /* DOS_NT */
1096 fprintf (stderr, "This platform does not support the -daemon flag.\n");
1097 exit (1);
1098 #endif /* DOS_NT */
1101 if (! noninteractive)
1103 #ifdef BSD_PGRPS
1104 if (initialized)
1106 inherited_pgroup = EMACS_GETPGRP (0);
1107 setpgrp (0, getpid ());
1109 #else
1110 #if defined (USG5) && defined (INTERRUPT_INPUT)
1111 setpgrp ();
1112 #endif
1113 #endif
1114 #if defined (HAVE_GTK_AND_PTHREAD) && !defined (SYSTEM_MALLOC) && !defined (DOUG_LEA_MALLOC)
1116 extern void malloc_enable_thread P_ ((void));
1118 malloc_enable_thread ();
1120 #endif
1123 init_signals ();
1125 /* Don't catch SIGHUP if dumping. */
1126 if (1
1127 #ifndef CANNOT_DUMP
1128 && initialized
1129 #endif
1132 sigblock (sigmask (SIGHUP));
1133 /* In --batch mode, don't catch SIGHUP if already ignored.
1134 That makes nohup work. */
1135 if (! noninteractive
1136 || signal (SIGHUP, SIG_IGN) != SIG_IGN)
1137 signal (SIGHUP, fatal_error_signal);
1138 sigunblock (sigmask (SIGHUP));
1141 if (
1142 #ifndef CANNOT_DUMP
1143 ! noninteractive || initialized
1144 #else
1146 #endif
1149 /* Don't catch these signals in batch mode if dumping.
1150 On some machines, this sets static data that would make
1151 signal fail to work right when the dumped Emacs is run. */
1152 signal (SIGQUIT, fatal_error_signal);
1153 signal (SIGILL, fatal_error_signal);
1154 signal (SIGTRAP, fatal_error_signal);
1155 #ifdef SIGUSR1
1156 add_user_signal (SIGUSR1, "sigusr1");
1157 #endif
1158 #ifdef SIGUSR2
1159 add_user_signal (SIGUSR2, "sigusr2");
1160 #endif
1161 #ifdef SIGABRT
1162 signal (SIGABRT, fatal_error_signal);
1163 #endif
1164 #ifdef SIGHWE
1165 signal (SIGHWE, fatal_error_signal);
1166 #endif
1167 #ifdef SIGPRE
1168 signal (SIGPRE, fatal_error_signal);
1169 #endif
1170 #ifdef SIGORE
1171 signal (SIGORE, fatal_error_signal);
1172 #endif
1173 #ifdef SIGUME
1174 signal (SIGUME, fatal_error_signal);
1175 #endif
1176 #ifdef SIGDLK
1177 signal (SIGDLK, fatal_error_signal);
1178 #endif
1179 #ifdef SIGCPULIM
1180 signal (SIGCPULIM, fatal_error_signal);
1181 #endif
1182 #ifdef SIGIOT
1183 /* This is missing on some systems - OS/2, for example. */
1184 signal (SIGIOT, fatal_error_signal);
1185 #endif
1186 #ifdef SIGEMT
1187 signal (SIGEMT, fatal_error_signal);
1188 #endif
1189 signal (SIGFPE, fatal_error_signal);
1190 #ifdef SIGBUS
1191 signal (SIGBUS, fatal_error_signal);
1192 #endif
1193 signal (SIGSEGV, fatal_error_signal);
1194 #ifdef SIGSYS
1195 signal (SIGSYS, fatal_error_signal);
1196 #endif
1197 signal (SIGTERM, fatal_error_signal);
1198 #ifdef SIGXCPU
1199 signal (SIGXCPU, fatal_error_signal);
1200 #endif
1201 #ifdef SIGXFSZ
1202 signal (SIGXFSZ, fatal_error_signal);
1203 #endif /* SIGXFSZ */
1205 #ifdef SIGDANGER
1206 /* This just means available memory is getting low. */
1207 signal (SIGDANGER, memory_warning_signal);
1208 #endif
1210 #ifdef AIX
1211 /* 20 is SIGCHLD, 21 is SIGTTIN, 22 is SIGTTOU. */
1212 signal (SIGXCPU, fatal_error_signal);
1213 #ifndef _I386
1214 signal (SIGIOINT, fatal_error_signal);
1215 #endif
1216 signal (SIGGRANT, fatal_error_signal);
1217 signal (SIGRETRACT, fatal_error_signal);
1218 signal (SIGSOUND, fatal_error_signal);
1219 signal (SIGMSG, fatal_error_signal);
1220 #endif /* AIX */
1223 noninteractive1 = noninteractive;
1225 /* Perform basic initializations (not merely interning symbols). */
1227 if (!initialized)
1229 init_alloc_once ();
1230 init_obarray ();
1231 init_eval_once ();
1232 init_character_once ();
1233 init_charset_once ();
1234 init_coding_once ();
1235 init_syntax_once (); /* Create standard syntax table. */
1236 init_category_once (); /* Create standard category table. */
1237 /* Must be done before init_buffer. */
1238 init_casetab_once ();
1239 init_buffer_once (); /* Create buffer table and some buffers. */
1240 init_minibuf_once (); /* Create list of minibuffers. */
1241 /* Must precede init_window_once. */
1243 /* Call syms_of_xfaces before init_window_once because that
1244 function creates Vterminal_frame. Termcap frames now use
1245 faces, and the face implementation uses some symbols as
1246 face names. */
1247 syms_of_xfaces ();
1248 /* XXX syms_of_keyboard uses some symbols in keymap.c. It would
1249 be better to arrange things not to have this dependency. */
1250 syms_of_keymap ();
1251 /* Call syms_of_keyboard before init_window_once because
1252 keyboard sets up symbols that include some face names that
1253 the X support will want to use. This can happen when
1254 CANNOT_DUMP is defined. */
1255 syms_of_keyboard ();
1257 /* Called before syms_of_fileio, because it sets up Qerror_condition. */
1258 syms_of_data ();
1259 syms_of_fileio ();
1260 /* Before syms_of_coding to initialize Vgc_cons_threshold. */
1261 syms_of_alloc ();
1262 /* Before syms_of_coding because it initializes Qcharsetp. */
1263 syms_of_charset ();
1264 /* Before init_window_once, because it sets up the
1265 Vcoding_system_hash_table. */
1266 syms_of_coding (); /* This should be after syms_of_fileio. */
1268 init_window_once (); /* Init the window system. */
1269 init_fileio_once (); /* Must precede any path manipulation. */
1270 #ifdef HAVE_WINDOW_SYSTEM
1271 init_fringe_once (); /* Swap bitmaps if necessary. */
1272 #endif /* HAVE_WINDOW_SYSTEM */
1275 init_alloc ();
1277 if (do_initial_setlocale)
1279 fixup_locale ();
1280 Vsystem_messages_locale = Vprevious_system_messages_locale;
1281 Vsystem_time_locale = Vprevious_system_time_locale;
1284 init_eval ();
1285 init_data ();
1286 #ifdef CLASH_DETECTION
1287 init_filelock ();
1288 #endif
1289 init_atimer ();
1290 running_asynch_code = 0;
1292 /* Handle --unibyte and the EMACS_UNIBYTE envvar,
1293 but not while dumping. */
1294 if (1)
1296 int inhibit_unibyte = 0;
1298 /* --multibyte overrides EMACS_UNIBYTE. */
1299 if (argmatch (argv, argc, "-no-unibyte", "--no-unibyte", 4, NULL, &skip_args)
1300 || argmatch (argv, argc, "-multibyte", "--multibyte", 4, NULL, &skip_args)
1301 /* Ignore EMACS_UNIBYTE before dumping. */
1302 || (!initialized && noninteractive))
1303 inhibit_unibyte = 1;
1305 /* --unibyte requests that we set up to do everything with single-byte
1306 buffers and strings. We need to handle this before calling
1307 init_lread, init_editfns and other places that generate Lisp strings
1308 from text in the environment. */
1309 /* Actually this shouldn't be needed as of 20.4 in a generally
1310 unibyte environment. As handa says, environment values
1311 aren't now decoded; also existing buffers are now made
1312 unibyte during startup if .emacs sets unibyte. Tested with
1313 8-bit data in environment variables and /etc/passwd, setting
1314 unibyte and Latin-1 in .emacs. -- Dave Love */
1315 if (argmatch (argv, argc, "-unibyte", "--unibyte", 4, NULL, &skip_args)
1316 || argmatch (argv, argc, "-no-multibyte", "--no-multibyte", 4, NULL, &skip_args)
1317 || (getenv ("EMACS_UNIBYTE") && !inhibit_unibyte))
1319 Lisp_Object old_log_max;
1320 Lisp_Object symbol, tail;
1322 symbol = intern ("default-enable-multibyte-characters");
1323 Fset (symbol, Qnil);
1325 if (initialized)
1327 /* Erase pre-dump messages in *Messages* now so no abort. */
1328 old_log_max = Vmessage_log_max;
1329 XSETFASTINT (Vmessage_log_max, 0);
1330 message_dolog ("", 0, 1, 0);
1331 Vmessage_log_max = old_log_max;
1334 for (tail = Vbuffer_alist; CONSP (tail);
1335 tail = XCDR (tail))
1337 Lisp_Object buffer;
1339 buffer = Fcdr (XCAR (tail));
1340 /* Make a multibyte buffer unibyte. */
1341 if (BUF_Z_BYTE (XBUFFER (buffer)) > BUF_Z (XBUFFER (buffer)))
1343 struct buffer *current = current_buffer;
1345 set_buffer_temp (XBUFFER (buffer));
1346 Fset_buffer_multibyte (Qnil);
1347 set_buffer_temp (current);
1353 no_loadup
1354 = argmatch (argv, argc, "-nl", "--no-loadup", 6, NULL, &skip_args);
1356 #ifdef HAVE_NS
1357 ns_alloc_autorelease_pool();
1358 if (!noninteractive)
1360 char *tmp;
1361 display_arg = 4;
1362 #ifdef NS_IMPL_COCOA
1363 if (skip_args < argc)
1365 if (!strncmp(argv[skip_args], "-psn", 4))
1367 skip_args += 1;
1368 chdir (getenv ("HOME"));
1370 else if (skip_args+1 < argc && !strncmp(argv[skip_args+1], "-psn", 4))
1372 skip_args += 2;
1373 chdir (getenv ("HOME"));
1376 #endif
1377 /* This used for remote operation.. not fully implemented yet. */
1378 if (argmatch (argv, argc, "-_NSMachLaunch", 0, 3, &tmp, &skip_args))
1379 display_arg = 4;
1380 else if (argmatch (argv, argc, "-MachLaunch", 0, 3, &tmp, &skip_args))
1381 display_arg = 4;
1382 else if (argmatch (argv, argc, "-macosx", 0, 2, NULL, &skip_args))
1383 display_arg = 4;
1384 else if (argmatch (argv, argc, "-NSHost", 0, 3, &tmp, &skip_args))
1385 display_arg = 4;
1387 #endif /* HAVE_NS */
1389 #ifdef HAVE_X_WINDOWS
1390 /* Stupid kludge to catch command-line display spec. We can't
1391 handle this argument entirely in window system dependent code
1392 because we don't even know which window system dependent code
1393 to run until we've recognized this argument. */
1395 char *displayname = 0;
1396 int count_before = skip_args;
1398 /* Skip any number of -d options, but only use the last one. */
1399 while (1)
1401 int count_before_this = skip_args;
1403 if (argmatch (argv, argc, "-d", "--display", 3, &displayname, &skip_args))
1404 display_arg = 1;
1405 else if (argmatch (argv, argc, "-display", 0, 3, &displayname, &skip_args))
1406 display_arg = 1;
1407 else
1408 break;
1410 count_before = count_before_this;
1413 /* If we have the form --display=NAME,
1414 convert it into -d name.
1415 This requires inserting a new element into argv. */
1416 if (displayname != 0 && skip_args - count_before == 1)
1418 char **new = (char **) xmalloc (sizeof (char *) * (argc + 2));
1419 int j;
1421 for (j = 0; j < count_before + 1; j++)
1422 new[j] = argv[j];
1423 new[count_before + 1] = "-d";
1424 new[count_before + 2] = displayname;
1425 for (j = count_before + 2; j <argc; j++)
1426 new[j + 1] = argv[j];
1427 argv = new;
1428 argc++;
1430 /* Change --display to -d, when its arg is separate. */
1431 else if (displayname != 0 && skip_args > count_before
1432 && argv[count_before + 1][1] == '-')
1433 argv[count_before + 1] = "-d";
1435 /* Don't actually discard this arg. */
1436 skip_args = count_before;
1438 #endif
1440 /* argmatch must not be used after here,
1441 except when bulding temacs
1442 because the -d argument has not been skipped in skip_args. */
1444 #ifdef MSDOS
1445 /* Call early 'cause init_environment needs it. */
1446 init_dosfns ();
1447 /* Set defaults for several environment variables. */
1448 if (initialized)
1449 init_environment (argc, argv, skip_args);
1450 else
1451 tzset ();
1452 #endif /* MSDOS */
1454 #ifdef WINDOWSNT
1455 globals_of_w32 ();
1456 /* Initialize environment from registry settings. */
1457 init_environment (argv);
1458 init_ntproc (); /* must precede init_editfns. */
1459 #endif
1461 #ifdef HAVE_NS
1462 #ifndef CANNOT_DUMP
1463 if (initialized)
1464 #endif
1465 ns_init_paths ();
1466 #endif
1468 /* egetenv is a pretty low-level facility, which may get called in
1469 many circumstances; it seems flimsy to put off initializing it
1470 until calling init_callproc. */
1471 set_initial_environment ();
1472 /* AIX crashes are reported in system versions 3.2.3 and 3.2.4
1473 if this is not done. Do it after set_global_environment so that we
1474 don't pollute Vglobal_environment. */
1475 /* Setting LANG here will defeat the startup locale processing... */
1476 #ifdef AIX
1477 putenv ("LANG=C");
1478 #endif
1480 init_buffer (); /* Init default directory of main buffer. */
1482 init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */
1483 init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */
1485 if (initialized)
1487 /* Erase any pre-dump messages in the message log, to avoid confusion. */
1488 Lisp_Object old_log_max;
1489 old_log_max = Vmessage_log_max;
1490 XSETFASTINT (Vmessage_log_max, 0);
1491 message_dolog ("", 0, 1, 0);
1492 Vmessage_log_max = old_log_max;
1495 init_callproc (); /* Must follow init_cmdargs but not init_sys_modes. */
1496 init_lread ();
1498 /* Intern the names of all standard functions and variables;
1499 define standard keys. */
1501 if (!initialized)
1503 /* The basic levels of Lisp must come first. */
1504 /* And data must come first of all
1505 for the sake of symbols like error-message. */
1506 syms_of_data ();
1507 syms_of_chartab ();
1508 syms_of_lread ();
1509 syms_of_print ();
1510 syms_of_eval ();
1511 syms_of_fns ();
1512 syms_of_floatfns ();
1514 syms_of_buffer ();
1515 syms_of_bytecode ();
1516 syms_of_callint ();
1517 syms_of_casefiddle ();
1518 syms_of_casetab ();
1519 syms_of_callproc ();
1520 syms_of_category ();
1521 syms_of_ccl ();
1522 syms_of_character ();
1523 syms_of_cmds ();
1524 #ifndef NO_DIR_LIBRARY
1525 syms_of_dired ();
1526 #endif /* not NO_DIR_LIBRARY */
1527 syms_of_display ();
1528 syms_of_doc ();
1529 syms_of_editfns ();
1530 syms_of_emacs ();
1531 #ifdef CLASH_DETECTION
1532 syms_of_filelock ();
1533 #endif /* CLASH_DETECTION */
1534 syms_of_indent ();
1535 syms_of_insdel ();
1536 /* syms_of_keymap (); */
1537 syms_of_macros ();
1538 syms_of_marker ();
1539 syms_of_minibuf ();
1540 syms_of_process ();
1541 syms_of_search ();
1542 syms_of_frame ();
1543 syms_of_syntax ();
1544 syms_of_terminal ();
1545 syms_of_term ();
1546 syms_of_undo ();
1547 #ifdef HAVE_SOUND
1548 syms_of_sound ();
1549 #endif
1550 syms_of_textprop ();
1551 syms_of_composite ();
1552 #ifdef WINDOWSNT
1553 syms_of_ntproc ();
1554 #endif /* WINDOWSNT */
1555 syms_of_window ();
1556 syms_of_xdisp ();
1557 syms_of_font ();
1558 #ifdef HAVE_WINDOW_SYSTEM
1559 syms_of_fringe ();
1560 syms_of_image ();
1561 #endif /* HAVE_WINDOW_SYSTEM */
1562 #ifdef HAVE_X_WINDOWS
1563 syms_of_xterm ();
1564 syms_of_xfns ();
1565 syms_of_xmenu ();
1566 syms_of_fontset ();
1567 #ifdef HAVE_X_SM
1568 syms_of_xsmfns ();
1569 #endif
1570 #ifdef HAVE_X11
1571 syms_of_xselect ();
1572 #endif
1573 #endif /* HAVE_X_WINDOWS */
1575 syms_of_menu ();
1577 #ifdef HAVE_NTGUI
1578 syms_of_w32term ();
1579 syms_of_w32fns ();
1580 syms_of_w32select ();
1581 syms_of_w32menu ();
1582 syms_of_fontset ();
1583 #endif /* HAVE_NTGUI */
1585 #ifdef MSDOS
1586 syms_of_xmenu ();
1587 #endif /* MSDOS */
1589 #ifdef HAVE_NS
1590 syms_of_nsterm ();
1591 syms_of_nsfns ();
1592 syms_of_nsmenu ();
1593 syms_of_nsselect ();
1594 syms_of_fontset ();
1595 #endif /* HAVE_NS */
1597 #ifdef HAVE_DBUS
1598 syms_of_dbusbind ();
1599 #endif /* HAVE_DBUS */
1601 #ifdef SYMS_SYSTEM
1602 SYMS_SYSTEM;
1603 #endif
1605 #ifdef SYMS_MACHINE
1606 SYMS_MACHINE;
1607 #endif
1609 keys_of_casefiddle ();
1610 keys_of_cmds ();
1611 keys_of_buffer ();
1612 keys_of_keyboard ();
1613 keys_of_keymap ();
1614 keys_of_window ();
1616 else
1618 /* Initialization that must be done even if the global variable
1619 initialized is non zero. */
1620 #ifdef HAVE_NTGUI
1621 globals_of_w32fns ();
1622 globals_of_w32menu ();
1623 globals_of_w32select ();
1624 #endif /* HAVE_NTGUI */
1627 init_charset ();
1629 init_editfns (); /* init_process uses Voperating_system_release. */
1630 init_process (); /* init_display uses add_keyboard_wait_descriptor. */
1631 init_keyboard (); /* This too must precede init_sys_modes. */
1632 if (!noninteractive)
1633 init_display (); /* Determine terminal type. Calls init_sys_modes. */
1634 init_fns ();
1635 init_xdisp ();
1636 #ifdef HAVE_WINDOW_SYSTEM
1637 init_fringe ();
1638 init_image ();
1639 #endif /* HAVE_WINDOW_SYSTEM */
1640 init_macros ();
1641 init_floatfns ();
1642 #ifdef HAVE_SOUND
1643 init_sound ();
1644 #endif
1645 init_window ();
1647 if (!initialized)
1649 char *file;
1650 /* Handle -l loadup, args passed by Makefile. */
1651 if (argmatch (argv, argc, "-l", "--load", 3, &file, &skip_args))
1652 Vtop_level = Fcons (intern ("load"),
1653 Fcons (build_string (file), Qnil));
1654 /* Unless next switch is -nl, load "loadup.el" first thing. */
1655 if (! no_loadup)
1656 Vtop_level = Fcons (intern ("load"),
1657 Fcons (build_string ("loadup.el"), Qnil));
1660 if (initialized)
1662 #ifdef HAVE_TZSET
1664 /* If the execution TZ happens to be the same as the dump TZ,
1665 change it to some other value and then change it back,
1666 to force the underlying implementation to reload the TZ info.
1667 This is needed on implementations that load TZ info from files,
1668 since the TZ file contents may differ between dump and execution. */
1669 char *tz = getenv ("TZ");
1670 if (tz && !strcmp (tz, dump_tz))
1672 ++*tz;
1673 tzset ();
1674 --*tz;
1677 #endif
1680 /* Set up for profiling. This is known to work on FreeBSD,
1681 GNU/Linux and MinGW. It might work on some other systems too.
1682 Give it a try and tell us if it works on your system. To compile
1683 for profiling, add -pg to the switches your platform uses in
1684 CFLAGS and LDFLAGS. For example:
1685 `make CFLAGS="-pg -g -O -DPROFILING=1" LDFLAGS="-pg -g"'. */
1686 #if defined (__FreeBSD__) || defined (GNU_LINUX) || defined(__MINGW32__)
1687 #ifdef PROFILING
1688 if (initialized)
1690 extern void _mcleanup ();
1691 #ifdef __MINGW32__
1692 extern unsigned char etext asm ("etext");
1693 #else
1694 extern char etext;
1695 #endif
1696 extern void safe_bcopy ();
1697 extern void dump_opcode_frequencies ();
1699 atexit (_mcleanup);
1700 /* This uses safe_bcopy because that function comes first in the
1701 Emacs executable. It might be better to use something that
1702 gives the start of the text segment, but start_of_text is not
1703 defined on all systems now. */
1704 monstartup (safe_bcopy, &etext);
1706 else
1707 moncontrol (0);
1708 #endif
1709 #endif
1711 initialized = 1;
1713 #ifdef LOCALTIME_CACHE
1714 /* Some versions of localtime have a bug. They cache the value of the time
1715 zone rather than looking it up every time. Since localtime() is
1716 called to bolt the undumping time into the undumped emacs, this
1717 results in localtime ignoring the TZ environment variable.
1718 This flushes the new TZ value into localtime. */
1719 tzset ();
1720 #endif /* defined (LOCALTIME_CACHE) */
1722 /* Enter editor command loop. This never returns. */
1723 Frecursive_edit ();
1724 /* NOTREACHED */
1725 return 0;
1728 /* Sort the args so we can find the most important ones
1729 at the beginning of argv. */
1731 /* First, here's a table of all the standard options. */
1733 struct standard_args
1735 char *name;
1736 char *longname;
1737 int priority;
1738 int nargs;
1741 struct standard_args standard_args[] =
1743 { "-version", "--version", 150, 0 },
1744 #ifdef HAVE_SHM
1745 { "-nl", "--no-shared-memory", 140, 0 },
1746 #endif
1747 { "-t", "--terminal", 120, 1 },
1748 { "-nw", "--no-window-system", 110, 0 },
1749 { "-nw", "--no-windows", 110, 0 },
1750 { "-batch", "--batch", 100, 0 },
1751 { "-script", "--script", 100, 1 },
1752 { "-daemon", "--daemon", 99, 0 },
1753 { "-help", "--help", 90, 0 },
1754 { "-no-unibyte", "--no-unibyte", 83, 0 },
1755 { "-multibyte", "--multibyte", 82, 0 },
1756 { "-unibyte", "--unibyte", 81, 0 },
1757 { "-no-multibyte", "--no-multibyte", 80, 0 },
1758 { "-nl", "--no-loadup", 70, 0 },
1759 /* -d must come last before the options handled in startup.el. */
1760 { "-d", "--display", 60, 1 },
1761 { "-display", 0, 60, 1 },
1762 /* Now for the options handled in startup.el. */
1763 { "-Q", "--quick", 55, 0 },
1764 { "-quick", 0, 55, 0 },
1765 { "-q", "--no-init-file", 50, 0 },
1766 { "-no-init-file", 0, 50, 0 },
1767 { "-no-site-file", "--no-site-file", 40, 0 },
1768 { "-u", "--user", 30, 1 },
1769 { "-user", 0, 30, 1 },
1770 { "-debug-init", "--debug-init", 20, 0 },
1771 { "-nbi", "--no-bitmap-icon", 15, 0 },
1772 { "-iconic", "--iconic", 15, 0 },
1773 { "-D", "--basic-display", 12, 0},
1774 { "-basic-display", 0, 12, 0},
1775 { "-bg", "--background-color", 10, 1 },
1776 { "-background", 0, 10, 1 },
1777 { "-fg", "--foreground-color", 10, 1 },
1778 { "-foreground", 0, 10, 1 },
1779 { "-bd", "--border-color", 10, 1 },
1780 { "-bw", "--border-width", 10, 1 },
1781 { "-ib", "--internal-border", 10, 1 },
1782 { "-ms", "--mouse-color", 10, 1 },
1783 { "-cr", "--cursor-color", 10, 1 },
1784 { "-nbc", "--no-blinking-cursor", 10, 0 },
1785 { "-fn", "--font", 10, 1 },
1786 { "-font", 0, 10, 1 },
1787 { "-fs", "--fullscreen", 10, 0 },
1788 { "-fw", "--fullwidth", 10, 0 },
1789 { "-fh", "--fullheight", 10, 0 },
1790 { "-g", "--geometry", 10, 1 },
1791 { "-geometry", 0, 10, 1 },
1792 { "-T", "--title", 10, 1 },
1793 { "-title", 0, 10, 1 },
1794 { "-name", "--name", 10, 1 },
1795 { "-xrm", "--xrm", 10, 1 },
1796 { "-parent-id", "--parent-id", 10, 1 },
1797 { "-r", "--reverse-video", 5, 0 },
1798 { "-rv", 0, 5, 0 },
1799 { "-reverse", 0, 5, 0 },
1800 { "-hb", "--horizontal-scroll-bars", 5, 0 },
1801 { "-vb", "--vertical-scroll-bars", 5, 0 },
1802 { "-color", "--color", 5, 0},
1803 { "-no-splash", "--no-splash", 3, 0 },
1804 { "-no-desktop", "--no-desktop", 3, 0 },
1805 #ifdef HAVE_NS
1806 { "-NSAutoLaunch", 0, 5, 1 },
1807 { "-NXAutoLaunch", 0, 5, 1 },
1808 { "-disable-font-backend", "--disable-font-backend", 65, 0 },
1809 { "-_NSMachLaunch", 0, 85, 1 },
1810 { "-MachLaunch", 0, 85, 1 },
1811 { "-macosx", 0, 85, 0 },
1812 { "-NSHost", 0, 85, 1 },
1813 #endif
1814 /* These have the same priority as ordinary file name args,
1815 so they are not reordered with respect to those. */
1816 { "-L", "--directory", 0, 1 },
1817 { "-directory", 0, 0, 1 },
1818 { "-l", "--load", 0, 1 },
1819 { "-load", 0, 0, 1 },
1820 /* This has no longname, because using --scriptload confuses sort_args,
1821 because then the --script long option seems to match twice; ie
1822 you can't have a long option which is a prefix of another long
1823 option. In any case, this is entirely an internal option. */
1824 { "-scriptload", NULL, 0, 1 },
1825 { "-f", "--funcall", 0, 1 },
1826 { "-funcall", 0, 0, 1 },
1827 { "-eval", "--eval", 0, 1 },
1828 { "-execute", "--execute", 0, 1 },
1829 { "-find-file", "--find-file", 0, 1 },
1830 { "-visit", "--visit", 0, 1 },
1831 { "-file", "--file", 0, 1 },
1832 { "-insert", "--insert", 0, 1 },
1833 #ifdef HAVE_NS
1834 { "-NXOpen", 0, 0, 1 },
1835 { "-NXOpenTemp", 0, 0, 1 },
1836 { "-NSOpen", 0, 0, 1 },
1837 { "-NSOpenTemp", 0, 0, 1 },
1838 { "-GSFilePath", 0, 0, 1 },
1839 #endif
1840 /* This should be processed after ordinary file name args and the like. */
1841 { "-kill", "--kill", -10, 0 },
1844 /* Reorder the elements of ARGV (assumed to have ARGC elements)
1845 so that the highest priority ones come first.
1846 Do not change the order of elements of equal priority.
1847 If an option takes an argument, keep it and its argument together.
1849 If an option that takes no argument appears more
1850 than once, eliminate all but one copy of it. */
1852 static void
1853 sort_args (argc, argv)
1854 int argc;
1855 char **argv;
1857 char **new = (char **) xmalloc (sizeof (char *) * argc);
1858 /* For each element of argv,
1859 the corresponding element of options is:
1860 0 for an option that takes no arguments,
1861 1 for an option that takes one argument, etc.
1862 -1 for an ordinary non-option argument. */
1863 int *options = (int *) xmalloc (sizeof (int) * argc);
1864 int *priority = (int *) xmalloc (sizeof (int) * argc);
1865 int to = 1;
1866 int incoming_used = 1;
1867 int from;
1868 int i;
1870 /* Categorize all the options,
1871 and figure out which argv elts are option arguments. */
1872 for (from = 1; from < argc; from++)
1874 options[from] = -1;
1875 priority[from] = 0;
1876 if (argv[from][0] == '-')
1878 int match, thislen;
1879 char *equals;
1881 /* If we have found "--", don't consider
1882 any more arguments as options. */
1883 if (argv[from][1] == '-' && argv[from][2] == 0)
1885 /* Leave the "--", and everything following it, at the end. */
1886 for (; from < argc; from++)
1888 priority[from] = -100;
1889 options[from] = -1;
1891 break;
1894 /* Look for a match with a known old-fashioned option. */
1895 for (i = 0; i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1896 if (!strcmp (argv[from], standard_args[i].name))
1898 options[from] = standard_args[i].nargs;
1899 priority[from] = standard_args[i].priority;
1900 if (from + standard_args[i].nargs >= argc)
1901 fatal ("Option `%s' requires an argument\n", argv[from]);
1902 from += standard_args[i].nargs;
1903 goto done;
1906 /* Look for a match with a known long option.
1907 MATCH is -1 if no match so far, -2 if two or more matches so far,
1908 >= 0 (the table index of the match) if just one match so far. */
1909 if (argv[from][1] == '-')
1911 match = -1;
1912 thislen = strlen (argv[from]);
1913 equals = index (argv[from], '=');
1914 if (equals != 0)
1915 thislen = equals - argv[from];
1917 for (i = 0;
1918 i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1919 if (standard_args[i].longname
1920 && !strncmp (argv[from], standard_args[i].longname,
1921 thislen))
1923 if (match == -1)
1924 match = i;
1925 else
1926 match = -2;
1929 /* If we found exactly one match, use that. */
1930 if (match >= 0)
1932 options[from] = standard_args[match].nargs;
1933 priority[from] = standard_args[match].priority;
1934 /* If --OPTION=VALUE syntax is used,
1935 this option uses just one argv element. */
1936 if (equals != 0)
1937 options[from] = 0;
1938 if (from + options[from] >= argc)
1939 fatal ("Option `%s' requires an argument\n", argv[from]);
1940 from += options[from];
1942 /* FIXME When match < 0, shouldn't there be some error,
1943 or at least indication to the user that there was a
1944 problem? */
1946 done: ;
1950 /* Copy the arguments, in order of decreasing priority, to NEW. */
1951 new[0] = argv[0];
1952 while (incoming_used < argc)
1954 int best = -1;
1955 int best_priority = -9999;
1957 /* Find the highest priority remaining option.
1958 If several have equal priority, take the first of them. */
1959 for (from = 1; from < argc; from++)
1961 if (argv[from] != 0 && priority[from] > best_priority)
1963 best_priority = priority[from];
1964 best = from;
1966 /* Skip option arguments--they are tied to the options. */
1967 if (options[from] > 0)
1968 from += options[from];
1971 if (best < 0)
1972 abort ();
1974 /* Copy the highest priority remaining option, with its args, to NEW.
1975 Unless it is a duplicate of the previous one. */
1976 if (! (options[best] == 0
1977 && ! strcmp (new[to - 1], argv[best])))
1979 new[to++] = argv[best];
1980 for (i = 0; i < options[best]; i++)
1981 new[to++] = argv[best + i + 1];
1984 incoming_used += 1 + (options[best] > 0 ? options[best] : 0);
1986 /* Clear out this option in ARGV. */
1987 argv[best] = 0;
1988 for (i = 0; i < options[best]; i++)
1989 argv[best + i + 1] = 0;
1992 /* If duplicate options were deleted, fill up extra space with null ptrs. */
1993 while (to < argc)
1994 new[to++] = 0;
1996 bcopy (new, argv, sizeof (char *) * argc);
1998 xfree (options);
1999 xfree (new);
2000 xfree (priority);
2003 DEFUN ("kill-emacs", Fkill_emacs, Skill_emacs, 0, 1, "P",
2004 doc: /* Exit the Emacs job and kill it.
2005 If ARG is an integer, return ARG as the exit program code.
2006 If ARG is a string, stuff it as keyboard input.
2008 The value of `kill-emacs-hook', if not void,
2009 is a list of functions (of no args),
2010 all of which are called before Emacs is actually killed. */)
2011 (arg)
2012 Lisp_Object arg;
2014 struct gcpro gcpro1;
2016 GCPRO1 (arg);
2018 if (feof (stdin))
2019 arg = Qt;
2021 if (!NILP (Vrun_hooks) && !noninteractive)
2022 call1 (Vrun_hooks, intern ("kill-emacs-hook"));
2024 UNGCPRO;
2026 shut_down_emacs (0, 0, STRINGP (arg) ? arg : Qnil);
2028 /* If we have an auto-save list file,
2029 kill it because we are exiting Emacs deliberately (not crashing).
2030 Do it after shut_down_emacs, which does an auto-save. */
2031 if (STRINGP (Vauto_save_list_file_name))
2032 unlink (SDATA (Vauto_save_list_file_name));
2034 exit (INTEGERP (arg) ? XINT (arg) : EXIT_SUCCESS);
2035 /* NOTREACHED */
2036 return Qnil;
2040 /* Perform an orderly shutdown of Emacs. Autosave any modified
2041 buffers, kill any child processes, clean up the terminal modes (if
2042 we're in the foreground), and other stuff like that. Don't perform
2043 any redisplay; this may be called when Emacs is shutting down in
2044 the background, or after its X connection has died.
2046 If SIG is a signal number, print a message for it.
2048 This is called by fatal signal handlers, X protocol error handlers,
2049 and Fkill_emacs. */
2051 void
2052 shut_down_emacs (sig, no_x, stuff)
2053 int sig, no_x;
2054 Lisp_Object stuff;
2056 /* Prevent running of hooks from now on. */
2057 Vrun_hooks = Qnil;
2059 /* Don't update display from now on. */
2060 Vinhibit_redisplay = Qt;
2062 /* If we are controlling the terminal, reset terminal modes. */
2063 #ifdef EMACS_HAVE_TTY_PGRP
2065 int pgrp = EMACS_GETPGRP (0);
2067 int tpgrp;
2068 if (EMACS_GET_TTY_PGRP (0, &tpgrp) != -1
2069 && tpgrp == pgrp)
2071 reset_all_sys_modes ();
2072 if (sig && sig != SIGTERM)
2073 fprintf (stderr, "Fatal error (%d)", sig);
2076 #else
2077 fflush (stdout);
2078 reset_all_sys_modes ();
2079 #endif
2081 stuff_buffered_input (stuff);
2083 #ifdef subprocesses
2084 inhibit_sentinels = 1;
2085 #endif
2086 kill_buffer_processes (Qnil);
2087 Fdo_auto_save (Qt, Qnil);
2089 #ifdef CLASH_DETECTION
2090 unlock_all_files ();
2091 #endif
2093 #if 0 /* This triggers a bug in XCloseDisplay and is not needed. */
2094 #ifdef HAVE_X_WINDOWS
2095 /* It's not safe to call intern here. Maybe we are crashing. */
2096 if (!noninteractive && SYMBOLP (Vinitial_window_system)
2097 && SCHARS (SYMBOL_NAME (Vinitial_window_system)) == 1
2098 && SREF (SYMBOL_NAME (Vinitial_window_system), 0) == 'x'
2099 && ! no_x)
2100 Fx_close_current_connection ();
2101 #endif /* HAVE_X_WINDOWS */
2102 #endif
2104 #ifdef SIGIO
2105 /* There is a tendency for a SIGIO signal to arrive within exit,
2106 and cause a SIGHUP because the input descriptor is already closed. */
2107 unrequest_sigio ();
2108 signal (SIGIO, SIG_IGN);
2109 #endif
2111 #ifdef WINDOWSNT
2112 term_ntproc ();
2113 #endif
2115 /* Do this only if terminating normally, we want glyph matrices
2116 etc. in a core dump. */
2117 if (sig == 0 || sig == SIGTERM)
2119 check_glyph_memory ();
2120 check_message_stack ();
2123 #ifdef MSDOS
2124 dos_cleanup ();
2125 #endif
2127 #ifdef HAVE_NS
2128 ns_term_shutdown (sig);
2129 #endif
2134 #ifndef CANNOT_DUMP
2136 #ifdef HAVE_SHM
2138 DEFUN ("dump-emacs-data", Fdump_emacs_data, Sdump_emacs_data, 1, 1, 0,
2139 doc: /* Dump current state of Emacs into data file FILENAME.
2140 This function exists on systems that use HAVE_SHM. */)
2141 (filename)
2142 Lisp_Object filename;
2144 extern char my_edata[];
2145 Lisp_Object tem;
2147 check_pure_size ();
2148 CHECK_STRING (filename);
2149 filename = Fexpand_file_name (filename, Qnil);
2151 tem = Vpurify_flag;
2152 Vpurify_flag = Qnil;
2154 fflush (stdout);
2155 /* Tell malloc where start of impure now is. */
2156 /* Also arrange for warnings when nearly out of space. */
2157 #ifndef SYSTEM_MALLOC
2158 memory_warnings (my_edata, malloc_warning);
2159 #endif
2160 map_out_data (SDATA (filename));
2162 Vpurify_flag = tem;
2164 return Qnil;
2167 #else /* not HAVE_SHM */
2169 DEFUN ("dump-emacs", Fdump_emacs, Sdump_emacs, 2, 2, 0,
2170 doc: /* Dump current state of Emacs into executable file FILENAME.
2171 Take symbols from SYMFILE (presumably the file you executed to run Emacs).
2172 This is used in the file `loadup.el' when building Emacs.
2174 You must run Emacs in batch mode in order to dump it. */)
2175 (filename, symfile)
2176 Lisp_Object filename, symfile;
2178 extern char my_edata[];
2179 Lisp_Object tem;
2180 Lisp_Object symbol;
2181 int count = SPECPDL_INDEX ();
2183 check_pure_size ();
2185 if (! noninteractive)
2186 error ("Dumping Emacs works only in batch mode");
2188 #ifdef GNU_LINUX
2189 if (heap_bss_diff > MAX_HEAP_BSS_DIFF)
2191 fprintf (stderr, "**************************************************\n");
2192 fprintf (stderr, "Warning: Your system has a gap between BSS and the\n");
2193 fprintf (stderr, "heap (%lu bytes). This usually means that exec-shield\n",
2194 heap_bss_diff);
2195 fprintf (stderr, "or something similar is in effect. The dump may\n");
2196 fprintf (stderr, "fail because of this. See the section about\n");
2197 fprintf (stderr, "exec-shield in etc/PROBLEMS for more information.\n");
2198 fprintf (stderr, "**************************************************\n");
2200 #endif /* GNU_LINUX */
2202 /* Bind `command-line-processed' to nil before dumping,
2203 so that the dumped Emacs will process its command line
2204 and set up to work with X windows if appropriate. */
2205 symbol = intern ("command-line-processed");
2206 specbind (symbol, Qnil);
2208 CHECK_STRING (filename);
2209 filename = Fexpand_file_name (filename, Qnil);
2210 if (!NILP (symfile))
2212 CHECK_STRING (symfile);
2213 if (SCHARS (symfile))
2214 symfile = Fexpand_file_name (symfile, Qnil);
2217 tem = Vpurify_flag;
2218 Vpurify_flag = Qnil;
2220 #ifdef HAVE_TZSET
2221 set_time_zone_rule (dump_tz);
2222 #ifndef LOCALTIME_CACHE
2223 /* Force a tz reload, since set_time_zone_rule doesn't. */
2224 tzset ();
2225 #endif
2226 #endif
2228 fflush (stdout);
2229 /* Tell malloc where start of impure now is. */
2230 /* Also arrange for warnings when nearly out of space. */
2231 #ifndef SYSTEM_MALLOC
2232 #ifndef WINDOWSNT
2233 /* On Windows, this was done before dumping, and that once suffices.
2234 Meanwhile, my_edata is not valid on Windows. */
2235 memory_warnings (my_edata, malloc_warning);
2236 #endif /* not WINDOWSNT */
2237 #endif
2238 #if !defined (SYSTEM_MALLOC) && defined (HAVE_GTK_AND_PTHREAD) && !defined SYNC_INPUT
2239 /* Pthread may call malloc before main, and then we will get an endless
2240 loop, because pthread_self (see alloc.c) calls malloc the first time
2241 it is called on some systems. */
2242 reset_malloc_hooks ();
2243 #endif
2244 #ifdef DOUG_LEA_MALLOC
2245 malloc_state_ptr = malloc_get_state ();
2246 #endif
2248 #ifdef USE_MMAP_FOR_BUFFERS
2249 mmap_set_vars (0);
2250 #endif
2251 unexec (SDATA (filename),
2252 !NILP (symfile) ? SDATA (symfile) : 0, my_edata, 0, 0);
2253 #ifdef USE_MMAP_FOR_BUFFERS
2254 mmap_set_vars (1);
2255 #endif
2256 #ifdef DOUG_LEA_MALLOC
2257 free (malloc_state_ptr);
2258 #endif
2260 Vpurify_flag = tem;
2262 return unbind_to (count, Qnil);
2265 #endif /* not HAVE_SHM */
2267 #endif /* not CANNOT_DUMP */
2269 #if HAVE_SETLOCALE
2270 /* Recover from setlocale (LC_ALL, ""). */
2271 void
2272 fixup_locale ()
2274 /* The Emacs Lisp reader needs LC_NUMERIC to be "C",
2275 so that numbers are read and printed properly for Emacs Lisp. */
2276 setlocale (LC_NUMERIC, "C");
2279 /* Set system locale CATEGORY, with previous locale *PLOCALE, to
2280 DESIRED_LOCALE. */
2281 static void
2282 synchronize_locale (category, plocale, desired_locale)
2283 int category;
2284 Lisp_Object *plocale;
2285 Lisp_Object desired_locale;
2287 if (! EQ (*plocale, desired_locale))
2289 *plocale = desired_locale;
2290 setlocale (category, (STRINGP (desired_locale)
2291 ? (char *) SDATA (desired_locale)
2292 : ""));
2296 /* Set system time locale to match Vsystem_time_locale, if possible. */
2297 void
2298 synchronize_system_time_locale ()
2300 synchronize_locale (LC_TIME, &Vprevious_system_time_locale,
2301 Vsystem_time_locale);
2304 /* Set system messages locale to match Vsystem_messages_locale, if
2305 possible. */
2306 void
2307 synchronize_system_messages_locale ()
2309 #ifdef LC_MESSAGES
2310 synchronize_locale (LC_MESSAGES, &Vprevious_system_messages_locale,
2311 Vsystem_messages_locale);
2312 #endif
2314 #endif /* HAVE_SETLOCALE */
2316 #ifndef SEPCHAR
2317 #define SEPCHAR ':'
2318 #endif
2320 Lisp_Object
2321 decode_env_path (evarname, defalt)
2322 char *evarname, *defalt;
2324 register char *path, *p;
2325 Lisp_Object lpath, element, tem;
2327 /* It's okay to use getenv here, because this function is only used
2328 to initialize variables when Emacs starts up, and isn't called
2329 after that. */
2330 if (evarname != 0)
2331 path = (char *) getenv (evarname);
2332 else
2333 path = 0;
2334 if (!path)
2335 path = defalt;
2336 #ifdef DOS_NT
2337 /* Ensure values from the environment use the proper directory separator. */
2338 if (path)
2340 p = alloca (strlen (path) + 1);
2341 strcpy (p, path);
2342 path = p;
2344 if ('/' == DIRECTORY_SEP)
2345 dostounix_filename (path);
2346 else
2347 unixtodos_filename (path);
2349 #endif
2350 lpath = Qnil;
2351 while (1)
2353 p = index (path, SEPCHAR);
2354 if (!p) p = path + strlen (path);
2355 element = (p - path ? make_string (path, p - path)
2356 : build_string ("."));
2358 /* Add /: to the front of the name
2359 if it would otherwise be treated as magic. */
2360 tem = Ffind_file_name_handler (element, Qt);
2362 /* However, if the handler says "I'm safe",
2363 don't bother adding /:. */
2364 if (SYMBOLP (tem))
2366 Lisp_Object prop;
2367 prop = Fget (tem, intern ("safe-magic"));
2368 if (! NILP (prop))
2369 tem = Qnil;
2372 if (! NILP (tem))
2373 element = concat2 (build_string ("/:"), element);
2375 lpath = Fcons (element, lpath);
2376 if (*p)
2377 path = p + 1;
2378 else
2379 break;
2381 return Fnreverse (lpath);
2384 DEFUN ("daemonp", Fdaemonp, Sdaemonp, 0, 0, 0,
2385 doc: /* Return t if the current emacs process is a daemon. */)
2388 return is_daemon ? Qt : Qnil;
2391 void
2392 syms_of_emacs ()
2394 Qfile_name_handler_alist = intern ("file-name-handler-alist");
2395 staticpro (&Qfile_name_handler_alist);
2397 #ifndef CANNOT_DUMP
2398 #ifdef HAVE_SHM
2399 defsubr (&Sdump_emacs_data);
2400 #else
2401 defsubr (&Sdump_emacs);
2402 #endif
2403 #endif
2405 defsubr (&Skill_emacs);
2407 defsubr (&Sinvocation_name);
2408 defsubr (&Sinvocation_directory);
2409 defsubr (&Sdaemonp);
2411 DEFVAR_LISP ("command-line-args", &Vcommand_line_args,
2412 doc: /* Args passed by shell to Emacs, as a list of strings.
2413 Many arguments are deleted from the list as they are processed. */);
2415 DEFVAR_LISP ("system-type", &Vsystem_type,
2416 doc: /* Value is symbol indicating type of operating system you are using.
2417 Special values:
2418 `gnu' compiled for a GNU Hurd system.
2419 `gnu/linux' compiled for a GNU/Linux system.
2420 `darwin' compiled for Darwin (GNU-Darwin, Mac OS X, ...).
2421 `ms-dos' compiled as an MS-DOS application.
2422 `windows-nt' compiled as a native W32 application.
2423 `cygwin' compiled using the Cygwin library.
2424 Anything else indicates some sort of Unix system. */);
2425 Vsystem_type = intern (SYSTEM_TYPE);
2427 DEFVAR_LISP ("system-configuration", &Vsystem_configuration,
2428 doc: /* Value is string indicating configuration Emacs was built for.
2429 On MS-Windows, the value reflects the OS flavor and version on which
2430 Emacs is running. */);
2431 Vsystem_configuration = build_string (EMACS_CONFIGURATION);
2433 DEFVAR_LISP ("system-configuration-options", &Vsystem_configuration_options,
2434 doc: /* String containing the configuration options Emacs was built with. */);
2435 Vsystem_configuration_options = build_string (EMACS_CONFIG_OPTIONS);
2437 DEFVAR_BOOL ("noninteractive", &noninteractive1,
2438 doc: /* Non-nil means Emacs is running without interactive terminal. */);
2440 DEFVAR_LISP ("kill-emacs-hook", &Vkill_emacs_hook,
2441 doc: /* Hook to be run when `kill-emacs' is called.
2442 Since `kill-emacs' may be invoked when the terminal is disconnected (or
2443 in other similar situations), functions placed on this hook should not
2444 expect to be able to interact with the user. To ask for confirmation,
2445 see `kill-emacs-query-functions' instead.
2447 The hook is not run in batch mode, i.e., if `noninteractive' is non-nil. */);
2448 Vkill_emacs_hook = Qnil;
2450 DEFVAR_INT ("emacs-priority", &emacs_priority,
2451 doc: /* Priority for Emacs to run at.
2452 This value is effective only if set before Emacs is dumped,
2453 and only if the Emacs executable is installed with setuid to permit
2454 it to change priority. (Emacs sets its uid back to the real uid.)
2455 Currently, you need to define SET_EMACS_PRIORITY in `config.h'
2456 before you compile Emacs, to enable the code for this feature. */);
2457 emacs_priority = 0;
2459 DEFVAR_LISP ("path-separator", &Vpath_separator,
2460 doc: /* String containing the character that separates directories in
2461 search paths, such as PATH and other similar environment variables. */);
2463 char c = SEPCHAR;
2464 Vpath_separator = make_string (&c, 1);
2467 DEFVAR_LISP ("invocation-name", &Vinvocation_name,
2468 doc: /* The program name that was used to run Emacs.
2469 Any directory names are omitted. */);
2471 DEFVAR_LISP ("invocation-directory", &Vinvocation_directory,
2472 doc: /* The directory in which the Emacs executable was found, to run it.
2473 The value is nil if that directory's name is not known. */);
2475 DEFVAR_LISP ("installation-directory", &Vinstallation_directory,
2476 doc: /* A directory within which to look for the `lib-src' and `etc' directories.
2477 This is non-nil when we can't find those directories in their standard
2478 installed locations, but we can find them near where the Emacs executable
2479 was found. */);
2480 Vinstallation_directory = Qnil;
2482 DEFVAR_LISP ("system-messages-locale", &Vsystem_messages_locale,
2483 doc: /* System locale for messages. */);
2484 Vsystem_messages_locale = Qnil;
2486 DEFVAR_LISP ("previous-system-messages-locale",
2487 &Vprevious_system_messages_locale,
2488 doc: /* Most recently used system locale for messages. */);
2489 Vprevious_system_messages_locale = Qnil;
2491 DEFVAR_LISP ("system-time-locale", &Vsystem_time_locale,
2492 doc: /* System locale for time. */);
2493 Vsystem_time_locale = Qnil;
2495 DEFVAR_LISP ("previous-system-time-locale", &Vprevious_system_time_locale,
2496 doc: /* Most recently used system locale for time. */);
2497 Vprevious_system_time_locale = Qnil;
2499 DEFVAR_LISP ("before-init-time", &Vbefore_init_time,
2500 doc: /* Value of `current-time' before Emacs begins initialization. */);
2501 Vbefore_init_time = Qnil;
2503 DEFVAR_LISP ("after-init-time", &Vafter_init_time,
2504 doc: /* Value of `current-time' after loading the init files.
2505 This is nil during initialization. */);
2506 Vafter_init_time = Qnil;
2509 /* arch-tag: 7bfd356a-c720-4612-8ab6-aa4222931c2e
2510 (do not change this comment) */