Document reserved keys
[emacs.git] / lisp / loadup.el
blob5ecfae170fc1ab08dad0a910fd0357ff6cf8a4d9
1 ;;; loadup.el --- load up standardly loaded Lisp files for Emacs
3 ;; Copyright (C) 1985-1986, 1992, 1994, 2001-2018 Free Software
4 ;; Foundation, Inc.
6 ;; Maintainer: emacs-devel@gnu.org
7 ;; Keywords: internal
8 ;; Package: emacs
10 ;; This file is part of GNU Emacs.
12 ;; GNU Emacs is free software: you can redistribute it and/or modify
13 ;; it under the terms of the GNU General Public License as published by
14 ;; the Free Software Foundation, either version 3 of the License, or
15 ;; (at your option) any later version.
17 ;; GNU Emacs is distributed in the hope that it will be useful,
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 ;; GNU General Public License for more details.
22 ;; You should have received a copy of the GNU General Public License
23 ;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
25 ;;; Commentary:
27 ;; This is loaded into a bare Emacs to make a dumpable one.
29 ;; If you add a file to be loaded here, keep the following points in mind:
31 ;; i) If the file is no-byte-compile, explicitly load the .el version.
32 ;; Such files should (where possible) obey the doc-string conventions
33 ;; expected by make-docfile. They should also be added to the
34 ;; uncompiled[] list in make-docfile.c.
36 ;; ii) If the file is dumped with Emacs (on any platform), put the
37 ;; load statement at the start of a line (leading whitespace is ok).
39 ;; iii) If the file is _not_ dumped with Emacs, make sure the load
40 ;; statement is _not_ at the start of a line. See pcase for an example.
42 ;; These rules are so that src/Makefile can construct lisp.mk automatically.
43 ;; This ensures both that the Lisp files are compiled (if necessary)
44 ;; before the emacs executable is dumped, and that they are passed to
45 ;; make-docfile. (Any that are not processed for DOC will not have
46 ;; doc strings in the dumped Emacs.)
48 ;;; Code:
50 ;; This is used in xdisp.c to determine when bidi reordering is safe.
51 ;; (It starts non-nil in temacs, but we set it non-nil here anyway, in
52 ;; case someone loads loadup one more time.) We reset it after
53 ;; successfully loading charprop.el, which defines the Unicode tables
54 ;; bidi.c needs for its job.
55 (setq redisplay--inhibit-bidi t)
57 ;; Add subdirectories to the load-path for files that might get
58 ;; autoloaded when bootstrapping.
59 ;; This is because PATH_DUMPLOADSEARCH is just "../lisp".
60 (if (or (equal (member "bootstrap" command-line-args) '("bootstrap"))
61 ;; FIXME this is irritatingly fragile.
62 (and (stringp (nth 4 command-line-args))
63 (string-match "^unidata-gen\\(\\.elc?\\)?$"
64 (nth 4 command-line-args)))
65 (member (nth 7 command-line-args) '("unidata-gen-file"
66 "unidata-gen-charprop"))
67 (if (fboundp 'dump-emacs)
68 (string-match "src/bootstrap-emacs" (nth 0 command-line-args))
69 t))
70 (let ((dir (car load-path)))
71 ;; We'll probably overflow the pure space.
72 (setq purify-flag nil)
73 ;; Value of max-lisp-eval-depth when compiling initially.
74 ;; During bootstrapping the byte-compiler is run interpreted when
75 ;; compiling itself, which uses a lot more stack than usual.
76 (setq max-lisp-eval-depth 2200)
77 (setq load-path (list (expand-file-name "." dir)
78 (expand-file-name "emacs-lisp" dir)
79 (expand-file-name "progmodes" dir)
80 (expand-file-name "language" dir)
81 (expand-file-name "international" dir)
82 (expand-file-name "textmodes" dir)
83 (expand-file-name "vc" dir)))))
85 (if (eq t purify-flag)
86 ;; Hash consing saved around 11% of pure space in my tests.
87 (setq purify-flag (make-hash-table :test 'equal :size 80000)))
89 (message "Using load-path %s" load-path)
91 ;; This is a poor man's `last', since we haven't loaded subr.el yet.
92 (if (and (fboundp 'dump-emacs)
93 (or (equal (member "bootstrap" command-line-args) '("bootstrap"))
94 (equal (member "dump" command-line-args) '("dump"))))
95 (progn
96 ;; To reduce the size of dumped Emacs, we avoid making huge char-tables.
97 (setq inhibit-load-charset-map t)
98 ;; --eval gets handled too late.
99 (defvar load--prefer-newer load-prefer-newer)
100 (setq load-prefer-newer t)))
102 ;; We don't want to have any undo records in the dumped Emacs.
103 (set-buffer "*scratch*")
104 (setq buffer-undo-list t)
106 (load "emacs-lisp/byte-run")
107 (load "emacs-lisp/backquote")
108 (load "subr")
110 ;; Do it after subr, since both after-load-functions and add-hook are
111 ;; implemented in subr.el.
112 (add-hook 'after-load-functions (lambda (f) (garbage-collect)))
114 (load "version")
116 (load "widget")
117 (load "custom")
118 (load "emacs-lisp/map-ynp")
119 (load "international/mule")
120 (load "international/mule-conf")
121 (load "env")
122 (load "format")
123 (load "bindings")
124 (load "window") ; Needed here for `replace-buffer-in-windows'.
125 ;; We are now capable of resizing the mini-windows, so give the
126 ;; variable its advertised default value (it starts as nil, see
127 ;; xdisp.c).
128 (setq resize-mini-windows 'grow-only)
129 (setq load-source-file-function 'load-with-code-conversion)
130 (load "files")
132 ;; Load-time macro-expansion can only take effect after setting
133 ;; load-source-file-function because of where it is called in lread.c.
134 (load "emacs-lisp/macroexp")
135 (if (byte-code-function-p (symbol-function 'macroexpand-all))
137 ;; Since loaddefs is not yet loaded, macroexp's uses of pcase will simply
138 ;; fail until pcase is explicitly loaded. This also means that we have to
139 ;; disable eager macro-expansion while loading pcase.
140 (let ((macroexp--pending-eager-loads '(skip))) (load "emacs-lisp/pcase"))
141 ;; Re-load macroexp so as to eagerly macro-expand its uses of pcase.
142 (let ((max-lisp-eval-depth (* 2 max-lisp-eval-depth)))
143 (load "emacs-lisp/macroexp")))
145 (load "cus-face")
146 (load "faces") ; after here, `defface' may be used.
148 (load "button")
150 ;; We don't want to store loaddefs.el in the repository because it is
151 ;; a generated file; but it is required in order to compile the lisp files.
152 ;; When bootstrapping, we cannot generate loaddefs.el until an
153 ;; emacs binary has been built. We therefore compromise and keep
154 ;; ldefs-boot.el in the repository. This does not need to be updated
155 ;; as often as the real loaddefs.el would. Bootstrap should always
156 ;; work with ldefs-boot.el. Therefore, whenever a new autoload cookie
157 ;; gets added that is necessary during bootstrapping, ldefs-boot.el
158 ;; should be updated by overwriting it with an up-to-date copy of
159 ;; loaddefs.el that is not corrupted by local changes.
160 ;; admin/update_autogen can be used to update ldefs-boot.el periodically.
161 (condition-case nil (load "loaddefs.el")
162 ;; In case loaddefs hasn't been generated yet.
163 (file-error (load "ldefs-boot.el")))
165 (let ((new (make-hash-table :test 'equal)))
166 ;; Now that loaddefs has populated definition-prefixes, purify its contents.
167 (maphash (lambda (k v) (puthash (purecopy k) (purecopy v) new))
168 definition-prefixes)
169 (setq definition-prefixes new))
171 (load "emacs-lisp/nadvice")
172 (load "emacs-lisp/cl-preloaded")
173 (load "minibuffer") ;After loaddefs, for define-minor-mode.
174 (load "obarray") ;abbrev.el is implemented in terms of obarrays.
175 (load "abbrev") ;lisp-mode.el and simple.el use define-abbrev-table.
176 (load "simple")
178 (load "help")
180 (load "jka-cmpr-hook")
181 (load "epa-hook")
182 ;; Any Emacs Lisp source file (*.el) loaded here after can contain
183 ;; multilingual text.
184 (load "international/mule-cmds")
185 (load "case-table")
186 ;; This file doesn't exist when building a development version of Emacs
187 ;; from the repository. It is generated just after temacs is built.
188 (load "international/charprop.el" t)
189 (if (featurep 'charprop)
190 (setq redisplay--inhibit-bidi nil))
191 (load "international/characters")
192 (load "composite")
194 ;; Load language-specific files.
195 (load "language/chinese")
196 (load "language/cyrillic")
197 (load "language/indian")
198 (load "language/sinhala")
199 (load "language/english")
200 (load "language/ethiopic")
201 (load "language/european")
202 (load "language/czech")
203 (load "language/slovak")
204 (load "language/romanian")
205 (load "language/greek")
206 (load "language/hebrew")
207 (load "international/cp51932")
208 (load "international/eucjp-ms")
209 (load "language/japanese")
210 (load "language/korean")
211 (load "language/lao")
212 (load "language/tai-viet")
213 (load "language/thai")
214 (load "language/tibetan")
215 (load "language/vietnamese")
216 (load "language/misc-lang")
217 (load "language/utf-8-lang")
218 (load "language/georgian")
219 (load "language/khmer")
220 (load "language/burmese")
221 (load "language/cham")
223 (load "indent")
224 (load "emacs-lisp/cl-generic")
225 (load "frame")
226 (load "startup")
227 (load "term/tty-colors")
228 (load "font-core")
229 ;; facemenu must be loaded before font-lock, because `facemenu-keymap'
230 ;; needs to be defined when font-lock is loaded.
231 (load "facemenu")
232 (load "emacs-lisp/syntax")
233 (load "font-lock")
234 (load "jit-lock")
236 (load "mouse")
237 (if (boundp 'x-toolkit-scroll-bars)
238 (load "scroll-bar"))
239 (load "select")
240 (load "emacs-lisp/timer")
241 (load "isearch")
242 (load "rfn-eshadow")
244 (load "menu-bar")
245 (load "emacs-lisp/lisp")
246 (load "textmodes/page")
247 (load "register")
248 (load "textmodes/paragraphs")
249 (load "progmodes/prog-mode")
250 (load "emacs-lisp/lisp-mode")
251 (load "progmodes/elisp-mode")
252 (load "textmodes/text-mode")
253 (load "textmodes/fill")
254 (load "newcomment")
256 (load "replace")
257 (load "emacs-lisp/tabulated-list")
258 (load "buff-menu")
260 (if (fboundp 'x-create-frame)
261 (progn
262 (load "fringe")
263 ;; Needed by `imagemagick-register-types'
264 (load "emacs-lisp/regexp-opt")
265 (load "image")
266 (load "international/fontset")
267 (load "dnd")
268 (load "tool-bar")))
270 (if (featurep 'dynamic-setting)
271 (load "dynamic-setting"))
273 (if (featurep 'x)
274 (progn
275 (load "x-dnd")
276 (load "term/common-win")
277 (load "term/x-win")))
279 (if (or (eq system-type 'windows-nt)
280 (featurep 'w32))
281 (progn
282 (load "term/common-win")
283 (load "w32-vars")
284 (load "term/w32-win")
285 (load "disp-table")
286 (when (eq system-type 'windows-nt)
287 (load "w32-fns")
288 (load "ls-lisp")
289 (load "dos-w32"))))
290 (if (eq system-type 'ms-dos)
291 (progn
292 (load "dos-w32")
293 (load "dos-fns")
294 (load "dos-vars")
295 ;; Don't load term/common-win: it isn't appropriate for the `pc'
296 ;; ``window system'', which generally behaves like a terminal.
297 (load "term/internal")
298 (load "term/pc-win")
299 (load "ls-lisp")
300 (load "disp-table"))) ; needed to setup ibm-pc char set, see internal.el
301 (if (featurep 'ns)
302 (progn
303 (load "term/common-win")
304 ;; Don't load ucs-normalize.el unless uni-*.el files were
305 ;; already produced, because it needs uni-*.el files that might
306 ;; not be built early enough during bootstrap.
307 (when (featurep 'charprop)
308 (load "international/mule-util")
309 (load "international/ucs-normalize")
310 (load "term/ns-win"))))
311 (if (fboundp 'x-create-frame)
312 ;; Do it after loading term/foo-win.el since the value of the
313 ;; mouse-wheel-*-event vars depends on those files being loaded or not.
314 (load "mwheel"))
315 ;; Preload some constants and floating point functions.
316 (load "emacs-lisp/float-sup")
318 (load "vc/vc-hooks")
319 (load "vc/ediff-hook")
320 (load "uniquify")
321 (load "electric")
322 (load "emacs-lisp/eldoc")
323 (load "cus-start") ;Late to reduce customize-rogue (needs loaddefs.el anyway)
324 (if (not (eq system-type 'ms-dos))
325 (load "tooltip"))
327 ;; This file doesn't exist when building a development version of Emacs
328 ;; from the repository. It is generated just after temacs is built.
329 (load "leim/leim-list.el" t)
331 ;; If you want additional libraries to be preloaded and their
332 ;; doc strings kept in the DOC file rather than in core,
333 ;; you may load them with a "site-load.el" file.
334 ;; But you must also cause them to be scanned when the DOC file
335 ;; is generated.
336 (let ((lp load-path))
337 (load "site-load" t)
338 ;; We reset load-path after dumping.
339 ;; For a permanent change in load-path, use configure's
340 ;; --enable-locallisppath option.
341 ;; See https://debbugs.gnu.org/16107 for more details.
342 (or (equal lp load-path)
343 (message "Warning: Change in load-path due to site-load will be \
344 lost after dumping")))
346 ;; Make sure default-directory is unibyte when dumping. This is
347 ;; because we cannot decode and encode it correctly (since the locale
348 ;; environment is not, and should not be, set up). default-directory
349 ;; is used every time we call expand-file-name, which we do in every
350 ;; file primitive. So the only workable solution to support building
351 ;; in non-ASCII directories is to manipulate unibyte strings in the
352 ;; current locale's encoding.
353 (if (and (member (car (last command-line-args)) '("dump" "bootstrap"))
354 (fboundp 'dump-emacs)
355 (multibyte-string-p default-directory))
356 (error "default-directory must be unibyte when dumping Emacs!"))
358 ;; Determine which build number to use
359 ;; based on the executables that now exist.
360 (if (and (equal (last command-line-args) '("dump"))
361 (fboundp 'dump-emacs)
362 (not (eq system-type 'ms-dos)))
363 (let* ((base (concat "emacs-" emacs-version "."))
364 (exelen (if (eq system-type 'windows-nt) -4))
365 (files (file-name-all-completions base default-directory))
366 (versions (mapcar (function
367 (lambda (name)
368 (string-to-number
369 (substring name (length base) exelen))))
370 files)))
371 (setq emacs-repository-version (condition-case nil (emacs-repository-get-version)
372 (error nil)))
373 ;; A constant, so we shouldn't change it with `setq'.
374 (defconst emacs-build-number
375 (if versions (1+ (apply 'max versions)) 1))))
378 (message "Finding pointers to doc strings...")
379 (if (and (fboundp 'dump-emacs)
380 (equal (last command-line-args) '("dump")))
381 (Snarf-documentation "DOC")
382 (condition-case nil
383 (Snarf-documentation "DOC")
384 (error nil)))
385 (message "Finding pointers to doc strings...done")
387 ;; Note: You can cause additional libraries to be preloaded
388 ;; by writing a site-init.el that loads them.
389 ;; See also "site-load" above
390 (let ((lp load-path))
391 (load "site-init" t)
392 (or (equal lp load-path)
393 (message "Warning: Change in load-path due to site-init will be \
394 lost after dumping")))
396 (setq current-load-list nil)
397 ;; Avoid storing references to build directory in the binary.
398 (setq custom-current-group-alist nil)
400 ;; We keep the load-history data in PURE space.
401 ;; Make sure that the spine of the list is not in pure space because it can
402 ;; be destructively mutated in lread.c:build_load_history.
403 (setq load-history (mapcar 'purecopy load-history))
405 (set-buffer-modified-p nil)
407 (remove-hook 'after-load-functions (lambda (f) (garbage-collect)))
409 (if (boundp 'load--prefer-newer)
410 (progn
411 (setq load-prefer-newer load--prefer-newer)
412 (put 'load-prefer-newer 'standard-value load--prefer-newer)
413 (makunbound 'load--prefer-newer)))
415 (setq inhibit-load-charset-map nil)
416 (clear-charset-maps)
417 (garbage-collect)
419 ;; At this point, we're ready to resume undo recording for scratch.
420 (buffer-enable-undo "*scratch*")
422 (when (hash-table-p purify-flag)
423 (let ((strings 0)
424 (vectors 0)
425 (bytecodes 0)
426 (conses 0)
427 (others 0))
428 (maphash (lambda (k v)
429 (cond
430 ((stringp k) (setq strings (1+ strings)))
431 ((vectorp k) (setq vectors (1+ vectors)))
432 ((consp k) (setq conses (1+ conses)))
433 ((byte-code-function-p v) (setq bytecodes (1+ bytecodes)))
434 (t (setq others (1+ others)))))
435 purify-flag)
436 (message "Pure-hashed: %d strings, %d vectors, %d conses, %d bytecodes, %d others"
437 strings vectors conses bytecodes others)))
439 ;; Avoid error if user loads some more libraries now and make sure the
440 ;; hash-consing hash table is GC'd.
441 (setq purify-flag nil)
443 (if (null (garbage-collect))
444 (setq pure-space-overflow t))
446 ;; Make sure we will attempt bidi reordering henceforth.
447 (setq redisplay--inhibit-bidi nil)
449 (if (and (fboundp 'dump-emacs)
450 (member (car (last command-line-args)) '("dump" "bootstrap")))
451 (progn
452 ;; Prevent build-time PATH getting stored in the binary.
453 ;; Mainly cosmetic, but helpful for Guix. (Bug#20330)
454 ;; Do this here, rather than earlier, so that the above code
455 ;; can invoke Git commands and the like.
456 (setq exec-path nil)
457 (message "Dumping under the name emacs")
458 (condition-case ()
459 (delete-file "emacs")
460 (file-error nil))
461 ;; We used to dump under the name xemacs, but that occasionally
462 ;; confused people installing Emacs (they'd install the file
463 ;; under the name `xemacs'), and it's inconsistent with every
464 ;; other GNU program's build process.
465 (dump-emacs "emacs" "temacs")
466 (message "%d pure bytes used" pure-bytes-used)
467 ;; Recompute NAME now, so that it isn't set when we dump.
468 (if (not (or (eq system-type 'ms-dos)
469 ;; Don't bother adding another name if we're just
470 ;; building bootstrap-emacs.
471 (equal (last command-line-args) '("bootstrap"))))
472 (let ((name (format "emacs-%s.%d" emacs-version emacs-build-number))
473 (exe (if (eq system-type 'windows-nt) ".exe" "")))
474 (while (string-match "[^-+_.a-zA-Z0-9]+" name)
475 (setq name (concat (downcase (substring name 0 (match-beginning 0)))
477 (substring name (match-end 0)))))
478 (setq name (concat name exe))
479 (message "Adding name %s" name)
480 ;; When this runs on Windows, invocation-directory is not
481 ;; necessarily the current directory.
482 (add-name-to-file (expand-file-name (concat "emacs" exe)
483 invocation-directory)
484 (expand-file-name name invocation-directory)
485 t)))
486 (kill-emacs)))
488 ;; For machines with CANNOT_DUMP defined in config.h,
489 ;; this file must be loaded each time Emacs is run.
490 ;; So run the startup code now. First, remove `-l loadup' from args.
492 (if (and (member (nth 1 command-line-args) '("-l" "--load"))
493 (equal (nth 2 command-line-args) "loadup"))
494 (setcdr command-line-args (nthcdr 3 command-line-args)))
496 (eval top-level)
499 ;; Local Variables:
500 ;; no-byte-compile: t
501 ;; no-update-autoloads: t
502 ;; End:
504 ;;; loadup.el ends here