annotate lisp/startup.el @ 11631:f9170a6c2e6f

(normal-top-level): Set auto-save-list-file-name.
author Richard M. Stallman <rms@gnu.org>
date Sun, 30 Apr 1995 19:50:00 +0000
parents 927b52de7ed2
children e068b3b7b232
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
11625
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
26 ;; This is a list of options processed in this file.
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
27 ;; There are also -- forms, but they aren't listed here.
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
28 ;; There are also options for X windows, not listed here;
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
29 ;; see term/x-win.el.
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
30
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
31 ; These options are processed first, no matter where they appear.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
32 ; -batch execute noninteractively (messages go to stdout,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
33 ; variable noninteractive set to t)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
34 ; This option must be the first in the arglist.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
35 ; Processed by `main' in emacs.c -- never seen by lisp
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
36 ; -t file Specify to use file rather than stdin/stdout
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
37 ; as the terminal.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
38 ; This option must be the first in the arglist.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
39 ; Processed by `main' in emacs.c -- never seen by lisp
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
40 ; -nw Inhibit the use of any window-system-specific display
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
41 ; code; use the current virtual terminal.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
42 ; This option must be the first in the arglist.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
43 ; 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
44 ; -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
45 ; But this has no effect on site-start.el.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
46 ; -no-init-file same
11083
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
47 ; -u user load USER's init file instead of your own.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
48 ; -user user same
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
49 ; -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
50 ; -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
51 ; (This is the ONLY way to prevent loading that file.)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
52
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
53 ; These are processed in the order encountered.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
54 ; -f function execute function
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
55 ; -funcall function same
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
56 ; -l file load file
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
57 ; -load file same
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
58 ; -insert file insert file into buffer
11625
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
59 ; -L dir add dir to load-path
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
60 ; file visit file
11625
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
61
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
62 ; This is always processed last, no matter where it appears.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
63 ; -kill kill (exit) emacs
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
64
787
3cece0106722 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 779
diff changeset
65 ;;; Code:
3cece0106722 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 779
diff changeset
66
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
67 (setq top-level '(normal-top-level))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
68
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
69 (defvar command-line-processed nil "t once command line has been processed")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
70
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
71 (defconst inhibit-startup-message nil
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
72 "*Non-nil inhibits the initial startup message.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
73 This is for use in your personal init file, once you are familiar
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
74 with the contents of the startup message.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
75
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
76 (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
77 "*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
78 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
79 a line of this form:
6119
9e150a376c32 (inhibit-startup-echo-area-message): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 5932
diff changeset
80 (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
81 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
82 (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
83 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
84 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
85
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
86 (defconst inhibit-default-init nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
87 "*Non-nil inhibits loading the `default' library.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
88
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
89 (defconst command-switch-alist nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
90 "Alist of command-line switches.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
91 Elements look like (SWITCH-STRING . HANDLER-FUNCTION).
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
92 HANDLER-FUNCTION receives switch name as sole arg;
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
93 remaining command-line args are in the variable `command-line-args-left'.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
94
8335
e6afa5879de3 (command-line-args-left): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8147
diff changeset
95 (defvar command-line-args-left nil
e6afa5879de3 (command-line-args-left): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8147
diff changeset
96 "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
97
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
98 (defvar command-line-functions nil ;; lrs 7/31/89
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
99 "List of functions to process unrecognized command-line arguments.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
100 Each function should access the dynamically bound variables
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
101 `argi' (the current argument) and `command-line-args-left' (the remaining
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
102 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
103 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
104 altering `command-line-args-left' to remove them.")
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
105
7022
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
106 (defvar command-line-default-directory nil
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
107 "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
108 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
109
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
110 (defvar before-init-hook nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
111 "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
112 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
113 Emacs loads the user's initialization file.")
d56e16bd220a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 326
diff changeset
114
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
115 (defvar after-init-hook nil
1550
279b5a572def Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 903
diff changeset
116 "Functions to call after loading the init file (`~/.emacs').
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
117 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
118 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
119
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
120 (defvar term-setup-hook nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
121 "Functions to be called after loading terminal-specific Lisp code.
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
122 See `run-hooks'. This variable exists for users to set,
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
123 so as to override the definitions made by the terminal-specific file.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
124 Emacs never sets this variable itself.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
125
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
126 (defvar keyboard-type nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
127 "The brand of keyboard you are using.
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
128 This variable is used to define
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
129 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
130 fashion analogous to the environment value TERM.")
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 window-setup-hook nil
6593
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
133 "Normal hook run to initialize window system display.
f7729c7b0aa7 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 6119
diff changeset
134 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
135 the user's init file.")
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
136
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
137 (defconst initial-major-mode 'lisp-interaction-mode
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
138 "Major mode command symbol to use for the initial *scratch* buffer.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
139
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
140 (defvar init-file-user nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
141 "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
142 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
143 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
144 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
145
6980
ef1b2bd0b19e (init-file-user): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 6911
diff changeset
146 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
147 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
148 looked for.
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
149
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
150 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
151 `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
152
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
153 (defvar site-run-file "site-start"
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
154 "File containing site-wide run-time initializations.
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
155 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
156 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
157 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
158 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
159 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
160
2c55e8ceb8b4 (init-file-user, site-run-file): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 10444
diff changeset
161 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
162 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
163 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
164 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
165 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
166 is less convenient.")
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
167
8147
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
168 (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
169 "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
170 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
171 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
172
8989
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
173 (defvar mail-host-address nil
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
174 "*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
175
8048
5253d3981da6 (user-mail-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7880
diff changeset
176 (defvar user-mail-address nil
8989
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
177 "*Full mailing address of this user.")
8048
5253d3981da6 (user-mail-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7880
diff changeset
178
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
179 (defvar init-file-debug nil)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
180
5109
062da10a4a6b (command-line): Set init-file-had-error to t or nil.
Richard M. Stallman <rms@gnu.org>
parents: 5024
diff changeset
181 (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
182
9443
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
183 ;; 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
184 (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
185 (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
186 (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
187
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
188 (defun normal-top-level ()
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
189 (if command-line-processed
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
190 (message "Back to top level.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
191 (setq command-line-processed t)
11294
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
192 ;; 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
193 ;; just to keep things predictable.
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
194 (let ((dir default-directory))
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
195 (save-excursion
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
196 (set-buffer (get-buffer "*Messages*"))
f5079cb33831 (normal-top-level): Copy default-directory
Richard M. Stallman <rms@gnu.org>
parents: 11083
diff changeset
197 (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
198 ;; 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
199 ;; 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
200 ;; 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
201 (let ((tail load-path)
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
202 new)
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
203 (while tail
5eaca32b6af6 (normal-top-level-add-to-load-path): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9348
diff changeset
204 (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
205 (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
206 (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
207 (setq tail (cdr tail))))
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
208 (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
209 (progn
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
210 ;; 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
211 (let ((pwd (getenv "PWD")))
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
212 (and (stringp pwd)
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
213 ;; 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
214 ;; 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
215 (or (equal (file-attributes
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
216 (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
217 (file-attributes
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
218 (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
219 ".")))
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
220 (setq process-environment
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
221 (delete (concat "PWD=" pwd)
a7e915481db1 * startup.el (normal-top-level): Don't worry about setting
Jim Blandy <jimb@redhat.com>
parents: 1550
diff changeset
222 process-environment)))))))
707
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 688
diff changeset
223 (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
224 (setq user-mail-address (concat (user-login-name) "@"
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
225 (or mail-host-address
54b7aaded223 (mail-host-address): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8759
diff changeset
226 (system-name))))
11631
f9170a6c2e6f (normal-top-level): Set auto-save-list-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 11625
diff changeset
227 ;; Specify the file for recording all the auto save files of this session.
f9170a6c2e6f (normal-top-level): Set auto-save-list-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 11625
diff changeset
228 ;; This is used by multiple-recover.
f9170a6c2e6f (normal-top-level): Set auto-save-list-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 11625
diff changeset
229 (setq auto-save-list-file-name
f9170a6c2e6f (normal-top-level): Set auto-save-list-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 11625
diff changeset
230 (expand-file-name
f9170a6c2e6f (normal-top-level): Set auto-save-list-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 11625
diff changeset
231 (format "~/.saves-%d-%s"
f9170a6c2e6f (normal-top-level): Set auto-save-list-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 11625
diff changeset
232 (emacs-pid)
f9170a6c2e6f (normal-top-level): Set auto-save-list-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 11625
diff changeset
233 (or mail-host-address (system-name)))))
7371
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
234 (let ((menubar-bindings-done nil))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
235 (unwind-protect
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
236 (command-line)
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
237 ;; 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
238 (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
239 (run-hooks 'emacs-startup-hook)
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
240 (and term-setup-hook
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
241 (run-hooks 'term-setup-hook))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
242 ;; 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
243 ;; ...-frame-alist.
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
244 (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
245 (frame-notice-user-settings))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
246 ;; 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
247 (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
248 (font-menu-add-default))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
249 (and window-setup-hook
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
250 (run-hooks 'window-setup-hook))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
251 (or menubar-bindings-done
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
252 (precompute-menubar-bindings))))))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
253
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
254 ;; 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
255 (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
256 (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
257 (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
258 (while submap
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
259 (and (consp (car submap))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
260 (symbolp (car (car submap)))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
261 (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
262 (keymapp (cdr (cdr (car submap))))
099233e3a3be (precompute-menubar-bindings): New function, formerly in loadup.el.
Karl Heuer <kwzh@gnu.org>
parents: 7022
diff changeset
263 (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
264 (setq submap (cdr submap))))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
265
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
266 (defun command-line ()
7022
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
267 (setq command-line-default-directory default-directory)
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
268
823
746ebe6cc4c8 *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 814
diff changeset
269 ;; See if we should import version-control from the environment variable.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
270 (let ((vc (getenv "VERSION_CONTROL")))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
271 (cond ((eq vc nil)) ;don't do anything if not set
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
272 ((or (string= vc "t")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
273 (string= vc "numbered"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
274 (setq version-control t))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
275 ((or (string= vc "nil")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
276 (string= vc "existing"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
277 (setq version-control nil))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
278 ((or (string= vc "never")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
279 (string= vc "simple"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
280 (setq version-control 'never))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
281
8147
053a450a871a (command-line): Check LC_ALL and LANG as well as LC_CTYPE.
Richard M. Stallman <rms@gnu.org>
parents: 8137
diff changeset
282 (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
283 ;; 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
284 (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
285 (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
286 (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
287 (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
288 (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
289 (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
290 (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
291 (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
292 (progn
9348
c4ccb2502ebf (command-line): Load disp-table explicitly.
Richard M. Stallman <rms@gnu.org>
parents: 9174
diff changeset
293 (require 'disp-table)
8127
81dacf7883e7 (command-line): Automatically use iso-syntax and
Richard M. Stallman <rms@gnu.org>
parents: 8048
diff changeset
294 (standard-display-european t)
81dacf7883e7 (command-line): Automatically use iso-syntax and
Richard M. Stallman <rms@gnu.org>
parents: 8048
diff changeset
295 (require 'iso-syntax)))
81dacf7883e7 (command-line): Automatically use iso-syntax and
Richard M. Stallman <rms@gnu.org>
parents: 8048
diff changeset
296
755
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
297 ;;! This has been commented out; I currently find the behavior when
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
298 ;;! 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
299 ;;! to it, then it would be better to eliminate the option.
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
300 ;;! ;; Choose a good default value for split-window-keep-point.
e43123226372 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 748
diff changeset
301 ;;! (setq split-window-keep-point (> baud-rate 2400))
384
9dab5ca1890f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 370
diff changeset
302
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
303 ;; 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
304 (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
305 (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
306 (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
307 (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
308 "-win")
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
309 ;; 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
310 ;; 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
311 nil t))
fca85f8be890 (command-line): If we can't load x-win.el, terminate.
Richard M. Stallman <rms@gnu.org>
parents: 8335
diff changeset
312 ;; 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
313 (error
8749
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
314 (princ
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
315 (if (eq (car error) 'error)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
316 (apply 'concat (cdr error))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
317 (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
318 (format "%s: %s"
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
319 (nth 1 error)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
320 (mapconcat '(lambda (obj) (prin1-to-string obj t))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
321 (cdr (cdr error)) ", "))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
322 (format "%s: %s"
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
323 (get (car error) 'error-message)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
324 (mapconcat '(lambda (obj) (prin1-to-string obj t))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
325 (cdr error) ", "))))
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
326 'external-debugging-output)
db4473742de7 (commmand-line): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 8748
diff changeset
327 (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
328 (kill-emacs)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
329
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
330 (let ((done nil)
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
331 (args (cdr command-line-args)))
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
332
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
333 ;; Figure out which user's init file to load,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
334 ;; either from the environment or from the options.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
335 (setq init-file-user (if noninteractive nil (user-login-name)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
336 ;; If user has not done su, use current $HOME to find .emacs.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
337 (and init-file-user (string= init-file-user (user-real-login-name))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
338 (setq init-file-user ""))
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
339
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
340 ;; Process the command-line args, and delete the arguments
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
341 ;; processed. This is consistent with the way main in emacs.c
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
342 ;; does things.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
343 (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
344 (let ((longopts '(("--no-init-file") ("--no-site-file") ("--user")
11620
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
345 ("--debug-init") ("--iconic") ("--icon-type")))
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
346 (argi (car args))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
347 (argval nil))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
348 (if (string-match "=" argi)
9174
900fdf19446a (command-line): Fix bug in previous change.
Karl Heuer <kwzh@gnu.org>
parents: 9173
diff changeset
349 (setq argval (substring argi (match-end 0))
900fdf19446a (command-line): Fix bug in previous change.
Karl Heuer <kwzh@gnu.org>
parents: 9173
diff changeset
350 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
351 (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
352 (if (eq completion t)
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
353 (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
354 (if (stringp completion)
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
355 (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
356 (or elt
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
357 (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
358 (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
359 (setq argval nil))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
360 (cond
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
361 ((or (string-equal argi "-q")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
362 (string-equal argi "-no-init-file"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
363 (setq init-file-user nil
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
364 args (cdr args)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
365 ((or (string-equal argi "-u")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
366 (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
367 (or argval
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
368 (setq argval (car args)
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
369 args (cdr args)))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
370 (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
371 argval nil
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
372 args (cdr args)))
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
373 ((string-equal argi "-no-site-file")
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
374 (setq site-run-file nil
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
375 args (cdr args)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
376 ((string-equal argi "-debug-init")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
377 (setq init-file-debug t
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
378 args (cdr args)))
11620
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
379 ((string-equal argi "-iconic")
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
380 (setq initial-frame-alist
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
381 (cons '(visibility . icon) initial-frame-alist))
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
382 (setq args (cdr args)))
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
383 ((or (string-equal argi "-icon-type")
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
384 (string-equal argi "-i")
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
385 (string-equal argi "-itype"))
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
386 (setq default-frame-alist
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
387 (cons '(icon-type . t) default-frame-alist))
5e836a7d213d (command-line): Handle -iconic and -icon-type here.
Richard M. Stallman <rms@gnu.org>
parents: 11294
diff changeset
388 (setq args (cdr args)))
9173
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
389 (t (setq done t)))
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
390 ;; 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
391 (and argval
6ee3eeec722b (command-line): Recognize --longopt synonyms for all options handled here.
Karl Heuer <kwzh@gnu.org>
parents: 8989
diff changeset
392 (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
393
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
394 ;; 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
395 (setcdr command-line-args args))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
396
2761
26bad513fbb0 (command-line): Call frame-initialize explicitly.
Richard M. Stallman <rms@gnu.org>
parents: 2105
diff changeset
397 ;; 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
398 (if (fboundp 'face-initialize)
12dcd89cfd88 (command-line): Call face-initialize before frame-initialize.
Richard M. Stallman <rms@gnu.org>
parents: 6593
diff changeset
399 (face-initialize))
2869
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
400 (if (fboundp 'frame-initialize)
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
401 (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
402 ;; 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
403 (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
404 (> (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
405 (menu-bar-mode t))
2761
26bad513fbb0 (command-line): Call frame-initialize explicitly.
Richard M. Stallman <rms@gnu.org>
parents: 2105
diff changeset
406
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
407 (run-hooks 'before-init-hook)
370
d56e16bd220a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 326
diff changeset
408
883
5a7ed0421c9d *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 876
diff changeset
409 ;; 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
410 ;; 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
411 ;; .emacs; that is useless.
4599
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
412 (if site-run-file
e1d54ee1deea (site-run-file): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4293
diff changeset
413 (load site-run-file t t))
883
5a7ed0421c9d *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 876
diff changeset
414
4672
8996606e0a12 (command-line): Setq inhibit-startup-message to nil.
Richard M. Stallman <rms@gnu.org>
parents: 4599
diff changeset
415 ;; 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
416 ;; the startup message.
8996606e0a12 (command-line): Setq inhibit-startup-message to nil.
Richard M. Stallman <rms@gnu.org>
parents: 4599
diff changeset
417 (setq inhibit-startup-message nil)
8996606e0a12 (command-line): Setq inhibit-startup-message to nil.
Richard M. Stallman <rms@gnu.org>
parents: 4599
diff changeset
418
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
419 ;; 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
420 (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
421 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
422 (debug-on-error-initial
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
423 (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
424 (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
425 ;; 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
426 (inner
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
427 (function
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
428 (lambda ()
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
429 (if init-file-user
5450
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
430 (progn
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
431 (setq user-init-file
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
432 (cond
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
433 ((eq system-type 'ms-dos)
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
434 (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
435 ((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
436 "~/_emacs")
5450
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
437 ((eq system-type 'vax-vms)
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
438 "sys$login:.emacs")
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
439 (t
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
440 (concat "~" init-file-user "/.emacs"))))
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
441 (load user-init-file t t t)
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
442 (or inhibit-default-init
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
443 (let ((inhibit-startup-message nil))
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
444 ;; 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
445 ;; (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
446 ;; 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
447 ;; except yourself.
9c57cdb2091e (command-line): Set user-init-file.
Richard M. Stallman <rms@gnu.org>
parents: 5379
diff changeset
448 (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
449 (if init-file-debug
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
450 ;; 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
451 (funcall inner)
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
452 (condition-case error
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
453 (progn
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
454 (funcall inner)
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
455 (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
456 (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
457 (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
458 (if (cdr error) ": " "")
5379
1d1d65ab7835 (command-line): In most cases, if init file sets
Richard M. Stallman <rms@gnu.org>
parents: 5109
diff changeset
459 (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
460 (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
461 ;; 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
462 ;; 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
463 (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
464 (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
465 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
466 (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
467 (setq debug-on-error debug-on-error-from-init-file)))
370
d56e16bd220a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 326
diff changeset
468
688
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
469 (run-hooks 'after-init-hook)
23cbc2c463eb *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 658
diff changeset
470
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
471 ;; If *scratch* exists and init file didn't change its mode, initialize it.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
472 (if (get-buffer "*scratch*")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
473 (save-excursion
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
474 (set-buffer "*scratch*")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
475 (if (eq major-mode 'fundamental-mode)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
476 (funcall initial-major-mode))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
477 ;; Load library for our terminal type.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
478 ;; User init file can set term-file-prefix to nil to prevent this.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
479 (and term-file-prefix (not noninteractive) (not window-system)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
480 (let ((term (getenv "TERM"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
481 hyphend)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
482 (while (and term
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
483 (not (load (concat term-file-prefix term) t t)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
484 ;; Strip off last hyphen and what follows, then try again
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
485 (if (setq hyphend (string-match "[-_][^-_]+$" term))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
486 (setq term (substring term 0 hyphend))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
487 (setq term nil)))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
488
326
ecc1a00366a3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 322
diff changeset
489 ;; Process the remaining args.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
490 (command-line-1 (cdr command-line-args))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
491
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
492 ;; If -batch, terminate after processing the command options.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
493 (if noninteractive (kill-emacs t)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
494
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
495 (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
496 (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
497 (and inhibit-startup-echo-area-message
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
498 (let ((buffer (get-buffer-create " *temp*")))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
499 (prog1
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
500 (condition-case nil
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
501 (save-excursion
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
502 (set-buffer buffer)
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
503 (insert-file-contents user-init-file)
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
504 (re-search-forward
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
505 (concat
5932
86efd91bb72c (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5931
diff changeset
506 "([ \t\n]*setq[ \t\n]+"
86efd91bb72c (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5931
diff changeset
507 "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
508 (regexp-quote
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
509 (prin1-to-string
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
510 (if (string= init-file-user "")
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
511 (user-login-name)
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
512 init-file-user)))
7008ece592cb (command-line-1): Improve previous change.
Richard M. Stallman <rms@gnu.org>
parents: 5930
diff changeset
513 "[ \t\n]*)")
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
514 nil t))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
515 (error nil))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
516 (kill-buffer buffer))))
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
517 (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
518 "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
519 (substitute-command-keys
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
520 "For information about the GNU Project and its goals, type \\[describe-project]."))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
521 (if (null command-line-args-left)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
522 (cond ((and (not inhibit-startup-message) (not noninteractive)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
523 ;; Don't clobber a non-scratch buffer if init file
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
524 ;; has selected it.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
525 (string= (buffer-name) "*scratch*")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
526 (not (input-pending-p)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
527 ;; If there are no switches to process, we might as well
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
528 ;; run this hook now, and there may be some need to do it
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
529 ;; before doing any output.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
530 (and term-setup-hook
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
531 (run-hooks 'term-setup-hook))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
532 ;; Don't let the hook be run twice.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
533 (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
534
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
535 ;; 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
536 ;; 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
537 ;; 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
538 ;; 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
539 (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
540 (frame-notice-user-settings))
d370b253473b * startup.el (normal-top-level, command-line, command-line-1):
Jim Blandy <jimb@redhat.com>
parents: 2761
diff changeset
541
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
542 (and window-setup-hook
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
543 (run-hooks 'window-setup-hook))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
544 (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
545 ;; 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
546 ;; 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
547 (precompute-menubar-bindings)
c06b9bcb12e7 (command-line-1): Precompute menu bar before startup msg.
Richard M. Stallman <rms@gnu.org>
parents: 7509
diff changeset
548 (setq menubar-bindings-done t)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
549 (unwind-protect
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
550 (progn
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
551 (insert (emacs-version)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
552 "
5930
3cfd09c8ba8e (inhibit-startup-echo-area-message): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5481
diff changeset
553 Copyright (C) 1994 Free Software Foundation, Inc.\n\n")
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
554 ;; If keys have their default meanings,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
555 ;; use precomputed string to save lots of time.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
556 (if (and (eq (key-binding "\C-h") 'help-command)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
557 (eq (key-binding "\C-xu") 'advertised-undo)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
558 (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
559 (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
560 (eq (key-binding "\C-hi") 'info))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
561 (insert
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
562 "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
563 To kill the Emacs job, type C-x C-c.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
564 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
565 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
566 (insert (substitute-command-keys
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
567 (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
568 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
569 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
570 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
571 (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
572 'help-command nil t)))
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
573 (if where
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
574 (key-description where)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
575 "M-x help"))))))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
576
10272
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
577 ;; 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
578 ;; window systems, but do have mouse support.
10285
abacb10bd5e6 Fix typo in previous change.
Richard M. Stallman <rms@gnu.org>
parents: 10272
diff changeset
579 (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
580 window-system)
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
581 (insert "
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
582 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
583 (insert "\n")
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
584 (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
585 (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
586 (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
587 (insert
f4c81ad44719 (command-line-1): Split startup msg into two parts.
Richard M. Stallman <rms@gnu.org>
parents: 10028
diff changeset
588 "
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
589 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
590 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
591 Type C-h C-d for information on getting the latest version.")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
592 (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
593 "
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
594 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
595 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
596 Type \\[describe-distribution] for information on getting the latest version.")))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
597 (set-buffer-modified-p nil)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
598 (sit-for 120))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
599 (save-excursion
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
600 ;; In case the Emacs server has already selected
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
601 ;; another buffer, erase the one our message is in.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
602 (set-buffer (get-buffer "*scratch*"))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
603 (erase-buffer)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
604 (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
605 ;; 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
606 ;; 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
607 (if init-file-had-error
82efaa5a2567 (command-line-1): Pause between init file error
Richard M. Stallman <rms@gnu.org>
parents: 10285
diff changeset
608 (sit-for 2))
7022
5635564a3064 (command-line-default-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 6980
diff changeset
609 (let ((dir command-line-default-directory)
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
610 (file-count 0)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
611 first-file-buffer
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
612 (line 0))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
613 (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
614 (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
615 (orig-argi argi)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
616 ;; 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
617 ;; 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
618 (longopts
11625
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
619 (append '(("--funcall") ("--load") ("--insert") ("--kill")
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
620 ("--directory"))
10028
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
621 (mapcar '(lambda (elt)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
622 (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
623 command-switch-alist)))
11625
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
624 tem argval completion
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
625 ;; List of directories specified in -L/--directory,
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
626 ;; in reverse of the order specified.
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
627 extra-load-path
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
628 (initial-load-path load-path))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
629 (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
630
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
631 ;; 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
632 ;; 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
633 (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
634 (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
635 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
636 (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
637 (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
638 (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
639 (if (stringp completion)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
640 (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
641 (or elt
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
642 (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
643 (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
644 (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
645
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
646 ;; Execute the option.
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
647 (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
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 (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
650 (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
651 (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
652 (funcall (cdr tem) argi)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
653 ((or (string-equal argi "-f") ;what the manual claims
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
654 (string-equal argi "-funcall")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
655 (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
656 (if argval
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
657 (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
658 (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
659 (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
660 (if (arrayp (symbol-function tem))
c6bc0c89d0ce (command-line-1): Handle -f with kbd macro.
Richard M. Stallman <rms@gnu.org>
parents: 10324
diff changeset
661 (command-execute tem)
c6bc0c89d0ce (command-line-1): Handle -f with kbd macro.
Richard M. Stallman <rms@gnu.org>
parents: 10324
diff changeset
662 (funcall tem)))
11625
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
663 ;; Set the default directory as specified in -L.
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
664 ((or (string-equal argi "-L")
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
665 (string-equal argi "-directory"))
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
666 (if argval
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
667 (setq tem argval)
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
668 (setq tem (car command-line-args-left)
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
669 command-line-args-left (cdr command-line-args-left)))
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
670 (setq extra-load-path
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
671 (cons (expand-file-name tem) extra-load-path))
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
672 (setq load-path (append (nreverse extra-load-path)
927b52de7ed2 (command-line-1): Implement -L/--directory option.
Richard M. Stallman <rms@gnu.org>
parents: 11620
diff changeset
673 initial-load-path)))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
674 ((or (string-equal argi "-l")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
675 (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
676 (if argval
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
677 (setq tem argval)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
678 (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
679 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
680 (let ((file tem))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
681 ;; Take file from default dir if it exists there;
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
682 ;; otherwise let `load' search for it.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
683 (if (file-exists-p (expand-file-name file))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
684 (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
685 (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
686 ((string-equal argi "-insert")
748
4714ad36583c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 707
diff changeset
687 (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
688 (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
689 (if argval
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
690 (setq tem argval)
55f7d03ce918 (command-line-1): Handle long options --funcall, --load, --insert, --kill.
Richard M. Stallman <rms@gnu.org>
parents: 9778
diff changeset
691 (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
692 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
693 (insert-file-contents tem))
322
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
694 ((string-equal argi "-kill")
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
695 (kill-emacs t))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
696 ((string-match "^\\+[0-9]+\\'" argi)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
697 (setq line (string-to-int argi)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
698 (t
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
699 ;; We have almost exhausted our options. See if the
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
700 ;; user has made any other command-line options available
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
701 (let ((hooks command-line-functions);; lrs 7/31/89
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
702 (did-hook nil))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
703 (while (and hooks
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
704 (not (setq did-hook (funcall (car hooks)))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
705 (setq hooks (cdr hooks)))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
706 (if (not did-hook)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
707 ;; Ok, presume that the argument is a file name
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
708 (progn
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
709 (setq file-count (1+ file-count))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
710 (cond ((= file-count 1)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
711 (setq first-file-buffer
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
712 (find-file (expand-file-name argi dir))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
713 (t
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
714 (find-file-other-window (expand-file-name argi dir))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
715 (or (zerop line)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
716 (goto-line line))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
717 (setq line 0))))))))
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
718 ;; If 3 or more files visited, and not all visible,
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
719 ;; show user what they all are.
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
720 (if (> file-count 2)
820dc6c9612a Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
721 (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
722 (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
723 (buffer-menu)))))))
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 650
diff changeset
724
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 650
diff changeset
725 ;;; startup.el ends here