X-Git-Url: https://code.delx.au/gnu-emacs/blobdiff_plain/01c86c564d3c6281347d160fe7aaf019d02618d3..dc0485c4f86e8754635ecd2003188d3894c23974:/lisp/loadup.el diff --git a/lisp/loadup.el b/lisp/loadup.el index 0c23fd47b8..15f47440ae 100644 --- a/lisp/loadup.el +++ b/lisp/loadup.el @@ -1,6 +1,6 @@ -;;; loadup.el --- load up standardly loaded Lisp files for Emacs. +;;; loadup.el --- load up standardly loaded Lisp files for Emacs -;; Copyright (C) 1985, 1986, 1992, 1994 Free Software Foundation, Inc. +;; Copyright (C) 1985, 1986, 1992, 1994, 2001 Free Software Foundation, Inc. ;; Maintainer: FSF ;; Keywords: internal @@ -31,18 +31,25 @@ ;; add subdirectories to the load-path for files that might ;; get autoloaded when bootstrapping (if (or (equal (nth 3 command-line-args) "bootstrap") - (equal (nth 4 command-line-args) "bootstrap")) - (let ((path (car load-path))) - (setq load-path (list path - (expand-file-name "emacs-lisp" path) - (expand-file-name "international" path))))) + (equal (nth 4 command-line-args) "bootstrap") + ;; in case CANNOT_DUMP + (equal (nth 0 command-line-args) "../src/bootstrap-emacs")) + (let ((dir (car load-path))) + ;; We'll probably overflow the pure space. + (setq purify-flag nil) + (setq load-path (list dir + (expand-file-name "emacs-lisp" dir) + (expand-file-name "language" dir) + (expand-file-name "international" dir) + (expand-file-name "textmodes" dir))))) (message "Using load-path %s" load-path) -;;; We don't want to have any undo records in the dumped Emacs. +;; We don't want to have any undo records in the dumped Emacs. (buffer-disable-undo "*scratch*") -(load "byte-run") +(load "emacs-lisp/byte-run") +(load "emacs-lisp/backquote") (load "subr") ;; We specify .el in case someone compiled version.el by mistake. @@ -50,8 +57,7 @@ (load "widget") (load "custom") -(autoload '\` "emacs-lisp/backquote" nil nil 'macro) -(load "map-ynp") +(load "emacs-lisp/map-ynp") (load "env") (load "cus-start") (load "international/mule") @@ -59,20 +65,27 @@ (load "format") (load "bindings") (setq load-source-file-function 'load-with-code-conversion) -(load "simple") -(load "help") (load "files") -;; Any Emacs Lisp source file (*.el) loaded here after can contain -;; multilingual text. -(load "international/mule-cmds") -(load "case-table") -(load "international/characters") + +(load "cus-face") +(load "faces") ; after here, `defface' may be used. (message "Lists of integers (garbage collection statistics) are normal output") (message "while building Emacs; they do not indicate a problem.") (message "%s" (garbage-collect)) (load "loaddefs.el") ;Don't get confused if someone compiled this by mistake. (message "%s" (garbage-collect)) +(load "simple") + +(load "help") + +;; Any Emacs Lisp source file (*.el) loaded here after can contain +;; multilingual text. +(load "international/mule-cmds") +(load "case-table") +(load "international/utf-8") +(load "international/utf-16") +(load "international/characters") (let ((set-case-syntax-set-multibyte t)) (load "international/latin-1") @@ -86,7 +99,10 @@ (load "language/chinese") (load "language/cyrillic") (load "language/indian") -(load "language/devanagari") ; This should be loaded after indian. +(load "language/devanagari") ; This should be loaded after indian. +(load "language/malayalam") ; This should be loaded after indian. +(load "language/tamil") ; This should be loaded after indian. +(load "language/kannada") ; This should be loaded after indian. (load "language/english") (load "language/ethiopic") (load "language/european") @@ -102,22 +118,29 @@ (load "language/tibetan") (load "language/vietnamese") (load "language/misc-lang") +(load "language/utf-8-lang") +(load "language/georgian") + +(load "international/ucs-tables") + (update-coding-systems-internal) (load "indent") (load "window") (load "frame") (load "term/tty-colors") -(load "faces") +(load "font-core") + (if (fboundp 'frame-face-alist) (progn (load "facemenu"))) (if (fboundp 'track-mouse) (progn (load "mouse") - (and (boundp 'x-toolkit-scroll-bars-p) + (and (boundp 'x-toolkit-scroll-bars) (load "scroll-bar")) (load "select"))) +(load "emacs-lisp/timer") (load "isearch") (message "%s" (garbage-collect)) @@ -147,6 +170,7 @@ (load "ls-lisp") (load "disp-table") ; needed to setup ibm-pc char set, see internal.el (load "dos-w32") + (load "w32-vars") (load "w32-fns"))) (if (eq system-type 'ms-dos) (progn @@ -154,12 +178,15 @@ (load "dos-w32") (load "dos-fns") (load "dos-vars") - (load "international/ccl") ; for cpNNN coding systems in codepage.el + (load "international/ccl") ; codepage.el uses CCL en/decoder (load "international/codepage") ; internal.el uses cpNNN coding systems (load "disp-table"))) ; needed to setup ibm-pc char set, see internal.el -(if (fboundp 'atan) ; preload some constants and +(if (eq system-type 'macos) + (progn + (load "ls-lisp"))) +(if (fboundp 'atan) ; preload some constants and (progn ; floating pt. functions if we have float support. - (load "float-sup"))) + (load "emacs-lisp/float-sup"))) (message "%s" (garbage-collect)) (load "vc-hooks") @@ -191,11 +218,10 @@ (versions (mapcar (function (lambda (name) (string-to-int (substring name (length base))))) files))) - (setq emacs-version (format "%s.%d" - emacs-version - (if versions - (1+ (apply 'max versions)) - 1))))) + ;; `emacs-version' is a constant, so we shouldn't change it with `setq'. + (defconst emacs-version + (format "%s.%d" + emacs-version (if versions (1+ (apply 'max versions)) 1))))) ;; Note: all compiled Lisp files loaded above this point ;; must be among the ones parsed by make-docfile @@ -231,33 +257,39 @@ ;; Write the value of load-history into fns-VERSION.el, ;; then clear out load-history. -(if (or (equal (nth 3 command-line-args) "dump") - (equal (nth 4 command-line-args) "dump")) - (let ((buffer-undo-list t)) - (princ "(setq load-history\n" (current-buffer)) - (princ " (nconc load-history\n" (current-buffer)) - (princ " '(" (current-buffer)) - (let ((tem load-history)) - (while tem - (prin1 (car tem) (current-buffer)) - (terpri (current-buffer)) - (if (cdr tem) - (princ " " (current-buffer))) - (setq tem (cdr tem)))) - (princ ")))\n" (current-buffer)) - (write-region (point-min) (point-max) - (expand-file-name - (cond - ((eq system-type 'ms-dos) - "../lib-src/fns.el") - ((eq system-type 'windows-nt) - (format "../../../lib-src/fns-%s.el" emacs-version)) - (t - (format "../lib-src/fns-%s.el" emacs-version))) - invocation-directory)) - (erase-buffer) - (setq load-history nil)) - (setq symbol-file-load-history-loaded t)) +;; (if (or (equal (nth 3 command-line-args) "dump") +;; (equal (nth 4 command-line-args) "dump")) +;; (let ((buffer-undo-list t)) +;; (princ "(setq load-history\n" (current-buffer)) +;; (princ " (nconc load-history\n" (current-buffer)) +;; (princ " '(" (current-buffer)) +;; (let ((tem load-history)) +;; (while tem +;; (prin1 (car tem) (current-buffer)) +;; (terpri (current-buffer)) +;; (if (cdr tem) +;; (princ " " (current-buffer))) +;; (setq tem (cdr tem)))) +;; (princ ")))\n" (current-buffer)) +;; (write-region (point-min) (point-max) +;; (expand-file-name +;; (cond +;; ((eq system-type 'ms-dos) +;; "../lib-src/fns.el") +;; ((eq system-type 'windows-nt) +;; (format "../../../lib-src/fns-%s.el" emacs-version)) +;; (t +;; (format "../lib-src/fns-%s.el" emacs-version))) +;; invocation-directory)) +;; (erase-buffer) +;; (setq load-history nil)) +;; (setq symbol-file-load-history-loaded t)) +;; We don't use this fns-*.el file. Instead we keep the data in PURE space. +;; Make sure that the spine of the list is not in pure space because it can +;; be destructively mutated in lread.c:build_load_history. +(setq load-history (mapcar 'purecopy load-history)) +(setq symbol-file-load-history-loaded t) + (set-buffer-modified-p nil) ;; reset the load-path. See lread.c:init_lread why. @@ -270,10 +302,13 @@ ;;; At this point, we're ready to resume undo recording for scratch. (buffer-enable-undo "*scratch*") +(if (null (garbage-collect)) + (setq pure-space-overflow t)) + (if (or (member (nth 3 command-line-args) '("dump" "bootstrap")) (member (nth 4 command-line-args) '("dump" "bootstrap"))) (if (eq system-type 'vax-vms) - (progn + (progn (message "Dumping data as file temacs.dump") (dump-emacs "temacs.dump" "temacs") (kill-emacs)) @@ -295,7 +330,7 @@ (dump-emacs "emacs" "temacs") (message "%d pure bytes used" pure-bytes-used) ;; Recompute NAME now, so that it isn't set when we dump. - (if (not (memq system-type '(ms-dos windows-nt))) + (if (not (memq system-type '(ms-dos windows-nt cygwin))) (let ((name (concat "emacs-" emacs-version))) (while (string-match "[^-+_.a-zA-Z0-9]+" name) (setq name (concat (downcase (substring name 0 (match-beginning 0))) @@ -317,4 +352,11 @@ (eval top-level) + +;;; Local Variables: +;;; no-byte-compile: t +;;; no-update-autoloads: t +;;; End: + +;;; arch-tag: 121e1dd4-36e1-45ac-860e-239f577a6335 ;;; loadup.el ends here