(makefile-font-lock-keywords): Catch variable
[bpt/emacs.git] / lisp / loadup.el
index 52472eb..f4da8db 100644 (file)
@@ -1,6 +1,6 @@
 ;;; loadup.el --- load up standardly loaded Lisp files for Emacs.
 
-;; Copyright (C) 1985, 1986, 1992 Free Software Foundation, Inc.
+;; Copyright (C) 1985, 1986, 1992, 1994 Free Software Foundation, Inc.
 
 ;; Maintainer: FSF
 ;; Keywords: internal
@@ -18,8 +18,9 @@
 ;; GNU General Public License for more details.
 
 ;; You should have received a copy of the GNU General Public License
-;; along with GNU Emacs; see the file COPYING.  If not, write to
-;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
+;; along with GNU Emacs; see the file COPYING.  If not, write to the
+;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+;; Boston, MA 02111-1307, USA.
 
 ;;; Commentary:
 
 ;;; Code:
 
 (message "Using load-path %s" load-path)
-(sleep-for 1)
 
 ;;; We don't want to have any undo records in the dumped Emacs.
 (buffer-disable-undo "*scratch*")
 
 (load "subr")
+
+;; We specify .el in case someone compiled version.el by mistake.
+(load "version.el")
+
 (garbage-collect)
 (load "byte-run")
 (garbage-collect)
 (garbage-collect)
 (load "files")
 (garbage-collect)
+(load "format")
+(garbage-collect)
 (load "indent")
 (garbage-collect)
-(load "window")
+(load "isearch")
 (garbage-collect)
+(load "window")
 (if (fboundp 'delete-frame)
     (progn
-      (load "frame")
+      (garbage-collect)
+      (load "frame")))
+(if (fboundp 'frame-face-alist)
+    (progn
+      (garbage-collect)
+      (load "faces")
+      (load "facemenu")))
+(if (fboundp 'track-mouse)
+    (progn
+      (garbage-collect)
       (load "mouse")
       (garbage-collect)
       (load "scroll-bar")
       (load "select")))
+(load "menu-bar")
 (garbage-collect)
 (load "paths.el")  ;Don't get confused if someone compiled paths by mistake.
 (garbage-collect)
 (garbage-collect)
 (load "fill")
 (garbage-collect)
-(load "c-mode")
-(garbage-collect)
-(load "isearch")
-(garbage-collect)
 (load "replace")
 (if (eq system-type 'vax-vms)
     (progn
     (progn
       (garbage-collect)
       (load "vms-patch")))
-(if (eq system-type 'ms-dos)
+(if (eq system-type 'windows-nt)
     (progn
+      (garbage-collect)
       (load "ls-lisp")
       (garbage-collect)
-      (load "mouse")
+      (load "disp-table") ; needed to setup ibm-pc char set, see internal.el
+      (garbage-collect)
+      (load "winnt")
+      (garbage-collect)))
+(if (eq system-type 'ms-dos)
+    (progn
+      (load "ls-lisp")
       (garbage-collect)
       (load "dos-fns")
       (garbage-collect)
     (progn             ; floating pt. functions if 
       (garbage-collect)        ; we have float support.
       (load "float-sup")))
+
 (garbage-collect)
 (load "vc-hooks")
+(load "ediff-hook")
 
 ;If you want additional libraries to be preloaded and their
 ;doc strings kept in the DOC file rather than in core,
 ;you may load them with a "site-load.el" file.
 ;But you must also cause them to be scanned when the DOC file
 ;is generated.  For VMS, you must edit ../vms/makedoc.com.
-;For other systems, you must edit ../src/ymakefile.
+;For other systems, you must edit ../src/Makefile.in.
 (if (load "site-load" t)
     (garbage-collect))
 
-(load "version.el")  ;Don't get confused if someone compiled version.el by mistake.
+(if (fboundp 'x-popup-menu)
+    (precompute-menubar-bindings))
+;; Turn on recording of which commands get rebound,
+;; for the sake of the next call to precompute-menubar-bindings.
+(setq define-key-rebound-commands nil)
 
 ;; Determine which last version number to use
 ;; based on the executables that now exist.
-(if (and (fboundp 'dump-emacs) (not (eq system-type 'ms-dos)))
-    (let* ((base (concat "emacs-" emacs-version))
+(if (and (or (equal (nth 3 command-line-args) "dump")
+            (equal (nth 4 command-line-args) "dump"))
+        (not (eq system-type 'ms-dos)))
+    (let* ((base (concat "emacs-" emacs-version "."))
           (files (file-name-all-completions base default-directory))
           (versions (mapcar (function (lambda (name)
-                                        (string-to-int (substring name (1+ (length base))))))
+                                        (string-to-int (substring name (length base)))))
                             files)))
       (setq emacs-version (format "%s.%d"
                                  emacs-version
-                                 (1+ (apply 'max versions))))))
+                                 (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
 ;; for DOC will not have doc strings in the dumped Emacs.
 
 (message "Finding pointers to doc strings...")
-(if (fboundp 'dump-emacs)
+(if (or (equal (nth 3 command-line-args) "dump")
+       (equal (nth 4 command-line-args) "dump"))
     (let ((name emacs-version))
       (while (string-match "[^-+_.a-zA-Z0-9]+" name)
        (setq name (concat (downcase (substring name 0 (match-beginning 0)))
                           "-"
                           (substring name (match-end 0)))))
-      (if (eq system-type 'ms-dos)
-         (setq name (expand-file-name "../etc/DOC"))
+      (if (memq system-type '(ms-dos windows-nt))
+         (setq name (expand-file-name
+                     (if (fboundp 'x-create-frame) "DOC-X" "DOC") "../etc"))
        (setq name (concat (expand-file-name "../etc/DOC-") name))
        (if (file-exists-p name)
            (delete-file name))
 ;by writing a site-init.el that loads them.
 ;See also "site-load" above.
 (load "site-init" t)
+(setq current-load-list nil)
 (garbage-collect)
 
 ;;; At this point, we're ready to resume undo recording for scratch.
       ;; under the name `xemacs'), and it's inconsistent with every
       ;; other GNU product's build process.
       (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 (eq system-type 'ms-dos))
+      (if (not (memq system-type '(ms-dos windows-nt)))
          (let ((name (concat "emacs-" emacs-version)))
            (while (string-match "[^-+_.a-zA-Z0-9]+" name)
              (setq name (concat (downcase (substring name 0 (match-beginning 0)))
 ;; this file must be loaded each time Emacs is run.
 ;; So run the startup code now.
 
-(or (fboundp 'dump-emacs)
-    (eval top-level))
+(or (equal (nth 3 command-line-args) "dump")
+    (equal (nth 4 command-line-args) "dump")
+    (progn
+      ;; Avoid loading loadup.el a second time!
+      (setq command-line-args (cdr (cdr command-line-args)))
+      (eval top-level)))
 
 ;;; loadup.el ends here