annotate lisp/startup.el @ 11515:0ebfc7701ebf

Make font-lock.el use compiled keywords; added FN as possible matcher. Use font-lock-syntax-table for syntactic fontification. Use font-lock-after-fontify-buffer not font-lock-after-fontify-buffer-hook.
author Simon Marshall <simon@gnu.org>
date Mon, 24 Apr 1995 10:49:03 +0000
parents f5079cb33831
children 5e836a7d213d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 650
diff changeset
1 ;;; startup.el --- process Emacs shell arguments
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 650
diff changeset
2
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
3 ;; Copyright (C) 1985, 1986, 1992, 1994 Free Software Foundation, Inc.
840
113281b361ec *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 823
diff changeset
4
787
3cece0106722 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 779
diff changeset
5 ;; Maintainer: FSF
814
38b2499cb3e9 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 789
diff changeset
6 ;; Keywords: internal
787
3cece0106722 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 779
diff changeset
7
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
8 ;; This file is part of GNU Emacs.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
9
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
621
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 437
diff changeset
12 ;; the Free Software Foundation; either version 2, or (at your option)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
13 ;; any later version.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
14
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
18 ;; GNU General Public License for more details.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
19
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
21 ;; along with GNU Emacs; see the file COPYING. If not, write to
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
22 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
23
787
3cece0106722 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 779
diff changeset
24 ;;; Commentary:
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
25
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
26 ; These are processed only at the beginning of the argument list.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
27 ; -batch execute noninteractively (messages go to stdout,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
28 ; variable noninteractive set to t)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
29 ; This option must be the first in the arglist.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
30 ; Processed by `main' in emacs.c -- never seen by lisp
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
31 ; -t file Specify to use file rather than stdin/stdout
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
32 ; as the terminal.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
33 ; This option must be the first in the arglist.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
34 ; Processed by `main' in emacs.c -- never seen by lisp
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
35 ; -nw Inhibit the use of any window-system-specific display
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
36 ; code; use the current virtual terminal.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
37 ; This option must be the first in the arglist.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
38 ; Processed by `main' in emacs.c -- never seen by lisp
11083
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
39 ; -q load no init file; don't load default.el either.
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
40 ; But this has no effect on site-start.el.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
41 ; -no-init-file same
11083
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
42 ; -u user load USER's init file instead of your own.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
43 ; -user user same
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
44 ; -debug-init Don't catch errors in init file; let debugger run.
11083
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
45 ; -no-site-file Don't load site-start.el.
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
46 ; (This is the ONLY way to prevent loading that file.)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
47
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
48 ; These are processed in the order encountered.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
49 ; -f function execute function
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
50 ; -funcall function same
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
51 ; -l file load file
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
52 ; -load file same
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
53 ; -insert file insert file into buffer
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
54 ; file visit file
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
55 ; -kill kill (exit) emacs
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
56
787
3cece0106722 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 779
diff changeset
57 ;;; Code:
3cece0106722 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 779
diff changeset
58
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
59 (setq top-level '(normal-top-level))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
60
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
61 (defvar command-line-processed nil "t once command line has been processed")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
62
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
63 (defconst inhibit-startup-message nil
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
64 "*Non-nil inhibits the initial startup message.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
65 This is for use in your personal init file, once you are familiar
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
66 with the contents of the startup message.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
67
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
68 (defconst inhibit-startup-echo-area-message nil
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
69 "*Non-nil inhibits the initial startup echo area message.
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
70 Inhibition takes effect only if your `.emacs' file contains
7880
3dd8448eee15 (inhibit-startup-echo-area-message): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7658
diff changeset
71 a line of this form:
6119
9e150a376c32 (inhibit-startup-echo-area-message): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 5932
diff changeset
72 (setq inhibit-startup-echo-area-message \"YOUR-USER-NAME\")
7880
3dd8448eee15 (inhibit-startup-echo-area-message): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7658
diff changeset
73 If your `.emacs' file is byte-compiled, use the following form instead:
3dd8448eee15 (inhibit-startup-echo-area-message): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7658
diff changeset
74 (eval '(setq inhibit-startup-echo-area-message \"YOUR-USER-NAME\"))
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
75 Thus, someone else using a copy of your `.emacs' file will see
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
76 the startup message unless he personally acts to inhibit it.")
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
77
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
78 (defconst inhibit-default-init nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
79 "*Non-nil inhibits loading the `default' library.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
80
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
81 (defconst command-switch-alist nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
82 "Alist of command-line switches.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
83 Elements look like (SWITCH-STRING . HANDLER-FUNCTION).
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
84 HANDLER-FUNCTION receives switch name as sole arg;
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
85 remaining command-line args are in the variable `command-line-args-left'.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
86
8335
e6afa5879de3 (command-line-args-left): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8147
diff changeset
87 (defvar command-line-args-left nil
e6afa5879de3 (command-line-args-left): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8147
diff changeset
88 "List of command-line args not yet processed.")
e6afa5879de3 (command-line-args-left): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8147
diff changeset
89
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
90 (defvar command-line-functions nil ;; lrs 7/31/89
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
91 "List of functions to process unrecognized command-line arguments.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
92 Each function should access the dynamically bound variables
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
93 `argi' (the current argument) and `command-line-args-left' (the remaining
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
94 arguments). The function should return non-nil only if it recognizes and
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
95 processes `argi'. If it does so, it may consume successive arguments by
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
96 altering `command-line-args-left' to remove them.")
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
97
7022
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
98 (defvar command-line-default-directory nil
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
99 "Default directory to use for command line arguments.
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
100 This is normally copied from `default-directory' when Emacs starts.")
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
101
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
102 (defvar before-init-hook nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
103 "Functions to call after handling urgent options but before init files.
779
c2dbf1fe0506 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
104 The frame system uses this to open frames to display messages while
370
d56e16bd220a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 326
diff changeset
105 Emacs loads the user's initialization file.")
d56e16bd220a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 326
diff changeset
106
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
107 (defvar after-init-hook nil
1550
279b5a572def Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 903
diff changeset
108 "Functions to call after loading the init file (`~/.emacs').
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
109 The call is not protected by a condition-case, so you can set `debug-on-error'
1550
279b5a572def Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 903
diff changeset
110 in `.emacs', and put all the actual code on `after-init-hook'.")
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
111
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
112 (defvar term-setup-hook nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
113 "Functions to be called after loading terminal-specific Lisp code.
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
114 See `run-hooks'. This variable exists for users to set,
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
115 so as to override the definitions made by the terminal-specific file.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
116 Emacs never sets this variable itself.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
117
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
118 (defvar keyboard-type nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
119 "The brand of keyboard you are using.
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
120 This variable is used to define
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
121 the proper function and keypad keys for use under X. It is used in a
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
122 fashion analogous to the environment value TERM.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
123
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
124 (defvar window-setup-hook nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
125 "Normal hook run to initialize window system display.
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
126 Emacs runs this hook after processing the command line arguments and loading
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
127 the user's init file.")
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
128
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
129 (defconst initial-major-mode 'lisp-interaction-mode
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
130 "Major mode command symbol to use for the initial *scratch* buffer.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
131
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
132 (defvar init-file-user nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
133 "Identity of user whose `.emacs' file is or was read.
6980
ef1b2bd0b19e (init-file-user): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 6911
diff changeset
134 The value is nil if no init file is being used; otherwise, it may be either
ef1b2bd0b19e (init-file-user): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 6911
diff changeset
135 the null string, meaning that the init file was taken from the user that
ef1b2bd0b19e (init-file-user): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 6911
diff changeset
136 originally logged in, or it may be a string containing a user's name.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
137
6980
ef1b2bd0b19e (init-file-user): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 6911
diff changeset
138 In either of the latter cases, `(concat \"~\" init-file-user \"/\")'
ef1b2bd0b19e (init-file-user): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 6911
diff changeset
139 evaluates to the name of the directory where the `.emacs' file was
11083
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
140 looked for.
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
141
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
142 Setting `init-file-user' does not prevent Emacs from loading
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
143 `site-start.el'. The only way to do that is to use `--no-site-file'.")
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
144
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
145 (defvar site-run-file "site-start"
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
146 "File containing site-wide run-time initializations.
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
147 This file is loaded at run-time before `~/.emacs'. It contains inits
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
148 that need to be in place for the entire site, but which, due to their
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
149 higher incidence of change, don't make sense to load into emacs'
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
150 dumped image. Thus, the run-time load order is: 1. file described in
11083
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
151 this variable, if non-nil; 2. `~/.emacs'; 3. `default.el'.
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
152
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
153 Don't use the `site-start.el' file for things some users may not like.
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
154 Put them in `default.el' instead, so that users can more easily
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
155 override them. Users can prevent loading `default.el' with the `-q'
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
156 option or by setting `inhibit-default-init' in their own init files,
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
157 but inhibiting `site-start.el' requires `--no-site-file', which
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
158 is less convenient.")
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
159
8147
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
160 (defconst iso-8859-1-locale-regexp "8859[-_]?1"
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
161 "Regexp that specifies when to enable the ISO 8859-1 character set.
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
162 We do that if this regexp matches the locale name
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
163 specified by the LC_ALL, LC_CTYPE and LANG environment variables.")
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
164
8989
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
165 (defvar mail-host-address nil
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
166 "*Name of this machine, for purposes of naming users.")
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
167
8048
5253d3981da6 (user-mail-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7880
diff changeset
168 (defvar user-mail-address nil
8989
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
169 "*Full mailing address of this user.")
8048
5253d3981da6 (user-mail-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7880
diff changeset
170
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
171 (defvar init-file-debug nil)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
172
5109
062da10a4a6b (command-line): Set init-file-had-error to t or nil.
Richard M. Stallman <rms@gnu.org>
parents: 5024
diff changeset
173 (defvar init-file-had-error nil)
062da10a4a6b (command-line): Set init-file-had-error to t or nil.
Richard M. Stallman <rms@gnu.org>
parents: 5024
diff changeset
174
9443
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
175 ;; This function is called from the subdirs.el file.
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
176 (defun normal-top-level-add-to-load-path (dirs)
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
177 (let ((tail (member default-directory load-path)))
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
178 (setcdr tail (append (mapcar 'expand-file-name dirs) (cdr tail)))))
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
179
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
180 (defun normal-top-level ()
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
181 (if command-line-processed
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
182 (message "Back to top level.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
183 (setq command-line-processed t)
11294
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
184 ;; Give *Messages* the same default-directory as *scratch*,
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
185 ;; just to keep things predictable.
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
186 (let ((dir default-directory))
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
187 (save-excursion
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
188 (set-buffer (get-buffer "*Messages*"))
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
189 (setq default-directory dir)))
9443
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
190 ;; Look in each dir in load-path for a subdirs.el file.
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
191 ;; If we find one, load it, which will add the appropriate subdirs
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
192 ;; of that dir into load-path,
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
193 (let ((tail load-path)
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
194 new)
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
195 (while tail
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
196 (setq new (cons (car tail) new))
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
197 (let ((default-directory (car tail)))
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
198 (load (expand-file-name "subdirs.el" (car tail)) t t t))
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
199 (setq tail (cdr tail))))
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
200 (if (not (eq system-type 'vax-vms))
1558
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
201 (progn
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
202 ;; If the PWD environment variable isn't accurate, delete it.
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
203 (let ((pwd (getenv "PWD")))
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
204 (and (stringp pwd)
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
205 ;; Use FOO/., so that if FOO is a symlink, file-attributes
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
206 ;; describes the directory linked to, not FOO itself.
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
207 (or (equal (file-attributes
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
208 (concat (file-name-as-directory pwd) "."))
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
209 (file-attributes
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
210 (concat (file-name-as-directory default-directory)
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
211 ".")))
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
212 (setq process-environment
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
213 (delete (concat "PWD=" pwd)
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
214 process-environment)))))))
707
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 688
diff changeset
215 (setq default-directory (abbreviate-file-name default-directory))
8989
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
216 (setq user-mail-address (concat (user-login-name) "@"
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
217 (or mail-host-address
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
218 (system-name))))
7371
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
219 (let ((menubar-bindings-done nil))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
220 (unwind-protect
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
221 (command-line)
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
222 ;; Do this again, in case .emacs defined more abbreviations.
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
223 (setq default-directory (abbreviate-file-name default-directory))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
224 (run-hooks 'emacs-startup-hook)
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
225 (and term-setup-hook
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
226 (run-hooks 'term-setup-hook))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
227 ;; Modify the initial frame based on what .emacs puts into
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
228 ;; ...-frame-alist.
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
229 (if (fboundp 'frame-notice-user-settings)
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
230 (frame-notice-user-settings))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
231 ;; Now we know the user's default font, so add it to the menu.
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
232 (if (fboundp 'font-menu-add-default)
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
233 (font-menu-add-default))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
234 (and window-setup-hook
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
235 (run-hooks 'window-setup-hook))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
236 (or menubar-bindings-done
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
237 (precompute-menubar-bindings))))))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
238
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
239 ;; Precompute the keyboard equivalents in the menu bar items.
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
240 (defun precompute-menubar-bindings ()
7509
dd0db01bc9f4 (precompute-menubar-bindings): Don't precompute menus if not using x.
Richard M. Stallman <rms@gnu.org>
parents: 7371
diff changeset
241 (if (eq window-system 'x)
7371
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
242 (let ((submap (lookup-key global-map [menu-bar])))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
243 (while submap
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
244 (and (consp (car submap))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
245 (symbolp (car (car submap)))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
246 (stringp (car-safe (cdr (car submap))))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
247 (keymapp (cdr (cdr (car submap))))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
248 (x-popup-menu nil (cdr (cdr (car submap)))))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
249 (setq submap (cdr submap))))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
250
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
251 (defun command-line ()
7022
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
252 (setq command-line-default-directory default-directory)
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
253
823
746ebe6cc4c8 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 814
diff changeset
254 ;; See if we should import version-control from the environment variable.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
255 (let ((vc (getenv "VERSION_CONTROL")))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
256 (cond ((eq vc nil)) ;don't do anything if not set
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
257 ((or (string= vc "t")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
258 (string= vc "numbered"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
259 (setq version-control t))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
260 ((or (string= vc "nil")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
261 (string= vc "existing"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
262 (setq version-control nil))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
263 ((or (string= vc "never")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
264 (string= vc "simple"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
265 (setq version-control 'never))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
266
8147
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
267 (if (let ((ctype
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
268 ;; Use the first of these three envvars that has a nonempty value.
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
269 (or (let ((string (getenv "LC_ALL")))
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
270 (and (not (equal string "")) string))
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
271 (let ((string (getenv "LC_CTYPE")))
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
272 (and (not (equal string "")) string))
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
273 (let ((string (getenv "LANG")))
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
274 (and (not (equal string "")) string)))))
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
275 (and ctype
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
276 (string-match iso-8859-1-locale-regexp ctype)))
8127
81dacf7883e7 (command-line): Automatically use iso-syntax and
Richard M. Stallman <rms@gnu.org>
parents: 8048
diff changeset
277 (progn
9348
c4ccb2502ebf (command-line): Load disp-table explicitly.
Richard M. Stallman <rms@gnu.org>
parents: 9174
diff changeset
278 (require 'disp-table)
8127
81dacf7883e7 (command-line): Automatically use iso-syntax and
Richard M. Stallman <rms@gnu.org>
parents: 8048
diff changeset
279 (standard-display-european t)
81dacf7883e7 (command-line): Automatically use iso-syntax and
Richard M. Stallman <rms@gnu.org>
parents: 8048
diff changeset
280 (require 'iso-syntax)))
81dacf7883e7 (command-line): Automatically use iso-syntax and
Richard M. Stallman <rms@gnu.org>
parents: 8048
diff changeset
281
755
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
282 ;;! This has been commented out; I currently find the behavior when
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
283 ;;! split-window-keep-point is nil disturbing, but if I can get used
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
284 ;;! to it, then it would be better to eliminate the option.
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
285 ;;! ;; Choose a good default value for split-window-keep-point.
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
286 ;;! (setq split-window-keep-point (> baud-rate 2400))
384
9dab5ca1890f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 370
diff changeset
287
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
288 ;; Read window system's init file if using a window system.
8748
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
289 (condition-case error
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
290 (if (and window-system (not noninteractive))
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
291 (load (concat term-file-prefix
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
292 (symbol-name window-system)
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
293 "-win")
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
294 ;; Every window system should have a startup file;
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
295 ;; barf if we can't find it.
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
296 nil t))
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
297 ;; If we can't read it, print the error message and exit.
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
298 (error
8749
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
299 (princ
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
300 (if (eq (car error) 'error)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
301 (apply 'concat (cdr error))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
302 (if (memq 'file-error (get (car error) 'error-conditions))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
303 (format "%s: %s"
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
304 (nth 1 error)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
305 (mapconcat '(lambda (obj) (prin1-to-string obj t))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
306 (cdr (cdr error)) ", "))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
307 (format "%s: %s"
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
308 (get (car error) 'error-message)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
309 (mapconcat '(lambda (obj) (prin1-to-string obj t))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
310 (cdr error) ", "))))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
311 'external-debugging-output)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
312 (setq window-system nil)
8748
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
313 (kill-emacs)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
314
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
315 (let ((done nil)
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
316 (args (cdr command-line-args)))
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
317
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
318 ;; Figure out which user's init file to load,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
319 ;; either from the environment or from the options.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
320 (setq init-file-user (if noninteractive nil (user-login-name)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
321 ;; If user has not done su, use current $HOME to find .emacs.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
322 (and init-file-user (string= init-file-user (user-real-login-name))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
323 (setq init-file-user ""))
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
324
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
325 ;; Process the command-line args, and delete the arguments
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
326 ;; processed. This is consistent with the way main in emacs.c
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
327 ;; does things.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
328 (while (and (not done) args)
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
329 (let ((longopts '(("--no-init-file") ("--no-site-file") ("--user")
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
330 ("--debug-init")))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
331 (argi (car args))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
332 (argval nil))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
333 (if (string-match "=" argi)
9174
900fdf19446a (command-line): Fix bug in previous change.
Karl Heuer <kwzh@gnu.org>
parents: 9173
diff changeset
334 (setq argval (substring argi (match-end 0))
900fdf19446a (command-line): Fix bug in previous change.
Karl Heuer <kwzh@gnu.org>
parents: 9173
diff changeset
335 argi (substring argi 0 (match-beginning 0))))
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
336 (let ((completion (try-completion argi longopts)))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
337 (if (eq completion t)
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
338 (setq argi (substring argi 1))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
339 (if (stringp completion)
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
340 (let ((elt (assoc completion longopts)))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
341 (or elt
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
342 (error "Option `%s' is ambiguous" argi))
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
343 (setq argi (substring (car elt) 1)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
344 (setq argval nil))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
345 (cond
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
346 ((or (string-equal argi "-q")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
347 (string-equal argi "-no-init-file"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
348 (setq init-file-user nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
349 args (cdr args)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
350 ((or (string-equal argi "-u")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
351 (string-equal argi "-user"))
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
352 (or argval
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
353 (setq argval (car args)
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
354 args (cdr args)))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
355 (setq init-file-user argval
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
356 argval nil
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
357 args (cdr args)))
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
358 ((string-equal argi "-no-site-file")
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
359 (setq site-run-file nil
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
360 args (cdr args)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
361 ((string-equal argi "-debug-init")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
362 (setq init-file-debug t
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
363 args (cdr args)))
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
364 (t (setq done t)))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
365 ;; Was argval set but not used?
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
366 (and argval
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
367 (error "Option `%s' doesn't allow an argument" argi))))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
368
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
369 ;; Re-attach the program name to the front of the arg list.
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
370 (setcdr command-line-args args))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
371
2761
26bad513fbb0 (command-line): Call frame-initialize explicitly.
Richard M. Stallman <rms@gnu.org>
parents: 2105
diff changeset
372 ;; Under X Windows, this creates the X frame and deletes the terminal frame.
6874
12dcd89cfd88 (command-line): Call face-initialize before frame-initialize.
Richard M. Stallman <rms@gnu.org>
parents: 6593
diff changeset
373 (if (fboundp 'face-initialize)
12dcd89cfd88 (command-line): Call face-initialize before frame-initialize.
Richard M. Stallman <rms@gnu.org>
parents: 6593
diff changeset
374 (face-initialize))
2869
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
375 (if (fboundp 'frame-initialize)
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
376 (frame-initialize))
8759
19d9177069c4 (command-line): If initial X frame has a menu bar, mark menu-bar-mode as on.
Richard M. Stallman <rms@gnu.org>
parents: 8749
diff changeset
377 ;; If frame was created with a menu bar, set menu-bar-mode on.
19d9177069c4 (command-line): If initial X frame has a menu bar, mark menu-bar-mode as on.
Richard M. Stallman <rms@gnu.org>
parents: 8749
diff changeset
378 (if (and (eq window-system 'x)
19d9177069c4 (command-line): If initial X frame has a menu bar, mark menu-bar-mode as on.
Richard M. Stallman <rms@gnu.org>
parents: 8749
diff changeset
379 (> (cdr (assq 'menu-bar-lines (frame-parameters))) 0))
19d9177069c4 (command-line): If initial X frame has a menu bar, mark menu-bar-mode as on.
Richard M. Stallman <rms@gnu.org>
parents: 8749
diff changeset
380 (menu-bar-mode t))
2761
26bad513fbb0 (command-line): Call frame-initialize explicitly.
Richard M. Stallman <rms@gnu.org>
parents: 2105
diff changeset
381
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
382 (run-hooks 'before-init-hook)
370
d56e16bd220a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 326
diff changeset
383
883
5a7ed0421c9d *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 876
diff changeset
384 ;; Run the site-start library if it exists. The point of this file is
5a7ed0421c9d *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 876
diff changeset
385 ;; that it is run before .emacs. There is no point in doing this after
5a7ed0421c9d *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 876
diff changeset
386 ;; .emacs; that is useless.
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
387 (if site-run-file
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
388 (load site-run-file t t))
883
5a7ed0421c9d *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 876
diff changeset
389
4672
8996606e0a12 (command-line): Setq inhibit-startup-message to nil.
Richard M. Stallman <rms@gnu.org>
parents: 4599
diff changeset
390 ;; Sites should not disable this. Only individuals should disable
8996606e0a12 (command-line): Setq inhibit-startup-message to nil.
Richard M. Stallman <rms@gnu.org>
parents: 4599
diff changeset
391 ;; the startup message.
8996606e0a12 (command-line): Setq inhibit-startup-message to nil.
Richard M. Stallman <rms@gnu.org>
parents: 4599
diff changeset
392 (setq inhibit-startup-message nil)
8996606e0a12 (command-line): Setq inhibit-startup-message to nil.
Richard M. Stallman <rms@gnu.org>
parents: 4599
diff changeset
393
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
394 ;; Load that user's init file, or the default one, or none.
5379
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
395 (let (debug-on-error-from-init-file
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
396 debug-on-error-should-be-set
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
397 (debug-on-error-initial
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
398 (if (eq init-file-debug t) 'startup init-file-debug)))
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
399 (let ((debug-on-error debug-on-error-initial)
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
400 ;; This function actually reads the init files.
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
401 (inner
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
402 (function
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
403 (lambda ()
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
404 (if init-file-user
5450
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
405 (progn
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
406 (setq user-init-file
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
407 (cond
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
408 ((eq system-type 'ms-dos)
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
409 (concat "~" init-file-user "/_emacs"))
9778
7641fc43ca94 (command-line): Use ~/_emacs as init file in windows-nt.
Richard M. Stallman <rms@gnu.org>
parents: 9443
diff changeset
410 ((eq system-type 'windows-nt)
7641fc43ca94 (command-line): Use ~/_emacs as init file in windows-nt.
Richard M. Stallman <rms@gnu.org>
parents: 9443
diff changeset
411 "~/_emacs")
5450
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
412 ((eq system-type 'vax-vms)
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
413 "sys$login:.emacs")
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
414 (t
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
415 (concat "~" init-file-user "/.emacs"))))
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
416 (load user-init-file t t t)
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
417 (or inhibit-default-init
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
418 (let ((inhibit-startup-message nil))
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
419 ;; Users are supposed to be told their rights.
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
420 ;; (Plus how to get help and how to undo.)
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
421 ;; Don't you dare turn this off for anyone
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
422 ;; except yourself.
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
423 (load "default" t t)))))))))
5379
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
424 (if init-file-debug
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
425 ;; Do this without a condition-case if the user wants to debug.
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
426 (funcall inner)
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
427 (condition-case error
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
428 (progn
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
429 (funcall inner)
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
430 (setq init-file-had-error nil))
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
431 (error (message "Error in init file: %s%s%s"
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
432 (get (car error) 'error-message)
6911
6062cabdbe74 (command-line): If no error data, print "", not nil.
Karl Heuer <kwzh@gnu.org>
parents: 6874
diff changeset
433 (if (cdr error) ": " "")
5379
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
434 (mapconcat 'prin1-to-string (cdr error) ", "))
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
435 (setq init-file-had-error t))))
6911
6062cabdbe74 (command-line): If no error data, print "", not nil.
Karl Heuer <kwzh@gnu.org>
parents: 6874
diff changeset
436 ;; If we can tell that the init file altered debug-on-error,
5379
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
437 ;; arrange to preserve the value that it set up.
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
438 (or (eq debug-on-error debug-on-error-initial)
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
439 (setq debug-on-error-should-be-set t
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
440 debug-on-error-from-init-file debug-on-error)))
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
441 (if debug-on-error-should-be-set
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
442 (setq debug-on-error debug-on-error-from-init-file)))
370
d56e16bd220a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 326
diff changeset
443
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
444 (run-hooks 'after-init-hook)
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
445
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
446 ;; If *scratch* exists and init file didn't change its mode, initialize it.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
447 (if (get-buffer "*scratch*")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
448 (save-excursion
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
449 (set-buffer "*scratch*")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
450 (if (eq major-mode 'fundamental-mode)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
451 (funcall initial-major-mode))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
452 ;; Load library for our terminal type.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
453 ;; User init file can set term-file-prefix to nil to prevent this.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
454 (and term-file-prefix (not noninteractive) (not window-system)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
455 (let ((term (getenv "TERM"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
456 hyphend)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
457 (while (and term
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
458 (not (load (concat term-file-prefix term) t t)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
459 ;; Strip off last hyphen and what follows, then try again
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
460 (if (setq hyphend (string-match "[-_][^-_]+$" term))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
461 (setq term (substring term 0 hyphend))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
462 (setq term nil)))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
463
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
464 ;; Process the remaining args.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
465 (command-line-1 (cdr command-line-args))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
466
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
467 ;; If -batch, terminate after processing the command options.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
468 (if noninteractive (kill-emacs t)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
469
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
470 (defun command-line-1 (command-line-args-left)
5109
062da10a4a6b (command-line): Set init-file-had-error to t or nil.
Richard M. Stallman <rms@gnu.org>
parents: 5024
diff changeset
471 (or noninteractive (input-pending-p) init-file-had-error
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
472 (and inhibit-startup-echo-area-message
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
473 (let ((buffer (get-buffer-create " *temp*")))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
474 (prog1
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
475 (condition-case nil
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
476 (save-excursion
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
477 (set-buffer buffer)
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
478 (insert-file-contents user-init-file)
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
479 (re-search-forward
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
480 (concat
5932
86efd91bb72c (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5931
diff changeset
481 "([ \t\n]*setq[ \t\n]+"
86efd91bb72c (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5931
diff changeset
482 "inhibit-startup-echo-area-message[ \t\n]+"
5931
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
483 (regexp-quote
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
484 (prin1-to-string
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
485 (if (string= init-file-user "")
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
486 (user-login-name)
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
487 init-file-user)))
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
488 "[ \t\n]*)")
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
489 nil t))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
490 (error nil))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
491 (kill-buffer buffer))))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
492 (message (if (eq (key-binding "\C-h\C-p") 'describe-project)
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
493 "For information about the GNU Project and its goals, type C-h C-p."
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
494 (substitute-command-keys
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
495 "For information about the GNU Project and its goals, type \\[describe-project]."))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
496 (if (null command-line-args-left)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
497 (cond ((and (not inhibit-startup-message) (not noninteractive)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
498 ;; Don't clobber a non-scratch buffer if init file
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
499 ;; has selected it.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
500 (string= (buffer-name) "*scratch*")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
501 (not (input-pending-p)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
502 ;; If there are no switches to process, we might as well
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
503 ;; run this hook now, and there may be some need to do it
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
504 ;; before doing any output.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
505 (and term-setup-hook
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
506 (run-hooks 'term-setup-hook))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
507 ;; Don't let the hook be run twice.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
508 (setq term-setup-hook nil)
2869
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
509
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
510 ;; It's important to notice the user settings before we
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
511 ;; display the startup message; otherwise, the settings
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
512 ;; won't take effect until the user gives the first
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
513 ;; keystroke, and that's distracting.
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
514 (if (fboundp 'frame-notice-user-settings)
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
515 (frame-notice-user-settings))
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
516
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
517 (and window-setup-hook
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
518 (run-hooks 'window-setup-hook))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
519 (setq window-setup-hook nil)
7658
c06b9bcb12e7 (command-line-1): Precompute menu bar before startup msg.
Richard M. Stallman <rms@gnu.org>
parents: 7509
diff changeset
520 ;; Do this now to avoid an annoying delay if the user
c06b9bcb12e7 (command-line-1): Precompute menu bar before startup msg.
Richard M. Stallman <rms@gnu.org>
parents: 7509
diff changeset
521 ;; clicks the menu bar during the sit-for.
c06b9bcb12e7 (command-line-1): Precompute menu bar before startup msg.
Richard M. Stallman <rms@gnu.org>
parents: 7509
diff changeset
522 (precompute-menubar-bindings)
c06b9bcb12e7 (command-line-1): Precompute menu bar before startup msg.
Richard M. Stallman <rms@gnu.org>
parents: 7509
diff changeset
523 (setq menubar-bindings-done t)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
524 (unwind-protect
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
525 (progn
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
526 (insert (emacs-version)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
527 "
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
528 Copyright (C) 1994 Free Software Foundation, Inc.\n\n")
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
529 ;; If keys have their default meanings,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
530 ;; use precomputed string to save lots of time.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
531 (if (and (eq (key-binding "\C-h") 'help-command)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
532 (eq (key-binding "\C-xu") 'advertised-undo)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
533 (eq (key-binding "\C-x\C-c") 'save-buffers-kill-emacs)
10272
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
534 (eq (key-binding "\C-ht") 'help-with-tutorial)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
535 (eq (key-binding "\C-hi") 'info))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
536 (insert
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
537 "Type C-h for help; C-x u to undo changes. (`C-' means use CTRL key.)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
538 To kill the Emacs job, type C-x C-c.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
539 Type C-h t for a tutorial on using Emacs.
10272
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
540 Type C-h i to enter Info, which you can use to read GNU documentation.")
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
541 (insert (substitute-command-keys
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
542 (format "Type %s for help; \\[advertised-undo] to undo changes. (`C-' means use CTRL key.)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
543 To kill the Emacs job, type \\[save-buffers-kill-emacs].
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
544 Type \\[help-with-tutorial] for a tutorial on using Emacs.
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
545 Type \\[info] to enter Info, which you can use to read GNU documentation."
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
546 (let ((where (where-is-internal
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
547 'help-command nil t)))
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
548 (if where
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
549 (key-description where)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
550 "M-x help"))))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
551
10272
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
552 ;; Windows and MSDOS (currently) do not count as
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
553 ;; window systems, but do have mouse support.
10285
abacb10bd5e6 Fix typo in previous change.
Richard M. Stallman <rms@gnu.org>
parents: 10272
diff changeset
554 (if (or (memq system-type '(msdos windowsnt))
10272
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
555 window-system)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
556 (insert "
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
557 C-mouse-3 (third mouse button, with Control) gets a mode-specific menu."))
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
558 (insert "\n")
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
559 (if (and (eq (key-binding "\C-h\C-c") 'describe-copying)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
560 (eq (key-binding "\C-h\C-d") 'describe-distribution)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
561 (eq (key-binding "\C-h\C-w") 'describe-no-warranty))
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
562 (insert
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
563 "
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
564 GNU Emacs comes with ABSOLUTELY NO WARRANTY; type C-h C-w for full details.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
565 You may give out copies of Emacs; type C-h C-c to see the conditions.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
566 Type C-h C-d for information on getting the latest version.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
567 (insert (substitute-command-keys
10272
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
568 "
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
569 GNU Emacs comes with ABSOLUTELY NO WARRANTY; type \\[describe-no-warranty] for full details.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
570 You may give out copies of Emacs; type \\[describe-copying] to see the conditions.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
571 Type \\[describe-distribution] for information on getting the latest version.")))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
572 (set-buffer-modified-p nil)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
573 (sit-for 120))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
574 (save-excursion
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
575 ;; In case the Emacs server has already selected
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
576 ;; another buffer, erase the one our message is in.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
577 (set-buffer (get-buffer "*scratch*"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
578 (erase-buffer)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
579 (set-buffer-modified-p nil)))))
10324
82efaa5a2567 (command-line-1): Pause between init file error
Richard M. Stallman <rms@gnu.org>
parents: 10285
diff changeset
580 ;; Delay 2 seconds after the init file error message
82efaa5a2567 (command-line-1): Pause between init file error
Richard M. Stallman <rms@gnu.org>
parents: 10285
diff changeset
581 ;; was displayed, so user can read it.
82efaa5a2567 (command-line-1): Pause between init file error
Richard M. Stallman <rms@gnu.org>
parents: 10285
diff changeset
582 (if init-file-had-error
82efaa5a2567 (command-line-1): Pause between init file error
Richard M. Stallman <rms@gnu.org>
parents: 10285
diff changeset
583 (sit-for 2))
7022
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
584 (let ((dir command-line-default-directory)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
585 (file-count 0)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
586 first-file-buffer
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
587 (line 0))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
588 (while command-line-args-left
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
589 (let* ((argi (car command-line-args-left))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
590 (orig-argi argi)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
591 ;; This includes our standard options' long versions
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
592 ;; and long versions of what's on command-switch-alist.
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
593 (longopts
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
594 (append '(("--funcall") ("--load") ("--insert") ("--kill"))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
595 (mapcar '(lambda (elt)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
596 (list (concat "-" (car elt))))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
597 command-switch-alist)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
598 tem argval completion)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
599 (setq command-line-args-left (cdr command-line-args-left))
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
600
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
601 ;; Convert long options to ordinary options
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
602 ;; and separate out an attached option argument into argval.
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
603 (if (string-match "^--[^=]*=" argi)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
604 (setq argval (substring argi (match-end 0))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
605 argi (substring argi 0 (1- (match-end 0)))))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
606 (setq completion (try-completion argi longopts))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
607 (if (eq completion t)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
608 (setq argi (substring argi 1))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
609 (if (stringp completion)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
610 (let ((elt (assoc completion longopts)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
611 (or elt
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
612 (error "Option `%s' is ambiguous" argi))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
613 (setq argi (substring (car elt) 1)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
614 (setq argval nil argi orig-argi)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
615
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
616 ;; Execute the option.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
617 (cond ((setq tem (assoc argi command-switch-alist))
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
618 (if argval
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
619 (let ((command-line-args-left
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
620 (cons argval command-line-args-left)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
621 (funcall (cdr tem) argi))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
622 (funcall (cdr tem) argi)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
623 ((or (string-equal argi "-f") ;what the manual claims
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
624 (string-equal argi "-funcall")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
625 (string-equal argi "-e")) ; what the source used to say
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
626 (if argval
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
627 (setq tem (intern argval))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
628 (setq tem (intern (car command-line-args-left)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
629 (setq command-line-args-left (cdr command-line-args-left)))
10444
c6bc0c89d0ce (command-line-1): Handle -f with kbd macro.
Richard M. Stallman <rms@gnu.org>
parents: 10324
diff changeset
630 (if (arrayp (symbol-function tem))
c6bc0c89d0ce (command-line-1): Handle -f with kbd macro.
Richard M. Stallman <rms@gnu.org>
parents: 10324
diff changeset
631 (command-execute tem)
c6bc0c89d0ce (command-line-1): Handle -f with kbd macro.
Richard M. Stallman <rms@gnu.org>
parents: 10324
diff changeset
632 (funcall tem)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
633 ((or (string-equal argi "-l")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
634 (string-equal argi "-load"))
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
635 (if argval
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
636 (setq tem argval)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
637 (setq tem (car command-line-args-left)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
638 command-line-args-left (cdr command-line-args-left)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
639 (let ((file tem))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
640 ;; Take file from default dir if it exists there;
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
641 ;; otherwise let `load' search for it.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
642 (if (file-exists-p (expand-file-name file))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
643 (setq file (expand-file-name file)))
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
644 (load file nil t)))
3072
a655e32e6270 * startup.el (command-line-1): Don't handle `-i'. We're
Jim Blandy <jimb@redhat.com>
parents: 2869
diff changeset
645 ((string-equal argi "-insert")
748
4714ad36583c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 707
diff changeset
646 (or (stringp (car command-line-args-left))
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
647 (error "File name omitted from `-insert' option"))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
648 (if argval
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
649 (setq tem argval)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
650 (setq tem (car command-line-args-left)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
651 command-line-args-left (cdr command-line-args-left)))
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
652 (insert-file-contents tem))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
653 ((string-equal argi "-kill")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
654 (kill-emacs t))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
655 ((string-match "^\\+[0-9]+\\'" argi)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
656 (setq line (string-to-int argi)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
657 (t
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
658 ;; We have almost exhausted our options. See if the
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
659 ;; user has made any other command-line options available
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
660 (let ((hooks command-line-functions);; lrs 7/31/89
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
661 (did-hook nil))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
662 (while (and hooks
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
663 (not (setq did-hook (funcall (car hooks)))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
664 (setq hooks (cdr hooks)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
665 (if (not did-hook)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
666 ;; Ok, presume that the argument is a file name
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
667 (progn
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
668 (setq file-count (1+ file-count))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
669 (cond ((= file-count 1)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
670 (setq first-file-buffer
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
671 (find-file (expand-file-name argi dir))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
672 (t
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
673 (find-file-other-window (expand-file-name argi dir))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
674 (or (zerop line)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
675 (goto-line line))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
676 (setq line 0))))))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
677 ;; If 3 or more files visited, and not all visible,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
678 ;; show user what they all are.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
679 (if (> file-count 2)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
680 (or (get-buffer-window first-file-buffer)
3281
49c371d2b020 (command-line-1): Pass arg to other-window.
Richard M. Stallman <rms@gnu.org>
parents: 3072
diff changeset
681 (progn (other-window 1)
5024
7eff30849357 (command-line-1): Display a message in the echo area.
Richard M. Stallman <rms@gnu.org>
parents: 5023
diff changeset
682 (buffer-menu)))))))
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 650
diff changeset
683
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 650
diff changeset
684 ;;; startup.el ends here