xemacs-packages / package-compile.el

;;; package-compile.el --- Bytecompiler wrapper for building packages from source

;; Copyright (C) 1998 by Free Software Foundation, Inc.
;; Copyright (C) 2002 Ben Wing.

;; Author: SL Baur <steve@xemacs.org>
;; Keywords: internal, lisp

;; This file is part of XEmacs.

;; XEmacs is free software; you can redistribute it and/or modify it
;; under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.

;; XEmacs is distributed in the hope that it will be useful, but
;; WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
;; General Public License for more details.

;; You should have received a copy of the GNU General Public License
;; along with XEmacs; see the file COPYING.  If not, write to the Free
;; Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
;; 02111-1301, USA.

;;; Synched up with: Not in FSF

;;; Commentary:

;; This is meant to be called -batch and handles setting up the loadpath
;; and minimizing what autoloads are imported.

;; This package cannot be used with an XEmacs binary that was built with
;; backwards compatible lisp directories.

;;; Code:

(setq stack-trace-on-error t)
;; #### We ought to set load-ignore-elc-files here.  However, that causes
;; a crash when loading auto-autoload files, for obscure reasons that I
;; haven't yet tracked down.  So we set it down below, after all the
;; auto-autoloads have been loaded.
;;
;; Using load-ignore-elc-files is the ONLY way to ensure that compilation
;; of the package tree proceeds properly regardless of the state of .elc
;; files wrt .el files. (Of course, another solution would be to simply
;; erase all .elc files; but this is less drastic.) Using
;; load-ignore-out-of-date-elc-files is a start, but not enough -- it's
;; possible, for example, for a .elc file that gets loaded to be out of
;; date even if its date is later than its .el file.  This happens, for
;; example, with a file containing top-level calls to macros located in
;; another file -- if the macros are changed in the other file, the .elc
;; file will be out of date because it will contain the old macros.
;; Loading the .el file (ala `load-ignore-elc-files') works, since the new
;; macros will be retrieved on-the-fly when the macro is first called.
(setq load-ignore-out-of-date-elc-files t)
(setq load-always-display-messages t)
;; Don't enable this by default, as it clutters up the output so much.
;; Turn it on if you're doubtful that the right files are being loaded.
;; (setq load-show-full-path-in-messages t)

(when (interactive-p)
  (error "package-compile may only be used with -batch"))

;;; Step 1, set the load-path and load the core autoloads.

(let ((depth (cond
	      ;; #### All hail Mr. Preprocessor!
	      ;; OK, OK, his code is under development; FIXME when it's done.
	      ((boundp 'paths-load-path-depth) ; XEmacs 21.1
	       paths-load-path-depth)
	      ((boundp 'paths-core-load-path-depth) ; XEmacs > 21.2.41
	       paths-core-load-path-depth)
	      (t (error "Somebody has been messing with paths-find-*!")))))
  (setq load-path (paths-find-recursive-load-path
                   (cons lisp-directory
                         ;; Only pay attention to mule-lisp-directory if
                         ;; it's non-nil.
                         (and mule-lisp-directory (list mule-lisp-directory)))
                   depth)))

(load (expand-file-name "auto-autoloads" (car load-path)))


;;; Step 2, collect the dependencies into load-path and load the autoloads.
(let ((load-ignore-elc-files nil)
      (load-ignore-out-of-date-elc-files t))
  ;; Make sure we get the compiled version of the byte compiler, otherwise
  ;; compilation will be UNGODLY slow.
  (require 'bytecomp)
  (require 'byte-optimize))

(defconst package-directory-map
  '(
    ;; xemacs-packages
    ("Sun" . "xemacs-packages")
    ("ada" . "xemacs-packages")
    ("apel" . "xemacs-packages")
    ("auctex" . "xemacs-packages")
    ("bbdb" . "xemacs-packages")
    ("build" . "xemacs-packages")
    ("c-support" . "xemacs-packages")
    ("calc" . "xemacs-packages")
    ("calendar" . "xemacs-packages")
    ("cc-mode" . "xemacs-packages")
    ("cedet-common" . "xemacs-packages")
    ("clearcase" . "xemacs-packages")
    ("cogre" . "xemacs-packages")
    ("cookie" . "xemacs-packages")
    ("crisp" . "xemacs-packages")
    ("debug" . "xemacs-packages")
    ("docbookide" . "xemacs-packages")
    ("dictionary" . "xemacs-packages")
    ("dired" . "xemacs-packages")
    ("ecb" . "xemacs-packages")
    ("ecrypto" . "xemacs-packages")
    ("ede" . "xemacs-packages")
    ("edebug" . "xemacs-packages")
    ("ediff" . "xemacs-packages")
    ("edit-utils" . "xemacs-packages")
    ("edt" . "xemacs-packages")
    ("efs" . "xemacs-packages")
    ("eieio" . "xemacs-packages")
    ("elib" . "xemacs-packages")
    ("emerge" . "xemacs-packages")
    ("erc" . "xemacs-packages")
    ("eshell" . "xemacs-packages")
    ("eterm" . "xemacs-packages")
    ("eudc" . "xemacs-packages")
    ("escreen" . "xemacs-packages")
    ("footnote" . "xemacs-packages")
    ("forms" . "xemacs-packages")
    ("fortran-modes" . "xemacs-packages")
    ("frame-icon" . "xemacs-packages")
    ("fsf-compat" . "xemacs-packages")
    ("games" . "xemacs-packages")
    ("general-docs" . "xemacs-packages")
    ("gnats" . "xemacs-packages")
    ("gnus" . "xemacs-packages")
    ("guided-tour" . "xemacs-packages")
    ("haskell-mode" . "xemacs-packages")
    ("hm--html-menus" . "xemacs-packages")
    ("hyperbole" . "xemacs-packages")
    ("ibuffer" . "xemacs-packages")
    ("idlwave" . "xemacs-packages")
    ("igrep" . "xemacs-packages")
    ("ilisp" . "xemacs-packages")
    ("ispell" . "xemacs-packages")
    ("jde" . "xemacs-packages")
    ("mail-lib" . "xemacs-packages")
    ("mailcrypt" . "xemacs-packages")
    ("mew" . "xemacs-packages")
    ("mh-e" . "xemacs-packages")
    ("mine" . "xemacs-packages")
    ("misc-games" . "xemacs-packages")
    ("mmm-mode" . "xemacs-packages")
    ("net-utils" . "xemacs-packages")
    ("ocaml" . "xemacs-packages")
    ("oo-browser" . "xemacs-packages")
    ("os-utils" . "xemacs-packages")
    ("pc" . "xemacs-packages")
    ("pcl-cvs" . "xemacs-packages")
    ("pcomplete" . "xemacs-packages")
    ("perl-modes" . "xemacs-packages")
    ("pgg" . "xemacs-packages")
    ("prog-modes" . "xemacs-packages")
    ("ps-print" . "xemacs-packages")
    ("psgml" . "xemacs-packages")
    ("psgml-dtds" . "xemacs-packages")
    ("python-modes" . "xemacs-packages")
    ("re-builder" . "xemacs-packages")
    ("reftex" . "xemacs-packages")
    ("riece" . "xemacs-packages")
    ("rmail" . "xemacs-packages")
    ("ruby-modes" . "xemacs-packages")
    ("sasl" . "xemacs-packages")
    ("scheme" . "xemacs-packages")
    ("semantic" . "xemacs-packages")
    ("sgml" . "xemacs-packages")
    ("sh-script" . "xemacs-packages")
    ("sieve" . "xemacs-packages")
    ("slider" . "xemacs-packages")
    ("sml-mode" . "xemacs-packages")
    ("sounds-au" . "xemacs-packages")
    ("sounds-wav" . "xemacs-packages")
    ("speedbar" . "xemacs-packages")
    ("strokes" . "xemacs-packages")
    ("supercite" . "xemacs-packages")
    ("texinfo" . "xemacs-packages")
    ("text-modes" . "xemacs-packages")
    ("textools" . "xemacs-packages")
    ("time" . "xemacs-packages")
    ("tm" . "xemacs-packages")
    ("tooltalk" . "xemacs-packages")
    ("tpu" . "xemacs-packages")
    ("tramp" . "xemacs-packages")
    ("vc" . "xemacs-packages")
    ("vc-cc" . "xemacs-packages")
    ("vhdl" . "xemacs-packages")
    ("view-process" . "xemacs-packages")
    ("viper" . "xemacs-packages")
    ("vm" . "xemacs-packages")
    ("w3" . "xemacs-packages")
    ("x-symbol" . "xemacs-packages")
    ("xemacs-base" . "xemacs-packages")
    ("xemacs-devel" . "xemacs-packages")
    ("xetla" . "xemacs-packages")
    ("xlib" . "xemacs-packages")
    ("xslide" . "xemacs-packages")
    ("xslt-process" . "xemacs-packages")
    ("xwem" . "xemacs-packages")
    ("zenirc" . "xemacs-packages")
    ;; mule-packages
    ("edict" . "mule-packages")
    ("egg-its" . "mule-packages")
    ("latin-euro-standards" . "mule-packages")
    ("latin-unity" . "mule-packages")
    ("leim" . "mule-packages")
    ("locale" . "mule-packages")
    ("lookup" . "mule-packages")
    ("mule-base" . "mule-packages")
    ("mule-ucs" . "mule-packages")
    ("skk" . "mule-packages")
    ))

(defvar package-source-root nil)
(let ((defdir default-directory))
  (while (not (file-exists-p (expand-file-name "XEmacs.rules" defdir)))
    (setq defdir (expand-file-name (concat defdir "/.."))))
  (setq package-source-root defdir))

(defun package-name-to-directories (package)
  "Map `package' to a source directory."
  (let* ((area (or (cdr (assoc package package-directory-map))
		   (error (concat "%s is not in `package-directory-map'.  "
				  "See: package-compile.el")
			  package)))
	 (dir (expand-file-name
	      package (expand-file-name area package-source-root))))
    (cond ((or (equal package "bbdb") 
	       (equal package "gnus")
	       (equal package "jde")
	       (equal package "lookup")
	       (equal package "mule-ucs")
	       (equal package "tramp")
	       (equal package "vm")
               (equal package "w3")
	       (equal package "x-symbol")
	       (equal package "xlib")
	       (equal package "xwem"))
	   (list (expand-file-name "lisp" (file-name-as-directory dir))))
	  ((equal package "mew")
	   (list (expand-file-name "mew" (file-name-as-directory dir))))
	  ((equal package "zenirc")
	   (list (expand-file-name "src" (file-name-as-directory dir))))
	  ((equal package "semantic")
	   (list dir
		 (expand-file-name "bovine" (file-name-as-directory dir))
		 (expand-file-name "wisent" (file-name-as-directory dir))))
	  (t (list dir)))))

(defvar depends nil)
(defvar command-line-args-left)

(while (and command-line-args-left
	    (not (equal "--" (car command-line-args-left))))
  (push (car command-line-args-left) depends)
  (pop command-line-args-left))

(when command-line-args-left
  (pop command-line-args-left))

;; Setup load-path, data-directory-list and load necessary auto-autoloads
(while depends
  (let ((dirs (package-name-to-directories (car depends))))
    (when (null dirs)
      (error "%s is not in `package-directory-map'.  See: package-compile.el"
	     (car depends)))
    (let* ((dir (car dirs))
	   (etc-dir (expand-file-name "etc" dir)))
      (while dirs
	(push (car dirs) load-path)
	(setq dirs (cdr dirs)))
      ;; This assumes package has layout *-packages/package/etc/package
      ;; This is the case for the only package it matters at the time or writing
      ;; which is ps-print
      (if (file-directory-p (expand-file-name (car depends) etc-dir))
	  (push (file-name-as-directory etc-dir) data-directory-list))
      (load (expand-file-name "auto-autoloads" dir))
      (pop depends))))

;; Lastly, add the current directory
(push default-directory load-path)

;; Let it be known we are running under special circomstances
(defvar bootstrap-in-progress t)

;;; Step 3, perform the requested bytecompilation

;; (message "datadirs = %s" data-directory-list)

;; (prin1 "Load path = ")
;; (prin1 load-path)
;; (terpri)

;; Let the caller specify command
;(batch-byte-compile)

;; See comment at top of file.
;; #### Let's see whether we actually need this.
;;(setq load-ignore-elc-files t)

(provide 'package-compile)

;;; package-compile.el ends here
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.