lisp/progmodes/prog-mode.el: Force font-lock to deal with `composition' prop.
[bpt/emacs.git] / src / emacs.c
CommitLineData
f927c5ae 1/* Fully extensible Emacs, running on Unix, intended for GNU.
bd6bc222 2
ab422c4d
PE
3Copyright (C) 1985-1987, 1993-1995, 1997-1999, 2001-2013 Free Software
4Foundation, Inc.
f927c5ae
JB
5
6This file is part of GNU Emacs.
7
9ec0b715 8GNU Emacs is free software: you can redistribute it and/or modify
f927c5ae 9it under the terms of the GNU General Public License as published by
9ec0b715
GM
10the Free Software Foundation, either version 3 of the License, or
11(at your option) any later version.
f927c5ae
JB
12
13GNU Emacs is distributed in the hope that it will be useful,
14but WITHOUT ANY WARRANTY; without even the implied warranty of
15MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16GNU General Public License for more details.
17
18You should have received a copy of the GNU General Public License
9ec0b715 19along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
f927c5ae
JB
20
21
68c45bf0 22#include <config.h>
f927c5ae 23#include <errno.h>
f927c5ae
JB
24#include <stdio.h>
25
26#include <sys/types.h>
27#include <sys/file.h>
cda4a5fd 28#include <unistd.h>
cda4a5fd 29
7ccfb720 30#include <close-stream.h>
01108e3f
PE
31#include <ignore-value.h>
32
0898ca10
JB
33#include "lisp.h"
34
edd3ff1d
JR
35#ifdef WINDOWSNT
36#include <fcntl.h>
52c7f9ee 37#include "w32.h"
0fda9b75
DC
38#include "w32heap.h"
39#endif
40
a9e7a9d5 41#if defined WINDOWSNT || defined HAVE_NTGUI
0fda9b75
DC
42#include "w32select.h"
43#include "w32font.h"
1cf1bbd5 44#include "w32common.h"
0fda9b75
DC
45#endif
46
3fc5e44a 47#if defined CYGWIN
0fda9b75 48#include "cygw32.h"
edd3ff1d
JR
49#endif
50
b3317662
FP
51#ifdef HAVE_WINDOW_SYSTEM
52#include TERM_HEADER
53#endif /* HAVE_WINDOW_SYSTEM */
54
edfda783
AR
55#ifdef NS_IMPL_GNUSTEP
56/* At least under Debian, GSConfig is in a subdirectory. --Stef */
57#include <GNUstepBase/GSConfig.h>
58#endif
59
f927c5ae 60#include "commands.h"
bef79ee4 61#include "intervals.h"
e5560ff7 62#include "character.h"
a08a816a 63#include "buffer.h"
3f6abfd7 64#include "window.h"
f927c5ae 65
edc8ae07 66#include "systty.h"
4d7e6e51 67#include "atimer.h"
6c3a4e9d 68#include "blockinput.h"
8090eb09 69#include "syssignal.h"
6c362a8b 70#include "process.h"
428a555e 71#include "frame.h"
5bda49c6 72#include "termhooks.h"
dfcf069d 73#include "keyboard.h"
e35f6ff7 74#include "keymap.h"
a41f8bed 75
8af55556
TZ
76#ifdef HAVE_GNUTLS
77#include "gnutls.h"
78#endif
79
9e4bf381
PE
80#if (defined PROFILING \
81 && (defined __FreeBSD__ || defined GNU_LINUX || defined __MINGW32__))
82# include <sys/gmon.h>
83extern void moncontrol (int mode);
84#endif
85
68c45bf0
PE
86#ifdef HAVE_SETLOCALE
87#include <locale.h>
88#endif
89
53c58b5d
RS
90#ifdef HAVE_SETRLIMIT
91#include <sys/time.h>
92#include <sys/resource.h>
93#endif
94
dede2792
JD
95#ifdef HAVE_PERSONALITY_LINUX32
96#include <sys/personality.h>
97#endif
98
16fab143 99static const char emacs_version[] = VERSION;
78f83752 100static const char emacs_copyright[] = COPYRIGHT;
8c5ff6dd 101
7e9fa161
JB
102/* Empty lisp strings. To avoid having to build any others. */
103Lisp_Object empty_unibyte_string, empty_multibyte_string;
f9a6326d 104
aa15c6bb
JB
105#ifdef WINDOWSNT
106/* Cache for externally loaded libraries. */
107Lisp_Object Vlibrary_cache;
108#endif
109
1882aa38
PE
110/* Set after Emacs has started up the first time.
111 Prevents reinitialization of the Lisp world and keymaps
112 on subsequent starts. */
113bool initialized;
f927c5ae 114
4393663b
JD
115#ifdef DARWIN_OS
116extern void unexec_init_emacs_zone (void);
117#endif
118
15aaf1b5
RS
119#ifdef DOUG_LEA_MALLOC
120/* Preserves a pointer to the memory allocated that copies that
121 static data inside glibc's malloc. */
35f08c38 122static void *malloc_state_ptr;
15aaf1b5 123/* From glibc, a routine that returns a copy of the malloc internal state. */
dd4c5104 124extern void *malloc_get_state (void);
15aaf1b5 125/* From glibc, a routine that overwrites the malloc internal state. */
dd4c5104 126extern int malloc_set_state (void*);
1882aa38 127/* True if the MALLOC_CHECK_ environment variable was set while
7c9cd446 128 dumping. Used to work around a bug in glibc's malloc. */
1882aa38 129static bool malloc_using_checking;
15aaf1b5
RS
130#endif
131
213d0b1f
RS
132Lisp_Object Qfile_name_handler_alist;
133
9dc3366b
GM
134Lisp_Object Qrisky_local_variable;
135
593a5f2e
PE
136Lisp_Object Qkill_emacs;
137static Lisp_Object Qkill_emacs_hook;
6c07aac2 138
1882aa38 139/* If true, Emacs should not attempt to use a window-specific code,
7db35a48 140 but instead should use the virtual terminal under which it was started. */
1882aa38 141bool inhibit_window_system;
f927c5ae 142
1882aa38 143/* If true, a filter or a sentinel is running. Tested to save the match
7db35a48 144 data on the first attempt to change it inside asynchronous code. */
1882aa38 145bool running_asynch_code;
7074fde6 146
5e617bc2 147#if defined (HAVE_X_WINDOWS) || defined (HAVE_NS)
1882aa38
PE
148/* If true, -d was specified, meaning we're using some window system. */
149bool display_arg;
f927c5ae
JB
150#endif
151
152/* An address near the bottom of the stack.
153 Tells GC how to save a copy of the stack. */
154char *stack_bottom;
155
2949f33b 156#if defined (DOUG_LEA_MALLOC) || defined (GNU_LINUX)
dede2792
JD
157/* The address where the heap starts (from the first sbrk (0) call). */
158static void *my_heap_start;
2949f33b 159#endif
dede2792 160
b312a492 161#ifdef GNU_LINUX
dede2792 162/* The gap between BSS end and heap start as far as we can tell. */
b312a492
PE
163static uprintmax_t heap_bss_diff;
164#endif
dede2792 165
ce9f00e4
DC
166/* To run as a daemon under Cocoa or Windows, we must do a fork+exec,
167 not a simple fork.
168
169 On Cocoa, CoreFoundation lib fails in forked process:
170 http://developer.apple.com/ReleaseNotes/
171 CoreFoundation/CoreFoundation.html)
172
173 On Windows, a Cygwin fork child cannot access the USER subsystem.
174
175 We mark being in the exec'd process by a daemon name argument of
176 form "--daemon=\nFD0,FD1\nNAME" where FD are the pipe file descriptors,
177 NAME is the original daemon name, if any. */
a9e7a9d5 178#if defined NS_IMPL_COCOA || (defined HAVE_NTGUI && defined CYGWIN)
ce9f00e4
DC
179# define DAEMON_MUST_EXEC
180#endif
181
1882aa38
PE
182/* True means running Emacs without interactive terminal. */
183bool noninteractive;
f927c5ae 184
1882aa38
PE
185/* True means remove site-lisp directories from load-path. */
186bool no_site_lisp;
66b7b0fe 187
4ff029f6
DN
188/* Name for the server started by the daemon.*/
189static char *daemon_name;
eab2ee89 190
5790ef40
DN
191/* Pipe used to send exit notification to the daemon parent at
192 startup. */
ff808935 193int daemon_pipe[2];
fc012771 194
e29f86e4
RS
195/* Save argv and argc. */
196char **initial_argv;
197int initial_argc;
081bef73 198
dd4c5104 199static void sort_args (int argc, char **argv);
35f08c38 200static void syms_of_emacs (void);
bd4590ba 201
6b61353c
KH
202/* MSVC needs each string be shorter than 2048 bytes, so the usage
203 strings below are split to not overflow this limit. */
73ebcd25 204#define USAGE1 "\
bd4590ba
GM
205Usage: %s [OPTION-OR-FILENAME]...\n\
206\n\
207Run Emacs, the extensible, customizable, self-documenting real-time\n\
208display editor. The recommended way to start Emacs for normal editing\n\
209is with no options at all.\n\
210\n\
49ca717b 211Run M-x info RET m emacs RET m emacs invocation RET inside Emacs to\n\
bd4590ba
GM
212read the main documentation for these command-line arguments.\n\
213\n\
214Initialization options:\n\
215\n\
6b61353c 216--batch do not do interactive display; implies -q\n\
f63d0028 217--chdir DIR change to directory DIR\n\
598898a7 218--daemon start a server in the background\n\
6b61353c
KH
219--debug-init enable Emacs Lisp debugger for init file\n\
220--display, -d DISPLAY use X server DISPLAY\n\
6b61353c
KH
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\
66b7b0fe 225--no-site-lisp, -nsl do not add site-lisp directories to load-path\n\
6b61353c 226--no-splash do not display a splash screen on startup\n\
2ff86b4e 227--no-window-system, -nw do not communicate with X, ignoring $DISPLAY\n\
66b7b0fe
GM
228--quick, -Q equivalent to:\n\
229 -q --no-site-file --no-site-lisp --no-splash\n\
6b61353c
KH
230--script FILE run FILE as an Emacs Lisp script\n\
231--terminal, -t DEVICE use DEVICE for terminal I/O\n\
6b61353c
KH
232--user, -u USER load ~USER/.emacs instead of your own\n\
233\n%s"
234
235#define USAGE2 "\
bd4590ba
GM
236Action options:\n\
237\n\
6b61353c 238FILE visit FILE using find-file\n\
9020b223
GM
239+LINE go to line LINE in next FILE\n\
240+LINE:COLUMN go to line LINE, column COLUMN, in next FILE\n\
6b61353c
KH
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\
73ebcd25
AI
251\n"
252
6b61353c 253#define USAGE3 "\
5b2ca26b 254Display options:\n\
bd4590ba 255\n\
6b61353c 256--background-color, -bg COLOR window background color\n\
2ff86b4e
NR
257--basic-display, -D disable many display features;\n\
258 used for debugging Emacs\n\
6b61353c
KH
259--border-color, -bd COLOR main border color\n\
260--border-width, -bw WIDTH width of main border\n\
ced74849 261--color, --color=MODE override color mode for character terminals;\n\
62973b41
JB
262 MODE defaults to `auto', and\n\
263 can also be `never', `always',\n\
6b61353c
KH
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\
62973b41 269--fullscreen, -fs make the first frame fullscreen\n\
6b61353c 270--fullwidth, -fw make the first frame wide as the screen\n\
3f1c6666 271--maximized, -mm make the first frame maximized\n\
6b61353c 272--geometry, -g GEOMETRY window geometry\n\
f9e36a6d 273--no-bitmap-icon, -nbi do not use picture of gnu for Emacs icon\n\
6b61353c
KH
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\
49ca717b 279--no-blinking-cursor, -nbc disable blinking cursor\n\
6b61353c
KH
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\
1540a61a 284--parent-id XID set parent window\n\
6b61353c
KH
285--help display this help and exit\n\
286--version output version information and exit\n\
07beadff
JR
287\n"
288
289#define USAGE4 "\
bd4590ba
GM
290You can generally also specify long option names with a single -; for\n\
291example, -batch as well as --batch. You can use any unambiguous\n\
292abbreviation for a --option.\n\
293\n\
294Various environment variables and window system resources also affect\n\
295Emacs' operation. See the main documentation.\n\
07beadff 296\n\
17284745 297Report bugs to bug-gnu-emacs@gnu.org. First, please see the Bugs\n\
bd4590ba
GM
298section of the Emacs manual or the file BUGS.\n"
299
f927c5ae 300\f
1882aa38
PE
301/* True if handling a fatal error already. */
302bool fatal_error_in_progress;
f927c5ae 303
204ee57f
JD
304#ifdef HAVE_NS
305/* NS autrelease pool, for memory management. */
306static void *ns_pool;
9e4bf381
PE
307#endif
308
204ee57f 309
4fab758d 310
cf29dd84
PE
311/* Report a fatal error due to signal SIG, output a backtrace of at
312 most BACKTRACE_LIMIT lines, and exit. */
313_Noreturn void
4d7e6e51 314terminate_due_to_signal (int sig, int backtrace_limit)
cf29dd84 315{
62a1d661 316 signal (sig, SIG_DFL);
4d7e6e51 317 totally_unblock_input ();
061b7f94 318
f927c5ae 319 /* If fatal error occurs in code below, avoid infinite recursion. */
8090eb09
JB
320 if (! fatal_error_in_progress)
321 {
322 fatal_error_in_progress = 1;
f927c5ae 323
9c524fcb 324 if (sig == SIGTERM || sig == SIGHUP || sig == SIGINT)
f63d0028
JD
325 Fkill_emacs (make_number (sig));
326
1882aa38 327 shut_down_emacs (sig, Qnil);
cf29dd84 328 emacs_backtrace (backtrace_limit);
8090eb09 329 }
f927c5ae 330
8090eb09 331 /* Signal the same code; this time it will really be fatal.
4d7e6e51
PE
332 Since we're in a signal handler, the signal is blocked, so we
333 have to unblock it if we want to really receive it. */
29b89fe0 334#ifndef MSDOS
2fe28299
PE
335 {
336 sigset_t unblocked;
337 sigemptyset (&unblocked);
4d7e6e51 338 sigaddset (&unblocked, sig);
2fe28299
PE
339 pthread_sigmask (SIG_UNBLOCK, &unblocked, 0);
340 }
29b89fe0 341#endif
4fab758d 342
4d7e6e51 343 emacs_raise (sig);
cf29dd84
PE
344
345 /* This shouldn't be executed, but it prevents a warning. */
346 exit (1);
f927c5ae
JB
347}
348\f
7db35a48 349/* Code for dealing with Lisp access to the Unix command line. */
f927c5ae 350
dfcf069d 351static void
dd4c5104 352init_cmdargs (int argc, char **argv, int skip_args)
f927c5ae
JB
353{
354 register int i;
74f10ca7 355 Lisp_Object name, dir, handler;
d311d28c 356 ptrdiff_t count = SPECPDL_INDEX ();
213d0b1f 357 Lisp_Object raw_name;
f927c5ae 358
e29f86e4
RS
359 initial_argv = argv;
360 initial_argc = argc;
361
213d0b1f
RS
362 raw_name = build_string (argv[0]);
363
364 /* Add /: to the front of the name
365 if it would otherwise be treated as magic. */
74f10ca7
PE
366 handler = Ffind_file_name_handler (raw_name, Qt);
367 if (! NILP (handler))
213d0b1f
RS
368 raw_name = concat2 (build_string ("/:"), raw_name);
369
370 Vinvocation_name = Ffile_name_nondirectory (raw_name);
371 Vinvocation_directory = Ffile_name_directory (raw_name);
372
ace40a69
RS
373 /* If we got no directory in argv[0], search PATH to find where
374 Emacs actually came from. */
375 if (NILP (Vinvocation_directory))
376 {
377 Lisp_Object found;
378 int yes = openp (Vexec_path, Vinvocation_name,
10c0915e 379 Vexec_suffixes, &found, make_number (X_OK));
e443f843 380 if (yes == 1)
213d0b1f
RS
381 {
382 /* Add /: to the front of the name
383 if it would otherwise be treated as magic. */
74f10ca7
PE
384 handler = Ffind_file_name_handler (found, Qt);
385 if (! NILP (handler))
213d0b1f
RS
386 found = concat2 (build_string ("/:"), found);
387 Vinvocation_directory = Ffile_name_directory (found);
388 }
ace40a69 389 }
59653951 390
4133b300
RS
391 if (!NILP (Vinvocation_directory)
392 && NILP (Ffile_name_absolute_p (Vinvocation_directory)))
213d0b1f
RS
393 /* Emacs was started with relative path, like ./emacs.
394 Make it absolute. */
4133b300
RS
395 Vinvocation_directory = Fexpand_file_name (Vinvocation_directory, Qnil);
396
07f4d123
RS
397 Vinstallation_directory = Qnil;
398
399 if (!NILP (Vinvocation_directory))
400 {
401 dir = Vinvocation_directory;
76151e2c
EZ
402#ifdef WINDOWSNT
403 /* If we are running from the build directory, set DIR to the
404 src subdirectory of the Emacs tree, like on Posix
405 platforms. */
406 if (SBYTES (dir) > sizeof ("/i386/") - 1
407 && 0 == strcmp (SSDATA (dir) + SBYTES (dir) - sizeof ("/i386/") + 1,
408 "/i386/"))
409 dir = Fexpand_file_name (build_string ("../.."), dir);
410#else /* !WINDOWSNT */
411#endif
07f4d123
RS
412 name = Fexpand_file_name (Vinvocation_name, dir);
413 while (1)
414 {
f5ab9736 415 Lisp_Object tem, lib_src_exists;
07f4d123
RS
416 Lisp_Object etc_exists, info_exists;
417
f5ab9736
RS
418 /* See if dir contains subdirs for use by Emacs.
419 Check for the ones that would exist in a build directory,
420 not including lisp and info. */
421 tem = Fexpand_file_name (build_string ("lib-src"), dir);
422 lib_src_exists = Ffile_exists_p (tem);
de004cc6 423
70344b34 424#ifdef MSDOS
de004cc6
RS
425 /* MSDOS installations frequently remove lib-src, but we still
426 must set installation-directory, or else info won't find
427 its files (it uses the value of installation-directory). */
428 tem = Fexpand_file_name (build_string ("info"), dir);
429 info_exists = Ffile_exists_p (tem);
70344b34
EZ
430#else
431 info_exists = Qnil;
432#endif
de004cc6
RS
433
434 if (!NILP (lib_src_exists) || !NILP (info_exists))
07f4d123 435 {
f5ab9736
RS
436 tem = Fexpand_file_name (build_string ("etc"), dir);
437 etc_exists = Ffile_exists_p (tem);
438 if (!NILP (etc_exists))
07f4d123 439 {
f5ab9736
RS
440 Vinstallation_directory
441 = Ffile_name_as_directory (dir);
442 break;
07f4d123
RS
443 }
444 }
445
446 /* See if dir's parent contains those subdirs. */
f5ab9736
RS
447 tem = Fexpand_file_name (build_string ("../lib-src"), dir);
448 lib_src_exists = Ffile_exists_p (tem);
de004cc6 449
70344b34
EZ
450
451#ifdef MSDOS
452 /* See the MSDOS commentary above. */
de004cc6
RS
453 tem = Fexpand_file_name (build_string ("../info"), dir);
454 info_exists = Ffile_exists_p (tem);
70344b34
EZ
455#else
456 info_exists = Qnil;
457#endif
de004cc6
RS
458
459 if (!NILP (lib_src_exists) || !NILP (info_exists))
07f4d123 460 {
f5ab9736
RS
461 tem = Fexpand_file_name (build_string ("../etc"), dir);
462 etc_exists = Ffile_exists_p (tem);
463 if (!NILP (etc_exists))
07f4d123 464 {
f5ab9736
RS
465 tem = Fexpand_file_name (build_string (".."), dir);
466 Vinstallation_directory
467 = Ffile_name_as_directory (tem);
468 break;
07f4d123
RS
469 }
470 }
471
472 /* If the Emacs executable is actually a link,
473 next try the dir that the link points into. */
474 tem = Ffile_symlink_p (name);
475 if (!NILP (tem))
476 {
260ec24d 477 name = Fexpand_file_name (tem, dir);
07f4d123
RS
478 dir = Ffile_name_directory (name);
479 }
480 else
481 break;
482 }
483 }
484
f927c5ae
JB
485 Vcommand_line_args = Qnil;
486
487 for (i = argc - 1; i >= 0; i--)
488 {
489 if (i == 0 || i > skip_args)
a520393d
KH
490 /* For the moment, we keep arguments as is in unibyte strings.
491 They are decoded in the function command-line after we know
492 locale-coding-system. */
f927c5ae 493 Vcommand_line_args
68db37aa 494 = Fcons (make_unibyte_string (argv[i], strlen (argv[i])),
a520393d 495 Vcommand_line_args);
f927c5ae 496 }
213d0b1f
RS
497
498 unbind_to (count, Qnil);
f927c5ae 499}
59653951
JB
500
501DEFUN ("invocation-name", Finvocation_name, Sinvocation_name, 0, 0, 0,
7db35a48
PJ
502 doc: /* Return the program name that was used to run Emacs.
503Any directory names are omitted. */)
5842a27b 504 (void)
59653951
JB
505{
506 return Fcopy_sequence (Vinvocation_name);
507}
508
ace40a69 509DEFUN ("invocation-directory", Finvocation_directory, Sinvocation_directory,
7db35a48
PJ
510 0, 0, 0,
511 doc: /* Return the directory name in which the Emacs executable was located. */)
5842a27b 512 (void)
ace40a69
RS
513{
514 return Fcopy_sequence (Vinvocation_directory);
515}
516
f927c5ae 517\f
0269dedb
RS
518#ifdef HAVE_TZSET
519/* A valid but unlikely value for the TZ environment value.
520 It is OK (though a bit slower) if the user actually chooses this value. */
5745a7df 521static char const dump_tz[] = "UtC0";
0269dedb
RS
522#endif
523
e2925360
KH
524/* Test whether the next argument in ARGV matches SSTR or a prefix of
525 LSTR (at least MINLEN characters). If so, then if VALPTR is non-null
526 (the argument is supposed to have a value) store in *VALPTR either
527 the next argument or the portion of this one after the equal sign.
528 ARGV is read starting at position *SKIPPTR; this index is advanced
529 by the number of arguments used.
530
531 Too bad we can't just use getopt for all of this, but we don't have
532 enough information to do it right. */
081bef73 533
1882aa38 534static bool
62973b41
JB
535argmatch (char **argv, int argc, const char *sstr, const char *lstr,
536 int minlen, char **valptr, int *skipptr)
e2925360 537{
6bbd7a29 538 char *p = NULL;
0b963a93 539 ptrdiff_t arglen;
df6530f8
RS
540 char *arg;
541
542 /* Don't access argv[argc]; give up in advance. */
543 if (argc <= *skipptr + 1)
544 return 0;
545
546 arg = argv[*skipptr+1];
e2925360
KH
547 if (arg == NULL)
548 return 0;
549 if (strcmp (arg, sstr) == 0)
550 {
551 if (valptr != NULL)
552 {
553 *valptr = argv[*skipptr+2];
554 *skipptr += 2;
555 }
556 else
557 *skipptr += 1;
558 return 1;
559 }
8966b757 560 arglen = (valptr != NULL && (p = strchr (arg, '=')) != NULL
e2925360 561 ? p - arg : strlen (arg));
c03e1113 562 if (lstr == 0 || arglen < minlen || strncmp (arg, lstr, arglen) != 0)
e2925360
KH
563 return 0;
564 else if (valptr == NULL)
565 {
566 *skipptr += 1;
567 return 1;
568 }
569 else if (p != NULL)
570 {
571 *valptr = p+1;
572 *skipptr += 1;
573 return 1;
574 }
575 else if (argv[*skipptr+2] != NULL)
576 {
577 *valptr = argv[*skipptr+2];
578 *skipptr += 2;
579 return 1;
580 }
581 else
582 {
583 return 0;
584 }
585}
586
b6779252 587#ifdef DOUG_LEA_MALLOC
f927c5ae 588
b6779252
KH
589/* malloc can be invoked even before main (e.g. by the dynamic
590 linker), so the dumped malloc state must be restored as early as
591 possible using this special hook. */
592
593static void
dd4c5104 594malloc_initialize_hook (void)
b6779252 595{
15aaf1b5
RS
596 if (initialized)
597 {
7c9cd446
AS
598 if (!malloc_using_checking)
599 /* Work around a bug in glibc's malloc. MALLOC_CHECK_ must be
600 ignored if the heap to be restored was constructed without
d942e12a
AS
601 malloc checking. Can't use unsetenv, since that calls malloc. */
602 {
603 char **p;
604
a57c4026 605 for (p = environ; p && *p; p++)
d942e12a
AS
606 if (strncmp (*p, "MALLOC_CHECK_=", 14) == 0)
607 {
608 do
609 *p = p[1];
610 while (*++p);
611 break;
612 }
613 }
b6779252 614
15aaf1b5 615 malloc_set_state (malloc_state_ptr);
68db37aa 616#ifndef XMALLOC_OVERRUN_CHECK
15aaf1b5 617 free (malloc_state_ptr);
68db37aa 618#endif
15aaf1b5 619 }
7c9cd446 620 else
dede2792
JD
621 {
622 if (my_heap_start == 0)
623 my_heap_start = sbrk (0);
624 malloc_using_checking = getenv ("MALLOC_CHECK_") != NULL;
625 }
b6779252
KH
626}
627
698d32e2 628void (*__malloc_initialize_hook) (void) EXTERNALLY_VISIBLE = malloc_initialize_hook;
b6779252
KH
629
630#endif /* DOUG_LEA_MALLOC */
631
7ccfb720
PE
632/* Close standard output and standard error, reporting any write
633 errors as best we can. This is intended for use with atexit. */
634static void
635close_output_streams (void)
636{
637 if (close_stream (stdout) != 0)
638 {
639 fprintf (stderr, "Write error to standard output: %s\n",
76abf5e5 640 strerror (errno));
7ccfb720
PE
641 fflush (stderr);
642 _exit (EXIT_FAILURE);
643 }
644
645 if (close_stream (stderr) != 0)
646 _exit (EXIT_FAILURE);
647}
d883731c 648
b6779252
KH
649/* ARGSUSED */
650int
7c2fb837 651main (int argc, char **argv)
b6779252 652{
2313132f 653#if GC_MARK_STACK
39ec21ea
GM
654 Lisp_Object dummy;
655#endif
b6779252 656 char stack_bottom_variable;
1882aa38 657 bool do_initial_setlocale;
4d7e6e51 658 bool dumping;
b6779252 659 int skip_args = 0;
b6779252
KH
660#ifdef HAVE_SETRLIMIT
661 struct rlimit rlim;
662#endif
1882aa38 663 bool no_loadup = 0;
6e910e07 664 char *junk = 0;
4ff029f6 665 char *dname_arg = 0;
ce9f00e4 666#ifdef DAEMON_MUST_EXEC
b3243e6f 667 char dname_arg2[80];
a9e7a9d5 668#endif
f63d0028 669 char *ch_to_dir;
b6779252 670
2313132f 671#if GC_MARK_STACK
39ec21ea
GM
672 stack_base = &dummy;
673#endif
674
4ffea447 675#ifdef G_SLICE_ALWAYS_MALLOC
a4ef73c8 676 /* This is used by the Cygwin build. */
5745a7df 677 xputenv ("G_SLICE=always-malloc");
a4ef73c8
CY
678#endif
679
b312a492 680#ifdef GNU_LINUX
dede2792
JD
681 if (!initialized)
682 {
683 extern char my_endbss[];
684 extern char *my_endbss_static;
685
686 if (my_heap_start == 0)
687 my_heap_start = sbrk (0);
688
689 heap_bss_diff = (char *)my_heap_start - max (my_endbss, my_endbss_static);
690 }
b312a492 691#endif
dede2792 692
1cf1bbd5
DC
693#if defined WINDOWSNT || defined HAVE_NTGUI
694 /* Set global variables used to detect Windows version. Do this as
695 early as possible. (unexw32.c calls this function as well, but
696 the additional call here is harmless.) */
697 cache_system_info ();
698#endif
699
d785cf9e
RS
700#ifdef RUN_TIME_REMAP
701 if (initialized)
702 run_time_remap (argv[0]);
703#endif
704
14145fa3
AR
705/* If using unexmacosx.c (set by s/darwin.h), we must do this. */
706#ifdef DARWIN_OS
e0f712ba
AC
707 if (!initialized)
708 unexec_init_emacs_zone ();
709#endif
710
76abf5e5
PE
711 atexit (close_output_streams);
712
081bef73 713 sort_args (argc, argv);
956e3c7e
RS
714 argc = 0;
715 while (argv[argc]) argc++;
081bef73 716
8c5ff6dd 717 if (argmatch (argv, argc, "-version", "--version", 3, NULL, &skip_args))
1702afef 718 {
8c5ff6dd
KR
719 const char *version, *copyright;
720 if (initialized)
5cf9ca93 721 {
8c5ff6dd
KR
722 Lisp_Object tem, tem2;
723 tem = Fsymbol_value (intern_c_string ("emacs-version"));
724 tem2 = Fsymbol_value (intern_c_string ("emacs-copyright"));
725 if (!STRINGP (tem))
726 {
727 fprintf (stderr, "Invalid value of `emacs-version'\n");
728 exit (1);
729 }
730 if (!STRINGP (tem2))
731 {
732 fprintf (stderr, "Invalid value of `emacs-copyright'\n");
733 exit (1);
734 }
735 else
736 {
42a5b22f
PE
737 version = SSDATA (tem);
738 copyright = SSDATA (tem2);
8c5ff6dd 739 }
5cf9ca93 740 }
1702afef
RS
741 else
742 {
8c5ff6dd
KR
743 version = emacs_version;
744 copyright = emacs_copyright;
1702afef 745 }
8c5ff6dd
KR
746 printf ("GNU Emacs %s\n", version);
747 printf ("%s\n", copyright);
748 printf ("GNU Emacs comes with ABSOLUTELY NO WARRANTY.\n");
749 printf ("You may redistribute copies of Emacs\n");
750 printf ("under the terms of the GNU General Public License.\n");
751 printf ("For more information about these matters, ");
752 printf ("see the file named COPYING.\n");
753 exit (0);
1702afef 754 }
947f5e01
JM
755
756 if (argmatch (argv, argc, "-chdir", "--chdir", 4, &ch_to_dir, &skip_args))
757 if (chdir (ch_to_dir) == -1)
758 {
759 fprintf (stderr, "%s: Can't chdir to %s: %s\n",
760 argv[0], ch_to_dir, strerror (errno));
761 exit (1);
762 }
f63d0028 763
4d7e6e51
PE
764 dumping = !initialized && (strcmp (argv[argc - 1], "dump") == 0
765 || strcmp (argv[argc - 1], "bootstrap") == 0);
1702afef 766
dede2792 767#ifdef HAVE_PERSONALITY_LINUX32
4d7e6e51 768 if (dumping && ! getenv ("EMACS_HEAP_EXEC"))
dede2792 769 {
fd75ddb2 770 /* Set this so we only do this once. */
5745a7df 771 xputenv ("EMACS_HEAP_EXEC=true");
711877f3 772
fd75ddb2
JD
773 /* A flag to turn off address randomization which is introduced
774 in linux kernel shipped with fedora core 4 */
711877f3 775#define ADD_NO_RANDOMIZE 0x0040000
fd75ddb2 776 personality (PER_LINUX32 | ADD_NO_RANDOMIZE);
711877f3
MY
777#undef ADD_NO_RANDOMIZE
778
fd75ddb2 779 execvp (argv[0], argv);
dede2792 780
fd75ddb2
JD
781 /* If the exec fails, try to dump anyway. */
782 perror ("execvp");
dede2792
JD
783 }
784#endif /* HAVE_PERSONALITY_LINUX32 */
785
ea2acec5 786#if defined (HAVE_SETRLIMIT) && defined (RLIMIT_STACK)
6c2935e9
RS
787 /* Extend the stack space available.
788 Don't do that if dumping, since some systems (e.g. DJGPP)
789 might define a smaller stack limit at that time. */
790 if (1
791#ifndef CANNOT_DUMP
792 && (!noninteractive || initialized)
793#endif
794 && !getrlimit (RLIMIT_STACK, &rlim))
53c58b5d 795 {
509a8fcd 796 long newlim;
fa8459a3 797 extern size_t re_max_failures;
03effc23
KH
798 /* Approximate the amount regex.c needs per unit of re_max_failures. */
799 int ratio = 20 * sizeof (char *);
800 /* Then add 33% to cover the size of the smaller stacks that regex.c
801 successively allocates and discards, on its way to the maximum. */
802 ratio += ratio / 3;
803 /* Add in some extra to cover
804 what we're likely to use for other reasons. */
805 newlim = re_max_failures * ratio + 200000;
d0381a7f
RS
806#ifdef __NetBSD__
807 /* NetBSD (at least NetBSD 1.2G and former) has a bug in its
808 stack allocation routine for new process that the allocation
809 fails if stack limit is not on page boundary. So, round up the
810 new limit to page boundary. */
5e617bc2 811 newlim = (newlim + getpagesize () - 1) / getpagesize () * getpagesize ();
d0381a7f 812#endif
509a8fcd 813 if (newlim > rlim.rlim_max)
6c2935e9
RS
814 {
815 newlim = rlim.rlim_max;
03effc23
KH
816 /* Don't let regex.c overflow the stack we have. */
817 re_max_failures = (newlim - 200000) / ratio;
6c2935e9 818 }
509a8fcd
RS
819 if (rlim.rlim_cur < newlim)
820 rlim.rlim_cur = newlim;
821
53c58b5d
RS
822 setrlimit (RLIMIT_STACK, &rlim);
823 }
ea2acec5 824#endif /* HAVE_SETRLIMIT and RLIMIT_STACK */
53c58b5d 825
f927c5ae
JB
826 /* Record (approximately) where the stack begins. */
827 stack_bottom = &stack_bottom_variable;
828
f927c5ae 829 clearerr (stdin);
9ae8f997 830
f927c5ae 831#ifndef SYSTEM_MALLOC
bf7f4e90
RS
832 /* Arrange to get warning messages as memory fills up. */
833 memory_warnings (0, malloc_warning);
9ac0d9e0 834
0caaedb1 835 /* Call malloc at least once, to run malloc_initialize_hook.
f5a3c8c4
AI
836 Also call realloc and free for consistency. */
837 free (realloc (malloc (4), 4));
bf7f4e90 838
f927c5ae
JB
839#endif /* not SYSTEM_MALLOC */
840
edd3ff1d 841#if defined (MSDOS) || defined (WINDOWSNT)
29b89fe0
RS
842 /* We do all file input/output as binary files. When we need to translate
843 newlines, we do that manually. */
844 _fmode = O_BINARY;
edd3ff1d 845#endif /* MSDOS || WINDOWSNT */
18198bb2 846
edd3ff1d 847#ifdef MSDOS
18198bb2
RS
848 if (!isatty (fileno (stdin)))
849 setmode (fileno (stdin), O_BINARY);
850 if (!isatty (fileno (stdout)))
851 {
852 fflush (stdout);
853 setmode (fileno (stdout), O_BINARY);
854 }
29b89fe0
RS
855#endif /* MSDOS */
856
68c45bf0
PE
857 /* Skip initial setlocale if LC_ALL is "C", as it's not needed in that case.
858 The build procedure uses this while dumping, to ensure that the
859 dumped Emacs does not have its system locale tables initialized,
860 as that might cause screwups when the dumped Emacs starts up. */
861 {
862 char *lc_all = getenv ("LC_ALL");
863 do_initial_setlocale = ! lc_all || strcmp (lc_all, "C");
864 }
865
866 /* Set locale now, so that initial error messages are localized properly.
867 fixup_locale must wait until later, since it builds strings. */
868 if (do_initial_setlocale)
869 setlocale (LC_ALL, "");
870
f927c5ae
JB
871 inhibit_window_system = 0;
872
7db35a48 873 /* Handle the -t switch, which specifies filename to use as terminal. */
956e3c7e
RS
874 while (1)
875 {
876 char *term;
877 if (argmatch (argv, argc, "-t", "--terminal", 4, &term, &skip_args))
878 {
879 int result;
68c45bf0
PE
880 emacs_close (0);
881 emacs_close (1);
882 result = emacs_open (term, O_RDWR, 0);
9055082e 883 if (result < 0 || dup (0) < 0)
956e3c7e
RS
884 {
885 char *errstring = strerror (errno);
186486eb 886 fprintf (stderr, "%s: %s: %s\n", argv[0], term, errstring);
956e3c7e
RS
887 exit (1);
888 }
956e3c7e
RS
889 if (! isatty (0))
890 {
186486eb 891 fprintf (stderr, "%s: %s: not a tty\n", argv[0], term);
956e3c7e
RS
892 exit (1);
893 }
894 fprintf (stderr, "Using %s\n", term);
8ba50e1a 895#ifdef HAVE_WINDOW_SYSTEM
956e3c7e 896 inhibit_window_system = 1; /* -t => -nw */
f927c5ae 897#endif
956e3c7e
RS
898 }
899 else
900 break;
901 }
902
400d6fa9 903 /* Command line option --no-windows is deprecated and thus not mentioned
333f9019 904 in the manual and usage information. */
400d6fa9
PJ
905 if (argmatch (argv, argc, "-nw", "--no-window-system", 6, NULL, &skip_args)
906 || argmatch (argv, argc, "-nw", "--no-windows", 6, NULL, &skip_args))
e2925360 907 inhibit_window_system = 1;
f927c5ae 908
e2925360 909 /* Handle the -batch switch, which means don't do interactive display. */
f927c5ae 910 noninteractive = 0;
df6530f8 911 if (argmatch (argv, argc, "-batch", "--batch", 5, NULL, &skip_args))
55f4edbc
RS
912 {
913 noninteractive = 1;
914 Vundo_outer_limit = Qnil;
915 }
6e910e07
RS
916 if (argmatch (argv, argc, "-script", "--script", 3, &junk, &skip_args))
917 {
918 noninteractive = 1; /* Set batch mode. */
21a4ff8e 919 /* Convert --script to -scriptload, un-skip it, and sort again
e09b9180 920 so that it will be handled in proper sequence. */
a09a5b5b 921 /* FIXME broken for --script=FILE - is that supposed to work? */
c03cd23f 922 argv[skip_args - 1] = (char *) "-scriptload";
6e910e07
RS
923 skip_args -= 2;
924 sort_args (argc, argv);
925 }
e2925360 926
7db35a48 927 /* Handle the --help option, which gives a usage message. */
df6530f8 928 if (argmatch (argv, argc, "-help", "--help", 3, NULL, &skip_args))
f927c5ae 929 {
6b61353c
KH
930 printf (USAGE1, argv[0], USAGE2);
931 printf (USAGE3);
17284745 932 printf (USAGE4);
e2925360 933 exit (0);
f927c5ae
JB
934 }
935
4ff029f6
DN
936 if (argmatch (argv, argc, "-daemon", "--daemon", 5, NULL, &skip_args)
937 || argmatch (argv, argc, "-daemon", "--daemon", 5, &dname_arg, &skip_args))
eab2ee89 938 {
9d29095c 939#ifndef DOS_NT
5790ef40
DN
940 pid_t f;
941
942 /* Start as a daemon: fork a new child process which will run the
943 rest of the initialization code, then exit.
944
fc012771
SM
945 Detaching a daemon requires the following steps:
946 - fork
947 - setsid
948 - exit the parent
949 - close the tty file-descriptors
950
951 We only want to do the last 2 steps once the daemon is ready to
952 serve requests, i.e. after loading .emacs (initialization).
953 OTOH initialization may start subprocesses (e.g. ispell) and these
954 should be run from the proper process (the one that will end up
955 running as daemon) and with the proper "session id" in order for
956 them to keep working after detaching, so fork and setsid need to be
957 performed before initialization.
958
5790ef40
DN
959 We want to avoid exiting before the server socket is ready, so
960 use a pipe for synchronization. The parent waits for the child
961 to close its end of the pipe (using `daemon-initialized')
962 before exiting. */
963 if (pipe (daemon_pipe) == -1)
964 {
965 fprintf (stderr, "Cannot pipe!\n");
966 exit (1);
967 }
968
ce9f00e4 969#ifndef DAEMON_MUST_EXEC
8b3115e7
DN
970#ifdef USE_GTK
971 fprintf (stderr, "\nWarning: due to a long standing Gtk+ bug\nhttp://bugzilla.gnome.org/show_bug.cgi?id=85715\n\
972Emacs might crash when run in daemon mode and the X11 connection is unexpectedly lost.\n\
973Using an Emacs configured with --with-x-toolkit=lucid does not have this problem.\n");
ce9f00e4 974#endif /* USE_GTK */
5790ef40 975 f = fork ();
ce9f00e4 976#else /* DAEMON_MUST_EXEC */
b3243e6f
AR
977 if (!dname_arg || !strchr (dname_arg, '\n'))
978 f = fork (); /* in orig */
979 else
980 f = 0; /* in exec'd */
ce9f00e4 981#endif /* !DAEMON_MUST_EXEC */
eab2ee89 982 if (f > 0)
5790ef40
DN
983 {
984 int retval;
985 char buf[1];
986
987 /* Close unused writing end of the pipe. */
988 close (daemon_pipe[1]);
989
990 /* Just wait for the child to close its end of the pipe. */
991 do
992 {
993 retval = read (daemon_pipe[0], &buf, 1);
994 }
995 while (retval == -1 && errno == EINTR);
996
997 if (retval < 0)
998 {
999 fprintf (stderr, "Error reading status from child\n");
1000 exit (1);
1001 }
fd95644b
DN
1002 else if (retval == 0)
1003 {
1004 fprintf (stderr, "Error: server did not start correctly\n");
1005 exit (1);
1006 }
5790ef40
DN
1007
1008 close (daemon_pipe[0]);
1009 exit (0);
1010 }
eab2ee89
DN
1011 if (f < 0)
1012 {
1013 fprintf (stderr, "Cannot fork!\n");
9d0a6e42 1014 exit (1);
eab2ee89
DN
1015 }
1016
ce9f00e4 1017#ifdef DAEMON_MUST_EXEC
b3243e6f 1018 {
cfa6accb 1019 /* In orig process, forked as child, OR in exec'd. */
b3243e6f 1020 if (!dname_arg || !strchr (dname_arg, '\n'))
cfa6accb 1021 { /* In orig, child: now exec w/special daemon name. */
b3243e6f 1022 char fdStr[80];
66c6fdd5
PE
1023 int fdStrlen =
1024 snprintf (fdStr, sizeof fdStr,
1025 "--daemon=\n%d,%d\n%s", daemon_pipe[0],
1026 daemon_pipe[1], dname_arg ? dname_arg : "");
b3243e6f 1027
66c6fdd5 1028 if (! (0 <= fdStrlen && fdStrlen < sizeof fdStr))
b3243e6f
AR
1029 {
1030 fprintf (stderr, "daemon: child name too long\n");
1031 exit (1);
1032 }
1033
b3243e6f
AR
1034 argv[skip_args] = fdStr;
1035
5257b701 1036 execvp (argv[0], argv);
cff11156 1037 fprintf (stderr, "emacs daemon: exec failed: %d\n", errno);
b3243e6f
AR
1038 exit (1);
1039 }
1040
cfa6accb 1041 /* In exec'd: parse special dname into pipe and name info. */
b3243e6f
AR
1042 if (!dname_arg || !strchr (dname_arg, '\n')
1043 || strlen (dname_arg) < 1 || strlen (dname_arg) > 70)
1044 {
1045 fprintf (stderr, "emacs daemon: daemon name absent or too long\n");
5e617bc2 1046 exit (1);
b3243e6f
AR
1047 }
1048 dname_arg2[0] = '\0';
1049 sscanf (dname_arg, "\n%d,%d\n%s", &(daemon_pipe[0]), &(daemon_pipe[1]),
1050 dname_arg2);
0b963a93 1051 dname_arg = *dname_arg2 ? dname_arg2 : NULL;
b3243e6f 1052 }
ce9f00e4 1053#endif /* DAEMON_MUST_EXEC */
b3243e6f 1054
4ff029f6
DN
1055 if (dname_arg)
1056 daemon_name = xstrdup (dname_arg);
5790ef40
DN
1057 /* Close unused reading end of the pipe. */
1058 close (daemon_pipe[0]);
7c19d3ae
DN
1059 /* Make sure that the used end of the pipe is closed on exec, so
1060 that it is not accessible to programs started from .emacs. */
1061 fcntl (daemon_pipe[1], F_SETFD, FD_CLOEXEC);
1062
5e617bc2 1063 setsid ();
eab2ee89 1064#else /* DOS_NT */
9d29095c
DN
1065 fprintf (stderr, "This platform does not support the -daemon flag.\n");
1066 exit (1);
eab2ee89 1067#endif /* DOS_NT */
9d29095c 1068 }
eab2ee89 1069
322aea6d 1070#if defined (HAVE_PTHREAD) && !defined (SYSTEM_MALLOC) && !defined (DOUG_LEA_MALLOC)
edb85f59
RS
1071 if (! noninteractive)
1072 {
322aea6d 1073 extern void malloc_enable_thread (void);
5467331d 1074
322aea6d 1075 malloc_enable_thread ();
edb85f59 1076 }
322aea6d 1077#endif
edb85f59 1078
4d7e6e51 1079 init_signals (dumping);
f927c5ae
JB
1080
1081 noninteractive1 = noninteractive;
1082
cf4bb06d 1083 /* Perform basic initializations (not merely interning symbols). */
f927c5ae
JB
1084
1085 if (!initialized)
1086 {
1087 init_alloc_once ();
1088 init_obarray ();
1089 init_eval_once ();
270ce821
KH
1090 init_charset_once ();
1091 init_coding_once ();
f927c5ae 1092 init_syntax_once (); /* Create standard syntax table. */
270ce821 1093 init_category_once (); /* Create standard category table. */
cf4bb06d 1094 init_casetab_once (); /* Must be done before init_buffer_once. */
7db35a48
PJ
1095 init_buffer_once (); /* Create buffer table and some buffers. */
1096 init_minibuf_once (); /* Create list of minibuffers. */
1097 /* Must precede init_window_once. */
1098
90d920b6
GM
1099 /* Call syms_of_xfaces before init_window_once because that
1100 function creates Vterminal_frame. Termcap frames now use
1101 faces, and the face implementation uses some symbols as
1102 face names. */
90d920b6 1103 syms_of_xfaces ();
4ea81208
KL
1104 /* XXX syms_of_keyboard uses some symbols in keymap.c. It would
1105 be better to arrange things not to have this dependency. */
1106 syms_of_keymap ();
7a18af49
KR
1107 /* Call syms_of_keyboard before init_window_once because
1108 keyboard sets up symbols that include some face names that
1109 the X support will want to use. This can happen when
1110 CANNOT_DUMP is defined. */
1111 syms_of_keyboard ();
90d920b6 1112
985773c9
MB
1113 /* Called before syms_of_fileio, because it sets up Qerror_condition. */
1114 syms_of_data ();
b7432bb2 1115 syms_of_fns (); /* Before syms_of_charset which uses hashtables. */
985773c9
MB
1116 syms_of_fileio ();
1117 /* Before syms_of_coding to initialize Vgc_cons_threshold. */
1118 syms_of_alloc ();
cf4bb06d
DA
1119 /* May call Ffuncall and so GC, thus the latter should be initialized. */
1120 init_print_once ();
985773c9
MB
1121 /* Before syms_of_coding because it initializes Qcharsetp. */
1122 syms_of_charset ();
1123 /* Before init_window_once, because it sets up the
1124 Vcoding_system_hash_table. */
1125 syms_of_coding (); /* This should be after syms_of_fileio. */
1a578e9b 1126
7db35a48 1127 init_window_once (); /* Init the window system. */
6b61353c 1128#ifdef HAVE_WINDOW_SYSTEM
b7432bb2 1129 init_fringe_once (); /* Swap bitmaps if necessary. */
6b61353c 1130#endif /* HAVE_WINDOW_SYSTEM */
f927c5ae
JB
1131 }
1132
1133 init_alloc ();
68c45bf0
PE
1134
1135 if (do_initial_setlocale)
1136 {
1137 fixup_locale ();
ca9c0567
PE
1138 Vsystem_messages_locale = Vprevious_system_messages_locale;
1139 Vsystem_time_locale = Vprevious_system_time_locale;
68c45bf0
PE
1140 }
1141
f927c5ae 1142 init_eval ();
ab5d0358 1143 init_atimer ();
7074fde6 1144 running_asynch_code = 0;
0e23ef9d 1145 init_random ();
0e956009 1146
956e3c7e 1147 no_loadup
b96f9fb7 1148 = argmatch (argv, argc, "-nl", "--no-loadup", 6, NULL, &skip_args);
956e3c7e 1149
66b7b0fe
GM
1150 no_site_lisp
1151 = argmatch (argv, argc, "-nsl", "--no-site-lisp", 11, NULL, &skip_args);
1152
edfda783 1153#ifdef HAVE_NS
204ee57f 1154 ns_pool = ns_alloc_autorelease_pool ();
edfda783
AR
1155 if (!noninteractive)
1156 {
edfda783
AR
1157#ifdef NS_IMPL_COCOA
1158 if (skip_args < argc)
1159 {
32299e33
PE
1160 /* FIXME: Do the right thing if getenv returns NULL, or if
1161 chdir fails. */
5e617bc2 1162 if (!strncmp (argv[skip_args], "-psn", 4))
edfda783
AR
1163 {
1164 skip_args += 1;
3d0a4431 1165 chdir (getenv ("HOME"));
edfda783 1166 }
5e617bc2 1167 else if (skip_args+1 < argc && !strncmp (argv[skip_args+1], "-psn", 4))
edfda783 1168 {
95889848 1169 skip_args += 2;
3d0a4431 1170 chdir (getenv ("HOME"));
edfda783
AR
1171 }
1172 }
9b68317c 1173#endif /* COCOA */
edfda783
AR
1174 }
1175#endif /* HAVE_NS */
1176
956e3c7e
RS
1177#ifdef HAVE_X_WINDOWS
1178 /* Stupid kludge to catch command-line display spec. We can't
1179 handle this argument entirely in window system dependent code
1180 because we don't even know which window system dependent code
1181 to run until we've recognized this argument. */
1182 {
1183 char *displayname = 0;
956e3c7e
RS
1184 int count_before = skip_args;
1185
1186 /* Skip any number of -d options, but only use the last one. */
1187 while (1)
1188 {
1189 int count_before_this = skip_args;
1190
1191 if (argmatch (argv, argc, "-d", "--display", 3, &displayname, &skip_args))
1192 display_arg = 1;
1193 else if (argmatch (argv, argc, "-display", 0, 3, &displayname, &skip_args))
1194 display_arg = 1;
1195 else
1196 break;
1197
1198 count_before = count_before_this;
1199 }
1200
1201 /* If we have the form --display=NAME,
1202 convert it into -d name.
1203 This requires inserting a new element into argv. */
0065d054 1204 if (displayname && count_before < skip_args)
956e3c7e 1205 {
0065d054
PE
1206 if (skip_args == count_before + 1)
1207 {
1208 memmove (argv + count_before + 3, argv + count_before + 2,
1209 (argc - (count_before + 2)) * sizeof *argv);
1210 argv[count_before + 2] = displayname;
1211 argc++;
1212 }
1213 argv[count_before + 1] = (char *) "-d";
956e3c7e 1214 }
956e3c7e 1215
66b7b0fe
GM
1216 if (! no_site_lisp)
1217 {
1218 if (argmatch (argv, argc, "-Q", "--quick", 3, NULL, &skip_args)
1219 || argmatch (argv, argc, "-quick", 0, 2, NULL, &skip_args))
1220 no_site_lisp = 1;
1221 }
1222
956e3c7e
RS
1223 /* Don't actually discard this arg. */
1224 skip_args = count_before;
1225 }
66b7b0fe
GM
1226#else /* !HAVE_X_WINDOWS */
1227 if (! no_site_lisp)
1228 {
1229 int count_before = skip_args;
1230
1231 if (argmatch (argv, argc, "-Q", "--quick", 3, NULL, &skip_args)
1232 || argmatch (argv, argc, "-quick", 0, 2, NULL, &skip_args))
1233 no_site_lisp = 1;
1234
1235 skip_args = count_before;
1236 }
956e3c7e
RS
1237#endif
1238
1239 /* argmatch must not be used after here,
91af3942 1240 except when building temacs
956e3c7e
RS
1241 because the -d argument has not been skipped in skip_args. */
1242
29b89fe0
RS
1243#ifdef MSDOS
1244 /* Call early 'cause init_environment needs it. */
1245 init_dosfns ();
1246 /* Set defaults for several environment variables. */
18198bb2
RS
1247 if (initialized)
1248 init_environment (argc, argv, skip_args);
1249 else
d1fc6752 1250 tzset ();
18198bb2 1251#endif /* MSDOS */
29b89fe0 1252
90db8702
MA
1253#ifdef HAVE_GFILENOTIFY
1254 globals_of_gfilenotify ();
1255#endif
1256
8ba50e1a 1257#ifdef WINDOWSNT
9785d95b 1258 globals_of_w32 ();
c9628c79 1259#ifdef HAVE_W32NOTIFY
37a4dabe 1260 globals_of_w32notify ();
c9628c79 1261#endif
8ba50e1a 1262 /* Initialize environment from registry settings. */
a3a58294 1263 init_environment (argv);
16b22fef 1264 init_ntproc (dumping); /* must precede init_editfns. */
8ba50e1a
GV
1265#endif
1266
8b4eb796
KR
1267 /* Initialize and GC-protect Vinitial_environment and
1268 Vprocess_environment before set_initial_environment fills them
1269 in. */
1270 if (!initialized)
1271 syms_of_callproc ();
0e956009
JB
1272 /* egetenv is a pretty low-level facility, which may get called in
1273 many circumstances; it seems flimsy to put off initializing it
738db178 1274 until calling init_callproc. Do not do it when dumping. */
4d7e6e51 1275 if (! dumping)
738db178
DN
1276 set_initial_environment ();
1277
93aed04d 1278 /* AIX crashes are reported in system versions 3.2.3 and 3.2.4
5990851d
KL
1279 if this is not done. Do it after set_global_environment so that we
1280 don't pollute Vglobal_environment. */
fa09a82d 1281 /* Setting LANG here will defeat the startup locale processing... */
f2a77c3a 1282#ifdef AIX
5745a7df 1283 xputenv ("LANG=C");
93aed04d 1284#endif
0e956009 1285
7db35a48 1286 init_buffer (); /* Init default directory of main buffer. */
ace40a69 1287
7928f0b5 1288 init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */
ace40a69 1289 init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */
380e25b8
RS
1290
1291 if (initialized)
1292 {
7db35a48 1293 /* Erase any pre-dump messages in the message log, to avoid confusion. */
380e25b8
RS
1294 Lisp_Object old_log_max;
1295 old_log_max = Vmessage_log_max;
1296 XSETFASTINT (Vmessage_log_max, 0);
f6fe7bb5 1297 message_dolog ("", 0, 1, 0);
380e25b8
RS
1298 Vmessage_log_max = old_log_max;
1299 }
1300
7928f0b5 1301 init_callproc (); /* Must follow init_cmdargs but not init_sys_modes. */
9fe43ff6 1302 init_fileio ();
fb8e9847 1303 init_lread ();
76151e2c
EZ
1304#ifdef WINDOWSNT
1305 /* Check to see if Emacs has been installed correctly. */
1306 check_windows_init_file ();
1307#endif
f927c5ae 1308
8bb697c0
RS
1309 /* Intern the names of all standard functions and variables;
1310 define standard keys. */
f927c5ae
JB
1311
1312 if (!initialized)
1313 {
4230ab74
KR
1314 /* The basic levels of Lisp must come first. Note that
1315 syms_of_data and some others have already been called. */
e37d7195 1316 syms_of_chartab ();
fb8e9847 1317 syms_of_lread ();
f927c5ae
JB
1318 syms_of_print ();
1319 syms_of_eval ();
f927c5ae 1320 syms_of_floatfns ();
f927c5ae 1321
f927c5ae
JB
1322 syms_of_buffer ();
1323 syms_of_bytecode ();
1324 syms_of_callint ();
1325 syms_of_casefiddle ();
1326 syms_of_casetab ();
270ce821
KH
1327 syms_of_category ();
1328 syms_of_ccl ();
e37d7195 1329 syms_of_character ();
f927c5ae 1330 syms_of_cmds ();
f927c5ae 1331 syms_of_dired ();
f927c5ae
JB
1332 syms_of_display ();
1333 syms_of_doc ();
1334 syms_of_editfns ();
1335 syms_of_emacs ();
f927c5ae 1336 syms_of_filelock ();
f927c5ae 1337 syms_of_indent ();
c2c5ed2c 1338 syms_of_insdel ();
4ea81208 1339 /* syms_of_keymap (); */
f927c5ae
JB
1340 syms_of_macros ();
1341 syms_of_marker ();
1342 syms_of_minibuf ();
f927c5ae 1343 syms_of_process ();
f927c5ae 1344 syms_of_search ();
1cbd5d9d 1345 syms_of_frame ();
f927c5ae 1346 syms_of_syntax ();
ed8dad6b 1347 syms_of_terminal ();
0d934e7b 1348 syms_of_term ();
f927c5ae 1349 syms_of_undo ();
90d920b6
GM
1350#ifdef HAVE_SOUND
1351 syms_of_sound ();
1352#endif
bef79ee4 1353 syms_of_textprop ();
9d100795 1354 syms_of_composite ();
05687c54
RS
1355#ifdef WINDOWSNT
1356 syms_of_ntproc ();
1357#endif /* WINDOWSNT */
3fc5e44a 1358#if defined CYGWIN
0fda9b75 1359 syms_of_cygw32 ();
a9e7a9d5 1360#endif
f927c5ae
JB
1361 syms_of_window ();
1362 syms_of_xdisp ();
d53f587b 1363 syms_of_font ();
4fa9161d 1364#ifdef HAVE_WINDOW_SYSTEM
6b61353c
KH
1365 syms_of_fringe ();
1366 syms_of_image ();
1367#endif /* HAVE_WINDOW_SYSTEM */
f927c5ae 1368#ifdef HAVE_X_WINDOWS
72412588 1369 syms_of_xterm ();
f927c5ae 1370 syms_of_xfns ();
edfda783 1371 syms_of_xmenu ();
270ce821 1372 syms_of_fontset ();
637fa988 1373 syms_of_xsettings ();
28b1b672
JD
1374#ifdef HAVE_X_SM
1375 syms_of_xsmfns ();
1376#endif
72412588
JB
1377#ifdef HAVE_X11
1378 syms_of_xselect ();
1379#endif
f927c5ae
JB
1380#endif /* HAVE_X_WINDOWS */
1381
381408e2
LMI
1382#ifdef HAVE_LIBXML2
1383 syms_of_xml ();
1384#endif
1385
4e77ce60 1386 syms_of_menu ();
4e77ce60 1387
8ba50e1a 1388#ifdef HAVE_NTGUI
fbd6baed
GV
1389 syms_of_w32term ();
1390 syms_of_w32fns ();
fbd6baed 1391 syms_of_w32menu ();
02062ac3 1392 syms_of_fontset ();
8ba50e1a
GV
1393#endif /* HAVE_NTGUI */
1394
a9e7a9d5 1395#if defined WINDOWSNT || defined HAVE_NTGUI
0fda9b75 1396 syms_of_w32select ();
a9e7a9d5 1397#endif
0fda9b75 1398
40da1153
EZ
1399#ifdef MSDOS
1400 syms_of_xmenu ();
5e617bc2
JB
1401 syms_of_dosfns ();
1402 syms_of_msdos ();
1403 syms_of_win16select ();
40da1153
EZ
1404#endif /* MSDOS */
1405
edfda783
AR
1406#ifdef HAVE_NS
1407 syms_of_nsterm ();
1408 syms_of_nsfns ();
1409 syms_of_nsmenu ();
1410 syms_of_nsselect ();
1411 syms_of_fontset ();
1412#endif /* HAVE_NS */
1413
8af55556
TZ
1414#ifdef HAVE_GNUTLS
1415 syms_of_gnutls ();
1416#endif
1417
c9628c79
MA
1418#ifdef HAVE_GFILENOTIFY
1419 syms_of_gfilenotify ();
1420#endif /* HAVE_GFILENOTIFY */
1421
81606b10
RS
1422#ifdef HAVE_INOTIFY
1423 syms_of_inotify ();
1424#endif /* HAVE_INOTIFY */
1425
033b73e2
MA
1426#ifdef HAVE_DBUS
1427 syms_of_dbusbind ();
1428#endif /* HAVE_DBUS */
1429
2e31d424
DN
1430#ifdef WINDOWSNT
1431 syms_of_ntterm ();
c9628c79 1432#ifdef HAVE_W32NOTIFY
477f1e50 1433 syms_of_w32notify ();
c9628c79 1434#endif /* HAVE_W32NOTIFY */
2e31d424 1435#endif /* WINDOWSNT */
f927c5ae 1436
c2d7786e
TM
1437 syms_of_profiler ();
1438
f927c5ae
JB
1439 keys_of_casefiddle ();
1440 keys_of_cmds ();
1441 keys_of_buffer ();
1442 keys_of_keyboard ();
1443 keys_of_keymap ();
f927c5ae 1444 keys_of_window ();
9785d95b 1445 }
3b6536b1 1446 else
9785d95b 1447 {
3b6536b1
AS
1448 /* Initialization that must be done even if the global variable
1449 initialized is non zero. */
9785d95b 1450#ifdef HAVE_NTGUI
db4f02f2 1451 globals_of_w32font ();
9785d95b
BK
1452 globals_of_w32fns ();
1453 globals_of_w32menu ();
3b6536b1 1454#endif /* HAVE_NTGUI */
0fda9b75 1455
a9e7a9d5 1456#if defined WINDOWSNT || defined HAVE_NTGUI
0fda9b75 1457 globals_of_w32select ();
a9e7a9d5 1458#endif
f927c5ae
JB
1459 }
1460
cf411e8d
KH
1461 init_charset ();
1462
b82da769
GM
1463 init_editfns (); /* init_process_emacs uses Voperating_system_release. */
1464 init_process_emacs (); /* init_display uses add_keyboard_wait_descriptor. */
7db35a48 1465 init_keyboard (); /* This too must precede init_sys_modes. */
0a125897 1466 if (!noninteractive)
7c2fb837 1467 init_display (); /* Determine terminal type. Calls init_sys_modes. */
8bb697c0 1468 init_xdisp ();
6b61353c
KH
1469#ifdef HAVE_WINDOW_SYSTEM
1470 init_fringe ();
6b61353c 1471#endif /* HAVE_WINDOW_SYSTEM */
8bb697c0 1472 init_macros ();
75816372 1473 init_window ();
74d75424 1474 init_font ();
087fc47a 1475
f927c5ae
JB
1476 if (!initialized)
1477 {
e2925360 1478 char *file;
7db35a48 1479 /* Handle -l loadup, args passed by Makefile. */
df6530f8 1480 if (argmatch (argv, argc, "-l", "--load", 3, &file, &skip_args))
d67b4f80 1481 Vtop_level = Fcons (intern_c_string ("load"),
e2925360 1482 Fcons (build_string (file), Qnil));
f927c5ae 1483 /* Unless next switch is -nl, load "loadup.el" first thing. */
956e3c7e 1484 if (! no_loadup)
d67b4f80 1485 Vtop_level = Fcons (intern_c_string ("load"),
f927c5ae 1486 Fcons (build_string ("loadup.el"), Qnil));
f927c5ae
JB
1487 }
1488
93572b43
KH
1489 if (initialized)
1490 {
0269dedb
RS
1491#ifdef HAVE_TZSET
1492 {
1493 /* If the execution TZ happens to be the same as the dump TZ,
1494 change it to some other value and then change it back,
1495 to force the underlying implementation to reload the TZ info.
1496 This is needed on implementations that load TZ info from files,
1497 since the TZ file contents may differ between dump and execution. */
1498 char *tz = getenv ("TZ");
1499 if (tz && !strcmp (tz, dump_tz))
1500 {
1501 ++*tz;
1502 tzset ();
1503 --*tz;
1504 }
1505 }
1506#endif
93572b43
KH
1507 }
1508
ecf783fa
EZ
1509 /* Set up for profiling. This is known to work on FreeBSD,
1510 GNU/Linux and MinGW. It might work on some other systems too.
1511 Give it a try and tell us if it works on your system. To compile
7b3a82d7 1512 for profiling, use the configure option --enable-profiling. */
5e617bc2 1513#if defined (__FreeBSD__) || defined (GNU_LINUX) || defined (__MINGW32__)
e610ea43
RS
1514#ifdef PROFILING
1515 if (initialized)
1516 {
ecf783fa
EZ
1517#ifdef __MINGW32__
1518 extern unsigned char etext asm ("etext");
1519#else
e610ea43 1520 extern char etext;
ecf783fa 1521#endif
67a5596f 1522
e610ea43 1523 atexit (_mcleanup);
9e4bf381 1524 monstartup ((uintptr_t) __executable_start, (uintptr_t) &etext);
e610ea43
RS
1525 }
1526 else
1527 moncontrol (0);
1528#endif
1529#endif
1530
f927c5ae
JB
1531 initialized = 1;
1532
e7536cff
RS
1533#ifdef LOCALTIME_CACHE
1534 /* Some versions of localtime have a bug. They cache the value of the time
279cc2b8
JB
1535 zone rather than looking it up every time. Since localtime() is
1536 called to bolt the undumping time into the undumped emacs, this
afe9fae9 1537 results in localtime ignoring the TZ environment variable.
7db35a48 1538 This flushes the new TZ value into localtime. */
afe9fae9 1539 tzset ();
e7536cff 1540#endif /* defined (LOCALTIME_CACHE) */
279cc2b8 1541
f927c5ae
JB
1542 /* Enter editor command loop. This never returns. */
1543 Frecursive_edit ();
1544 /* NOTREACHED */
6bbd7a29 1545 return 0;
f927c5ae
JB
1546}
1547\f
081bef73
RS
1548/* Sort the args so we can find the most important ones
1549 at the beginning of argv. */
1550
1551/* First, here's a table of all the standard options. */
1552
1553struct standard_args
1554{
5e2327cf
DN
1555 const char *name;
1556 const char *longname;
081bef73
RS
1557 int priority;
1558 int nargs;
1559};
1560
35f08c38 1561static const struct standard_args standard_args[] =
081bef73 1562{
05922407 1563 { "-version", "--version", 150, 0 },
f63d0028 1564 { "-chdir", "--chdir", 130, 1 },
05922407 1565 { "-t", "--terminal", 120, 1 },
400d6fa9 1566 { "-nw", "--no-window-system", 110, 0 },
05922407
RS
1567 { "-nw", "--no-windows", 110, 0 },
1568 { "-batch", "--batch", 100, 0 },
6e910e07 1569 { "-script", "--script", 100, 1 },
eab2ee89 1570 { "-daemon", "--daemon", 99, 0 },
05922407 1571 { "-help", "--help", 90, 0 },
956e3c7e 1572 { "-nl", "--no-loadup", 70, 0 },
66b7b0fe 1573 { "-nsl", "--no-site-lisp", 65, 0 },
956e3c7e
RS
1574 /* -d must come last before the options handled in startup.el. */
1575 { "-d", "--display", 60, 1 },
1576 { "-display", 0, 60, 1 },
4fe22cdf 1577 /* Now for the options handled in `command-line' (startup.el). */
66b7b0fe 1578 /* (Note that to imply -nsl, -Q is partially handled here.) */
a1716a57
RS
1579 { "-Q", "--quick", 55, 0 },
1580 { "-quick", 0, 55, 0 },
081bef73
RS
1581 { "-q", "--no-init-file", 50, 0 },
1582 { "-no-init-file", 0, 50, 0 },
1583 { "-no-site-file", "--no-site-file", 40, 0 },
1584 { "-u", "--user", 30, 1 },
1585 { "-user", 0, 30, 1 },
1586 { "-debug-init", "--debug-init", 20, 0 },
f2bc3538 1587 { "-iconic", "--iconic", 15, 0 },
a1716a57 1588 { "-D", "--basic-display", 12, 0},
e09b9180 1589 { "-basic-display", 0, 12, 0},
4fe22cdf
CY
1590 { "-nbc", "--no-blinking-cursor", 12, 0 },
1591 /* Now for the options handled in `command-line-1' (startup.el). */
1592 { "-nbi", "--no-bitmap-icon", 10, 0 },
081bef73
RS
1593 { "-bg", "--background-color", 10, 1 },
1594 { "-background", 0, 10, 1 },
1595 { "-fg", "--foreground-color", 10, 1 },
1596 { "-foreground", 0, 10, 1 },
1597 { "-bd", "--border-color", 10, 1 },
1598 { "-bw", "--border-width", 10, 1 },
1599 { "-ib", "--internal-border", 10, 1 },
1600 { "-ms", "--mouse-color", 10, 1 },
1601 { "-cr", "--cursor-color", 10, 1 },
1602 { "-fn", "--font", 10, 1 },
1603 { "-font", 0, 10, 1 },
94452530
EZ
1604 { "-fs", "--fullscreen", 10, 0 },
1605 { "-fw", "--fullwidth", 10, 0 },
1606 { "-fh", "--fullheight", 10, 0 },
3f1c6666 1607 { "-mm", "--maximized", 10, 0 },
081bef73
RS
1608 { "-g", "--geometry", 10, 1 },
1609 { "-geometry", 0, 10, 1 },
1610 { "-T", "--title", 10, 1 },
ae63ae52 1611 { "-title", 0, 10, 1 },
081bef73
RS
1612 { "-name", "--name", 10, 1 },
1613 { "-xrm", "--xrm", 10, 1 },
1540a61a 1614 { "-parent-id", "--parent-id", 10, 1 },
fcdeb5d9
RS
1615 { "-r", "--reverse-video", 5, 0 },
1616 { "-rv", 0, 5, 0 },
1617 { "-reverse", 0, 5, 0 },
ae63ae52 1618 { "-hb", "--horizontal-scroll-bars", 5, 0 },
fcdeb5d9 1619 { "-vb", "--vertical-scroll-bars", 5, 0 },
d20e1b1e 1620 { "-color", "--color", 5, 0},
16706228
JL
1621 { "-no-splash", "--no-splash", 3, 0 },
1622 { "-no-desktop", "--no-desktop", 3, 0 },
edfda783
AR
1623#ifdef HAVE_NS
1624 { "-NSAutoLaunch", 0, 5, 1 },
1625 { "-NXAutoLaunch", 0, 5, 1 },
1626 { "-disable-font-backend", "--disable-font-backend", 65, 0 },
1627 { "-_NSMachLaunch", 0, 85, 1 },
1628 { "-MachLaunch", 0, 85, 1 },
1629 { "-macosx", 0, 85, 0 },
1630 { "-NSHost", 0, 85, 1 },
1631#endif
fcdeb5d9
RS
1632 /* These have the same priority as ordinary file name args,
1633 so they are not reordered with respect to those. */
4af9e0b3
RS
1634 { "-L", "--directory", 0, 1 },
1635 { "-directory", 0, 0, 1 },
fcdeb5d9
RS
1636 { "-l", "--load", 0, 1 },
1637 { "-load", 0, 0, 1 },
21a4ff8e
GM
1638 /* This has no longname, because using --scriptload confuses sort_args,
1639 because then the --script long option seems to match twice; ie
1640 you can't have a long option which is a prefix of another long
1641 option. In any case, this is entirely an internal option. */
1642 { "-scriptload", NULL, 0, 1 },
fcdeb5d9
RS
1643 { "-f", "--funcall", 0, 1 },
1644 { "-funcall", 0, 0, 1 },
575985b1 1645 { "-eval", "--eval", 0, 1 },
67a5596f 1646 { "-execute", "--execute", 0, 1 },
2e13f8e9
RS
1647 { "-find-file", "--find-file", 0, 1 },
1648 { "-visit", "--visit", 0, 1 },
67a5596f 1649 { "-file", "--file", 0, 1 },
fcdeb5d9 1650 { "-insert", "--insert", 0, 1 },
edfda783
AR
1651#ifdef HAVE_NS
1652 { "-NXOpen", 0, 0, 1 },
1653 { "-NXOpenTemp", 0, 0, 1 },
1654 { "-NSOpen", 0, 0, 1 },
1655 { "-NSOpenTemp", 0, 0, 1 },
1656 { "-GSFilePath", 0, 0, 1 },
1657#endif
f2bc3538 1658 /* This should be processed after ordinary file name args and the like. */
fcdeb5d9 1659 { "-kill", "--kill", -10, 0 },
081bef73
RS
1660};
1661
1662/* Reorder the elements of ARGV (assumed to have ARGC elements)
1663 so that the highest priority ones come first.
1664 Do not change the order of elements of equal priority.
956e3c7e
RS
1665 If an option takes an argument, keep it and its argument together.
1666
1667 If an option that takes no argument appears more
1668 than once, eliminate all but one copy of it. */
081bef73
RS
1669
1670static void
dd4c5104 1671sort_args (int argc, char **argv)
081bef73 1672{
38182d90 1673 char **new = xmalloc (argc * sizeof *new);
081bef73
RS
1674 /* For each element of argv,
1675 the corresponding element of options is:
1676 0 for an option that takes no arguments,
1677 1 for an option that takes one argument, etc.
1678 -1 for an ordinary non-option argument. */
0065d054
PE
1679 int *options = xnmalloc (argc, sizeof *options);
1680 int *priority = xnmalloc (argc, sizeof *priority);
081bef73 1681 int to = 1;
956e3c7e 1682 int incoming_used = 1;
081bef73
RS
1683 int from;
1684 int i;
1685
1686 /* Categorize all the options,
1687 and figure out which argv elts are option arguments. */
1688 for (from = 1; from < argc; from++)
1689 {
1690 options[from] = -1;
fcdeb5d9 1691 priority[from] = 0;
081bef73
RS
1692 if (argv[from][0] == '-')
1693 {
0b963a93 1694 int match;
081bef73 1695
c96f26f4
RS
1696 /* If we have found "--", don't consider
1697 any more arguments as options. */
249443b6 1698 if (argv[from][1] == '-' && argv[from][2] == 0)
c96f26f4
RS
1699 {
1700 /* Leave the "--", and everything following it, at the end. */
1701 for (; from < argc; from++)
1702 {
1703 priority[from] = -100;
1704 options[from] = -1;
1705 }
1706 break;
1707 }
1708
081bef73
RS
1709 /* Look for a match with a known old-fashioned option. */
1710 for (i = 0; i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1711 if (!strcmp (argv[from], standard_args[i].name))
1712 {
1713 options[from] = standard_args[i].nargs;
1714 priority[from] = standard_args[i].priority;
fd76ec52
RS
1715 if (from + standard_args[i].nargs >= argc)
1716 fatal ("Option `%s' requires an argument\n", argv[from]);
081bef73
RS
1717 from += standard_args[i].nargs;
1718 goto done;
1719 }
1720
1721 /* Look for a match with a known long option.
1722 MATCH is -1 if no match so far, -2 if two or more matches so far,
1723 >= 0 (the table index of the match) if just one match so far. */
1724 if (argv[from][1] == '-')
1725 {
0b963a93
PE
1726 char const *equals = strchr (argv[from], '=');
1727 ptrdiff_t thislen =
1728 equals ? equals - argv[from] : strlen (argv[from]);
1729
081bef73 1730 match = -1;
081bef73 1731
f609ef57
KH
1732 for (i = 0;
1733 i < sizeof (standard_args) / sizeof (standard_args[0]); i++)
1734 if (standard_args[i].longname
1735 && !strncmp (argv[from], standard_args[i].longname,
1736 thislen))
081bef73
RS
1737 {
1738 if (match == -1)
1739 match = i;
1740 else
1741 match = -2;
1742 }
1743
1744 /* If we found exactly one match, use that. */
1745 if (match >= 0)
1746 {
1747 options[from] = standard_args[match].nargs;
1748 priority[from] = standard_args[match].priority;
1749 /* If --OPTION=VALUE syntax is used,
1750 this option uses just one argv element. */
1751 if (equals != 0)
1752 options[from] = 0;
fd76ec52
RS
1753 if (from + options[from] >= argc)
1754 fatal ("Option `%s' requires an argument\n", argv[from]);
081bef73
RS
1755 from += options[from];
1756 }
a09a5b5b
GM
1757 /* FIXME When match < 0, shouldn't there be some error,
1758 or at least indication to the user that there was a
1759 problem? */
081bef73
RS
1760 }
1761 done: ;
1762 }
1763 }
1764
1765 /* Copy the arguments, in order of decreasing priority, to NEW. */
1766 new[0] = argv[0];
956e3c7e 1767 while (incoming_used < argc)
081bef73
RS
1768 {
1769 int best = -1;
2c70c992 1770 int best_priority = -9999;
081bef73
RS
1771
1772 /* Find the highest priority remaining option.
1773 If several have equal priority, take the first of them. */
1774 for (from = 1; from < argc; from++)
1775 {
1776 if (argv[from] != 0 && priority[from] > best_priority)
1777 {
1778 best_priority = priority[from];
1779 best = from;
1780 }
1781 /* Skip option arguments--they are tied to the options. */
1782 if (options[from] > 0)
1783 from += options[from];
1784 }
7db35a48 1785
081bef73 1786 if (best < 0)
1088b922 1787 emacs_abort ();
081bef73 1788
956e3c7e
RS
1789 /* Copy the highest priority remaining option, with its args, to NEW.
1790 Unless it is a duplicate of the previous one. */
1791 if (! (options[best] == 0
1792 && ! strcmp (new[to - 1], argv[best])))
1793 {
1794 new[to++] = argv[best];
1795 for (i = 0; i < options[best]; i++)
1796 new[to++] = argv[best + i + 1];
1797 }
1798
1799 incoming_used += 1 + (options[best] > 0 ? options[best] : 0);
081bef73
RS
1800
1801 /* Clear out this option in ARGV. */
1802 argv[best] = 0;
1803 for (i = 0; i < options[best]; i++)
1804 argv[best + i + 1] = 0;
1805 }
1806
81b7af72
RS
1807 /* If duplicate options were deleted, fill up extra space with null ptrs. */
1808 while (to < argc)
1809 new[to++] = 0;
1810
72af86bd 1811 memcpy (argv, new, sizeof (char *) * argc);
0bf591da 1812
68db37aa
KS
1813 xfree (options);
1814 xfree (new);
1815 xfree (priority);
081bef73
RS
1816}
1817\f
a7ca3326 1818DEFUN ("kill-emacs", Fkill_emacs, Skill_emacs, 0, 1, "P",
7db35a48
PJ
1819 doc: /* Exit the Emacs job and kill it.
1820If ARG is an integer, return ARG as the exit program code.
b224de9b 1821If ARG is a string, stuff it as keyboard input.
7db35a48 1822
9c524fcb 1823This function is called upon receipt of the signals SIGTERM
383ebd15 1824or SIGHUP, and upon SIGINT in batch mode.
9c524fcb 1825
7db35a48
PJ
1826The value of `kill-emacs-hook', if not void,
1827is a list of functions (of no args),
1828all of which are called before Emacs is actually killed. */)
5842a27b 1829 (Lisp_Object arg)
f927c5ae 1830{
f927c5ae 1831 struct gcpro gcpro1;
8eca8a7c 1832 int exit_code;
f927c5ae
JB
1833
1834 GCPRO1 (arg);
1835
1836 if (feof (stdin))
1837 arg = Qt;
1838
73c14218
CY
1839 /* Fsignal calls emacs_abort () if it sees that waiting_for_input is
1840 set. */
1841 waiting_for_input = 0;
1842 Frun_hooks (1, &Qkill_emacs_hook);
f927c5ae
JB
1843 UNGCPRO;
1844
1dd3c2d9
CY
1845#ifdef HAVE_X_WINDOWS
1846 /* Transfer any clipboards we own to the clipboard manager. */
1847 x_clipboard_manager_save_all ();
1848#endif
1849
1882aa38 1850 shut_down_emacs (0, STRINGP (arg) ? arg : Qnil);
40be253a 1851
204ee57f
JD
1852#ifdef HAVE_NS
1853 ns_release_autorelease_pool (ns_pool);
1854#endif
1855
58545838
KH
1856 /* If we have an auto-save list file,
1857 kill it because we are exiting Emacs deliberately (not crashing).
1858 Do it after shut_down_emacs, which does an auto-save. */
1859 if (STRINGP (Vauto_save_list_file_name))
42a5b22f 1860 unlink (SSDATA (Vauto_save_list_file_name));
58545838 1861
5895d7b9
PE
1862 if (INTEGERP (arg))
1863 exit_code = (XINT (arg) < 0
1864 ? XINT (arg) | INT_MIN
1865 : XINT (arg) & INT_MAX);
d311d28c 1866 else
5895d7b9
PE
1867 exit_code = EXIT_SUCCESS;
1868 exit (exit_code);
f927c5ae 1869}
40be253a
JB
1870
1871
1872/* Perform an orderly shutdown of Emacs. Autosave any modified
1873 buffers, kill any child processes, clean up the terminal modes (if
1874 we're in the foreground), and other stuff like that. Don't perform
1875 any redisplay; this may be called when Emacs is shutting down in
1876 the background, or after its X connection has died.
1877
1878 If SIG is a signal number, print a message for it.
1879
1880 This is called by fatal signal handlers, X protocol error handlers,
1881 and Fkill_emacs. */
f7ab4e3d 1882
40be253a 1883void
1882aa38 1884shut_down_emacs (int sig, Lisp_Object stuff)
40be253a 1885{
829d872b
RS
1886 /* Prevent running of hooks from now on. */
1887 Vrun_hooks = Qnil;
1888
9db03f6c
KS
1889 /* Don't update display from now on. */
1890 Vinhibit_redisplay = Qt;
1891
7db35a48 1892 /* If we are controlling the terminal, reset terminal modes. */
a7ebc409 1893#ifndef DOS_NT
40be253a 1894 {
dd0333b6 1895 pid_t pgrp = getpgrp ();
69deda53 1896 pid_t tpgrp = tcgetpgrp (0);
12e610e8 1897 if ((tpgrp != -1) && tpgrp == pgrp)
40be253a 1898 {
28d440ab 1899 reset_all_sys_modes ();
40be253a 1900 if (sig && sig != SIGTERM)
01108e3f 1901 {
703342f8
PE
1902 static char const format[] = "Fatal error %d: ";
1903 char buf[sizeof format - 2 + INT_STRLEN_BOUND (int)];
1904 int buflen = sprintf (buf, format, sig);
aa1ba90e 1905 char const *sig_desc = safe_strsignal (sig);
01108e3f 1906 ignore_value (write (STDERR_FILENO, buf, buflen));
703342f8 1907 ignore_value (write (STDERR_FILENO, sig_desc, strlen (sig_desc)));
01108e3f 1908 }
40be253a
JB
1909 }
1910 }
1911#else
1912 fflush (stdout);
0a125897 1913 reset_all_sys_modes ();
40be253a
JB
1914#endif
1915
f7ab4e3d
RS
1916 stuff_buffered_input (stuff);
1917
92d835a4 1918 inhibit_sentinels = 1;
40be253a
JB
1919 kill_buffer_processes (Qnil);
1920 Fdo_auto_save (Qt, Qnil);
1921
1922#ifdef CLASH_DETECTION
1923 unlock_all_files ();
1924#endif
1925
40be253a
JB
1926 /* There is a tendency for a SIGIO signal to arrive within exit,
1927 and cause a SIGHUP because the input descriptor is already closed. */
1928 unrequest_sigio ();
4a4bbad2 1929 ignore_sigio ();
41f339d4 1930
cd8d4168
GM
1931 /* Do this only if terminating normally, we want glyph matrices
1932 etc. in a core dump. */
200f868e 1933 if (sig == 0 || sig == SIGTERM)
cd8d4168
GM
1934 {
1935 check_glyph_memory ();
1936 check_message_stack ();
1937 }
90d920b6 1938
d546e578
EZ
1939#ifdef MSDOS
1940 dos_cleanup ();
1941#endif
edfda783
AR
1942
1943#ifdef HAVE_NS
1944 ns_term_shutdown (sig);
1945#endif
fcb901a7
LMI
1946
1947#ifdef HAVE_LIBXML2
9078ead6 1948 xml_cleanup_parser ();
fcb901a7 1949#endif
f0e5f225
EZ
1950
1951#ifdef WINDOWSNT
1952 term_ntproc (0);
1953#endif
40be253a
JB
1954}
1955
1956
f927c5ae
JB
1957\f
1958#ifndef CANNOT_DUMP
f927c5ae 1959
ce701a33 1960#include "unexec.h"
dd5ecd6b 1961
f927c5ae 1962DEFUN ("dump-emacs", Fdump_emacs, Sdump_emacs, 2, 2, 0,
7db35a48
PJ
1963 doc: /* Dump current state of Emacs into executable file FILENAME.
1964Take symbols from SYMFILE (presumably the file you executed to run Emacs).
1965This is used in the file `loadup.el' when building Emacs.
1966
1967You must run Emacs in batch mode in order to dump it. */)
5842a27b 1968 (Lisp_Object filename, Lisp_Object symfile)
f927c5ae 1969{
f927c5ae 1970 Lisp_Object tem;
1b7ddf4f 1971 Lisp_Object symbol;
d311d28c 1972 ptrdiff_t count = SPECPDL_INDEX ();
4fab758d
GM
1973
1974 check_pure_size ();
f927c5ae 1975
87a98b1a
RS
1976 if (! noninteractive)
1977 error ("Dumping Emacs works only in batch mode");
1978
848a925e 1979#ifdef GNU_LINUX
c339dc2e
PE
1980
1981 /* Warn if the gap between BSS end and heap start is larger than this. */
1982# define MAX_HEAP_BSS_DIFF (1024*1024)
1983
dede2792
JD
1984 if (heap_bss_diff > MAX_HEAP_BSS_DIFF)
1985 {
1986 fprintf (stderr, "**************************************************\n");
1987 fprintf (stderr, "Warning: Your system has a gap between BSS and the\n");
b312a492 1988 fprintf (stderr, "heap (%"pMu" bytes). This usually means that exec-shield\n",
c37caf9d
JD
1989 heap_bss_diff);
1990 fprintf (stderr, "or something similar is in effect. The dump may\n");
e79beb56 1991 fprintf (stderr, "fail because of this. See the section about\n");
c37caf9d 1992 fprintf (stderr, "exec-shield in etc/PROBLEMS for more information.\n");
dede2792
JD
1993 fprintf (stderr, "**************************************************\n");
1994 }
848a925e 1995#endif /* GNU_LINUX */
dede2792 1996
1b7ddf4f
RS
1997 /* Bind `command-line-processed' to nil before dumping,
1998 so that the dumped Emacs will process its command line
1999 and set up to work with X windows if appropriate. */
4aaa3607 2000 symbol = intern ("command-line-processed");
1b7ddf4f
RS
2001 specbind (symbol, Qnil);
2002
b7826503 2003 CHECK_STRING (filename);
c9aae259
EN
2004 filename = Fexpand_file_name (filename, Qnil);
2005 if (!NILP (symfile))
f927c5ae 2006 {
b7826503 2007 CHECK_STRING (symfile);
d5db4077 2008 if (SCHARS (symfile))
c9aae259 2009 symfile = Fexpand_file_name (symfile, Qnil);
f927c5ae
JB
2010 }
2011
2012 tem = Vpurify_flag;
2013 Vpurify_flag = Qnil;
2014
0269dedb
RS
2015#ifdef HAVE_TZSET
2016 set_time_zone_rule (dump_tz);
2017#ifndef LOCALTIME_CACHE
2018 /* Force a tz reload, since set_time_zone_rule doesn't. */
2019 tzset ();
2020#endif
2021#endif
2022
f927c5ae 2023 fflush (stdout);
7db35a48 2024 /* Tell malloc where start of impure now is. */
f927c5ae
JB
2025 /* Also arrange for warnings when nearly out of space. */
2026#ifndef SYSTEM_MALLOC
cc5f52cb
RS
2027#ifndef WINDOWSNT
2028 /* On Windows, this was done before dumping, and that once suffices.
2029 Meanwhile, my_edata is not valid on Windows. */
c339dc2e
PE
2030 {
2031 extern char my_edata[];
2032 memory_warnings (my_edata, malloc_warning);
2033 }
cc5f52cb 2034#endif /* not WINDOWSNT */
dd5ecd6b 2035#endif /* not SYSTEM_MALLOC */
15aaf1b5
RS
2036#ifdef DOUG_LEA_MALLOC
2037 malloc_state_ptr = malloc_get_state ();
f927c5ae 2038#endif
2b7377ca 2039
a74c5ec1 2040#ifdef USE_MMAP_FOR_BUFFERS
2b7377ca
GM
2041 mmap_set_vars (0);
2042#endif
42a5b22f 2043 unexec (SSDATA (filename), !NILP (symfile) ? SSDATA (symfile) : 0);
a74c5ec1 2044#ifdef USE_MMAP_FOR_BUFFERS
2b7377ca
GM
2045 mmap_set_vars (1);
2046#endif
15aaf1b5
RS
2047#ifdef DOUG_LEA_MALLOC
2048 free (malloc_state_ptr);
2049#endif
f927c5ae 2050
aa15c6bb
JB
2051#ifdef WINDOWSNT
2052 Vlibrary_cache = Qnil;
2053#endif
2054#ifdef HAVE_WINDOW_SYSTEM
2055 reset_image_types ();
2056#endif
2057
f927c5ae
JB
2058 Vpurify_flag = tem;
2059
1b7ddf4f 2060 return unbind_to (count, Qnil);
f927c5ae
JB
2061}
2062
f927c5ae
JB
2063#endif /* not CANNOT_DUMP */
2064\f
68c45bf0
PE
2065#if HAVE_SETLOCALE
2066/* Recover from setlocale (LC_ALL, ""). */
2067void
d5a3eaaf 2068fixup_locale (void)
68c45bf0 2069{
68c45bf0
PE
2070 /* The Emacs Lisp reader needs LC_NUMERIC to be "C",
2071 so that numbers are read and printed properly for Emacs Lisp. */
2072 setlocale (LC_NUMERIC, "C");
68c45bf0
PE
2073}
2074
0c8559bb
PE
2075/* Set system locale CATEGORY, with previous locale *PLOCALE, to
2076 DESIRED_LOCALE. */
68c45bf0 2077static void
dd4c5104 2078synchronize_locale (int category, Lisp_Object *plocale, Lisp_Object desired_locale)
68c45bf0 2079{
0c8559bb
PE
2080 if (! EQ (*plocale, desired_locale))
2081 {
2082 *plocale = desired_locale;
2083 setlocale (category, (STRINGP (desired_locale)
51b59d79 2084 ? SSDATA (desired_locale)
0c8559bb
PE
2085 : ""));
2086 }
68c45bf0
PE
2087}
2088
ca9c0567 2089/* Set system time locale to match Vsystem_time_locale, if possible. */
68c45bf0 2090void
d5a3eaaf 2091synchronize_system_time_locale (void)
68c45bf0 2092{
ca9c0567
PE
2093 synchronize_locale (LC_TIME, &Vprevious_system_time_locale,
2094 Vsystem_time_locale);
68c45bf0
PE
2095}
2096
ca9c0567
PE
2097/* Set system messages locale to match Vsystem_messages_locale, if
2098 possible. */
68c45bf0 2099void
d5a3eaaf 2100synchronize_system_messages_locale (void)
68c45bf0
PE
2101{
2102#ifdef LC_MESSAGES
ca9c0567
PE
2103 synchronize_locale (LC_MESSAGES, &Vprevious_system_messages_locale,
2104 Vsystem_messages_locale);
68c45bf0
PE
2105#endif
2106}
2107#endif /* HAVE_SETLOCALE */
2108\f
f927c5ae
JB
2109
2110Lisp_Object
a8fe7202 2111decode_env_path (const char *evarname, const char *defalt)
f927c5ae 2112{
a8fe7202 2113 const char *path, *p;
213d0b1f 2114 Lisp_Object lpath, element, tem;
76151e2c 2115#ifdef WINDOWSNT
1882aa38 2116 bool defaulted = 0;
76151e2c
EZ
2117 const char *emacs_dir = egetenv ("emacs_dir");
2118 static const char *emacs_dir_env = "%emacs_dir%/";
2119 const size_t emacs_dir_len = strlen (emacs_dir_env);
2120#endif
f927c5ae 2121
2447c626
JB
2122 /* It's okay to use getenv here, because this function is only used
2123 to initialize variables when Emacs starts up, and isn't called
2124 after that. */
e065a56e 2125 if (evarname != 0)
a8fe7202 2126 path = getenv (evarname);
e065a56e
JB
2127 else
2128 path = 0;
f927c5ae 2129 if (!path)
76151e2c
EZ
2130 {
2131 path = defalt;
8671676c 2132#ifdef WINDOWSNT
76151e2c 2133 defaulted = 1;
8671676c 2134#endif
76151e2c 2135 }
6a30e6d6
RS
2136#ifdef DOS_NT
2137 /* Ensure values from the environment use the proper directory separator. */
2138 if (path)
2139 {
a8fe7202
AS
2140 char *path_copy = alloca (strlen (path) + 1);
2141 strcpy (path_copy, path);
e7ac588e 2142 dostounix_filename (path_copy, 0);
a8fe7202 2143 path = path_copy;
6a30e6d6
RS
2144 }
2145#endif
f927c5ae
JB
2146 lpath = Qnil;
2147 while (1)
2148 {
8966b757 2149 p = strchr (path, SEPCHAR);
a8fe7202
AS
2150 if (!p)
2151 p = path + strlen (path);
213d0b1f
RS
2152 element = (p - path ? make_string (path, p - path)
2153 : build_string ("."));
76151e2c
EZ
2154#ifdef WINDOWSNT
2155 /* Relative file names in the default path are interpreted as
2156 being relative to $emacs_dir. */
2157 if (emacs_dir && defaulted
2158 && strncmp (path, emacs_dir_env, emacs_dir_len) == 0)
2159 element = Fexpand_file_name (Fsubstring (element,
2160 make_number (emacs_dir_len),
2161 Qnil),
2162 build_string (emacs_dir));
2163#endif
213d0b1f
RS
2164
2165 /* Add /: to the front of the name
2166 if it would otherwise be treated as magic. */
2167 tem = Ffind_file_name_handler (element, Qt);
ca3df2d5
RS
2168
2169 /* However, if the handler says "I'm safe",
2170 don't bother adding /:. */
2171 if (SYMBOLP (tem))
2172 {
2173 Lisp_Object prop;
2174 prop = Fget (tem, intern ("safe-magic"));
2175 if (! NILP (prop))
2176 tem = Qnil;
2177 }
2178
213d0b1f
RS
2179 if (! NILP (tem))
2180 element = concat2 (build_string ("/:"), element);
2181
2182 lpath = Fcons (element, lpath);
f927c5ae
JB
2183 if (*p)
2184 path = p + 1;
2185 else
2186 break;
2187 }
2188 return Fnreverse (lpath);
2189}
2190
eab2ee89 2191DEFUN ("daemonp", Fdaemonp, Sdaemonp, 0, 0, 0,
4ff029f6
DN
2192 doc: /* Return non-nil if the current emacs process is a daemon.
2193If the daemon was given a name argument, return that name. */)
5842a27b 2194 (void)
eab2ee89 2195{
fc012771 2196 if (IS_DAEMON)
4ff029f6
DN
2197 if (daemon_name)
2198 return build_string (daemon_name);
2199 else
2200 return Qt;
2201 else
2202 return Qnil;
eab2ee89
DN
2203}
2204
5790ef40 2205DEFUN ("daemon-initialized", Fdaemon_initialized, Sdaemon_initialized, 0, 0, 0,
fc012771
SM
2206 doc: /* Mark the Emacs daemon as being initialized.
2207This finishes the daemonization process by doing the other half of detaching
2208from the parent process and its tty file descriptors. */)
5842a27b 2209 (void)
5790ef40
DN
2210{
2211 int nfd;
1882aa38 2212 bool err = 0;
5790ef40 2213
fc012771 2214 if (!IS_DAEMON)
5790ef40
DN
2215 error ("This function can only be called if emacs is run as a daemon");
2216
2217 if (daemon_pipe[1] < 0)
2218 error ("The daemon has already been initialized");
2219
2220 if (NILP (Vafter_init_time))
2221 error ("This function can only be called after loading the init files");
2222
2223 /* Get rid of stdin, stdout and stderr. */
29dadb54 2224 nfd = open ("/dev/null", O_RDWR);
dc1ca6a8
PE
2225 err |= nfd < 0;
2226 err |= dup2 (nfd, 0) < 0;
2227 err |= dup2 (nfd, 1) < 0;
2228 err |= dup2 (nfd, 2) < 0;
2229 err |= close (nfd) != 0;
5790ef40 2230
fc012771
SM
2231 /* Closing the pipe will notify the parent that it can exit.
2232 FIXME: In case some other process inherited the pipe, closing it here
2233 won't notify the parent because it's still open elsewhere, so we
2234 additionally send a byte, just to make sure the parent really exits.
2235 Instead, we should probably close the pipe in start-process and
2236 call-process to make sure the pipe is never inherited by
2237 subprocesses. */
dc1ca6a8
PE
2238 err |= write (daemon_pipe[1], "\n", 1) < 0;
2239 err |= close (daemon_pipe[1]) != 0;
5790ef40
DN
2240 /* Set it to an invalid value so we know we've already run this function. */
2241 daemon_pipe[1] = -1;
dc1ca6a8
PE
2242
2243 if (err)
2244 error ("I/O error during daemon initialization");
5790ef40
DN
2245 return Qt;
2246}
2247
dfcf069d 2248void
d5a3eaaf 2249syms_of_emacs (void)
f927c5ae 2250{
cd3520a4
JB
2251 DEFSYM (Qfile_name_handler_alist, "file-name-handler-alist");
2252 DEFSYM (Qrisky_local_variable, "risky-local-variable");
6c07aac2 2253 DEFSYM (Qkill_emacs, "kill-emacs");
73c14218 2254 DEFSYM (Qkill_emacs_hook, "kill-emacs-hook");
213d0b1f 2255
83591e66 2256#ifndef CANNOT_DUMP
f927c5ae
JB
2257 defsubr (&Sdump_emacs);
2258#endif
2259
2260 defsubr (&Skill_emacs);
2261
59653951 2262 defsubr (&Sinvocation_name);
ace40a69 2263 defsubr (&Sinvocation_directory);
eab2ee89 2264 defsubr (&Sdaemonp);
5790ef40 2265 defsubr (&Sdaemon_initialized);
59653951 2266
29208e82 2267 DEFVAR_LISP ("command-line-args", Vcommand_line_args,
2a9d2ed6
RS
2268 doc: /* Args passed by shell to Emacs, as a list of strings.
2269Many arguments are deleted from the list as they are processed. */);
f927c5ae 2270
29208e82 2271 DEFVAR_LISP ("system-type", Vsystem_type,
cf59a374 2272 doc: /* The value is a symbol indicating the type of operating system you are using.
40a8993a 2273Special values:
cf59a374
GM
2274 `gnu' compiled for a GNU Hurd system.
2275 `gnu/linux' compiled for a GNU/Linux system.
2276 `gnu/kfreebsd' compiled for a GNU system with a FreeBSD kernel.
2277 `darwin' compiled for Darwin (GNU-Darwin, Mac OS X, ...).
2278 `ms-dos' compiled as an MS-DOS application.
2279 `windows-nt' compiled as a native W32 application.
2280 `cygwin' compiled using the Cygwin library.
bd6bc222
GM
2281Anything else (in Emacs 24.1, the possibilities are: aix, berkeley-unix,
2282hpux, irix, usg-unix-v) indicates some sort of Unix system. */);
d67b4f80 2283 Vsystem_type = intern_c_string (SYSTEM_TYPE);
6edd2f3d 2284 /* See configure.ac (and config.nt) for the possible SYSTEM_TYPEs. */
f927c5ae 2285
29208e82 2286 DEFVAR_LISP ("system-configuration", Vsystem_configuration,
7db35a48
PJ
2287 doc: /* Value is string indicating configuration Emacs was built for.
2288On MS-Windows, the value reflects the OS flavor and version on which
2289Emacs is running. */);
f7511647 2290 Vsystem_configuration = build_string (EMACS_CONFIGURATION);
271c7b7c 2291
29208e82 2292 DEFVAR_LISP ("system-configuration-options", Vsystem_configuration_options,
7db35a48 2293 doc: /* String containing the configuration options Emacs was built with. */);
f0fc0b1a
KH
2294 Vsystem_configuration_options = build_string (EMACS_CONFIG_OPTIONS);
2295
29208e82 2296 DEFVAR_BOOL ("noninteractive", noninteractive1,
7db35a48 2297 doc: /* Non-nil means Emacs is running without interactive terminal. */);
e5d77022 2298
29208e82 2299 DEFVAR_LISP ("kill-emacs-hook", Vkill_emacs_hook,
e5d9c0d1 2300 doc: /* Hook run when `kill-emacs' is called.
d77b70e5 2301Since `kill-emacs' may be invoked when the terminal is disconnected (or
7db35a48
PJ
2302in other similar situations), functions placed on this hook should not
2303expect to be able to interact with the user. To ask for confirmation,
d77b70e5
MR
2304see `kill-emacs-query-functions' instead.
2305
9c524fcb
GM
2306Before Emacs 24.1, the hook was not run in batch mode, i.e., if
2307`noninteractive' was non-nil. */);
edc8ae07 2308 Vkill_emacs_hook = Qnil;
3005da00 2309
29208e82 2310 DEFVAR_LISP ("path-separator", Vpath_separator,
c7ed3276
EZ
2311 doc: /* String containing the character that separates directories in
2312search paths, such as PATH and other similar environment variables. */);
074a066b
GV
2313 {
2314 char c = SEPCHAR;
2315 Vpath_separator = make_string (&c, 1);
2316 }
59653951 2317
29208e82 2318 DEFVAR_LISP ("invocation-name", Vinvocation_name,
7db35a48
PJ
2319 doc: /* The program name that was used to run Emacs.
2320Any directory names are omitted. */);
f67de86f 2321
29208e82 2322 DEFVAR_LISP ("invocation-directory", Vinvocation_directory,
7db35a48
PJ
2323 doc: /* The directory in which the Emacs executable was found, to run it.
2324The value is nil if that directory's name is not known. */);
f67de86f 2325
29208e82 2326 DEFVAR_LISP ("installation-directory", Vinstallation_directory,
7db35a48 2327 doc: /* A directory within which to look for the `lib-src' and `etc' directories.
74cc8ff9
GM
2328In an installed Emacs, this is normally nil. It is non-nil if
2329both `lib-src' (on MS-DOS, `info') and `etc' directories are found
1e2c5d95
GM
2330within the variable `invocation-directory' or its parent. For example,
2331this is the case when running an uninstalled Emacs executable from its
74cc8ff9 2332build directory. */);
07f4d123 2333 Vinstallation_directory = Qnil;
68c45bf0 2334
29208e82 2335 DEFVAR_LISP ("system-messages-locale", Vsystem_messages_locale,
7db35a48 2336 doc: /* System locale for messages. */);
ca9c0567 2337 Vsystem_messages_locale = Qnil;
68c45bf0 2338
ca9c0567 2339 DEFVAR_LISP ("previous-system-messages-locale",
29208e82 2340 Vprevious_system_messages_locale,
7db35a48 2341 doc: /* Most recently used system locale for messages. */);
ca9c0567 2342 Vprevious_system_messages_locale = Qnil;
68c45bf0 2343
29208e82 2344 DEFVAR_LISP ("system-time-locale", Vsystem_time_locale,
7db35a48 2345 doc: /* System locale for time. */);
ca9c0567 2346 Vsystem_time_locale = Qnil;
68c45bf0 2347
29208e82 2348 DEFVAR_LISP ("previous-system-time-locale", Vprevious_system_time_locale,
7db35a48 2349 doc: /* Most recently used system locale for time. */);
ca9c0567 2350 Vprevious_system_time_locale = Qnil;
90503d96 2351
29208e82 2352 DEFVAR_LISP ("before-init-time", Vbefore_init_time,
90503d96
CY
2353 doc: /* Value of `current-time' before Emacs begins initialization. */);
2354 Vbefore_init_time = Qnil;
2355
29208e82 2356 DEFVAR_LISP ("after-init-time", Vafter_init_time,
90503d96
CY
2357 doc: /* Value of `current-time' after loading the init files.
2358This is nil during initialization. */);
2359 Vafter_init_time = Qnil;
fc012771 2360
29208e82 2361 DEFVAR_BOOL ("inhibit-x-resources", inhibit_x_resources,
9b68317c 2362 doc: /* If non-nil, X resources, Windows Registry settings, and NS defaults are not used. */);
8686ac71
JB
2363 inhibit_x_resources = 0;
2364
29208e82 2365 DEFVAR_LISP ("emacs-copyright", Vemacs_copyright,
8c5ff6dd
KR
2366 doc: /* Short copyright string for this version of Emacs. */);
2367 Vemacs_copyright = build_string (emacs_copyright);
2368
29208e82 2369 DEFVAR_LISP ("emacs-version", Vemacs_version,
8c5ff6dd
KR
2370 doc: /* Version numbers of this version of Emacs. */);
2371 Vemacs_version = build_string (emacs_version);
2372
29208e82 2373 DEFVAR_LISP ("dynamic-library-alist", Vdynamic_library_alist,
2e288d54
JB
2374 doc: /* Alist of dynamic libraries vs external files implementing them.
2375Each element is a list (LIBRARY FILE...), where the car is a symbol
2376representing a supported external library, and the rest are strings giving
2377alternate filenames for that library.
2378
2379Emacs tries to load the library from the files in the order they appear on
2380the list; if none is loaded, the running session of Emacs won't have access
2381to that library.
2382
2383Note that image types `pbm' and `xbm' do not need entries in this variable
2384because they do not depend on external libraries and are always available.
2385
2386Also note that this is not a generic facility for accessing external
2387libraries; only those already known by Emacs will be loaded. */);
2388 Vdynamic_library_alist = Qnil;
2389 Fput (intern_c_string ("dynamic-library-alist"), Qrisky_local_variable, Qt);
2390
aa15c6bb
JB
2391#ifdef WINDOWSNT
2392 Vlibrary_cache = Qnil;
2393 staticpro (&Vlibrary_cache);
2394#endif
2395
fc012771
SM
2396 /* Make sure IS_DAEMON starts up as false. */
2397 daemon_pipe[1] = 0;
f927c5ae 2398}