tm 7.52.1.
[elisp/tm.git] / inst-tm
1 ;;; -*-Emacs-Lisp-*-
2 ;;;
3 ;;; $Id: inst-tm,v 5.0 1996/04/21 19:43:46 morioka Exp $
4 ;;;
5
6 (load-file "TM-CFG")
7 (load-file "../tl/tl-els")
8 (load-file "../mel/mel-els")
9 (load-file "TM-ELS")
10 (load-file "mh-e/tmh-els")
11
12 (defun make-mime-setup (tl-path mel-path tm-path)
13   (let ((buf (find-file "mime-setup.el.in")))
14     (goto-char (point-min))
15     (re-search-forward "^;;; Code:" nil t)
16     (setq buffer-read-only nil)
17     (if (member tl-path default-load-path)
18         (insert "
19
20 \(require \'tl-misc)")
21       (insert
22        (format "
23
24 \(let ((load-path
25        (cons \"%s\"
26              load-path)))
27   (require \'tl-misc)
28   )
29 \(add-path \"%s\")" tl-path tl-path))
30       )
31     (or (member mel-path default-load-path)
32         (insert
33          (format "
34 \(add-path \"%s\")" mel-path)))
35     (or (member tm-path default-load-path)
36         (insert
37          (format "
38 \(add-path \"%s\")" tm-path)))
39     (insert (format "
40 (defvar mime-viewer/external-progs \"%s\")" METHOD_DIR))
41     (write-file "mime-setup.el")
42     ))
43
44 (defun compile-el-files (path modules)
45   (mapcar (function
46            (lambda (module)
47              (setq module (expand-file-name module path))
48              (let ((el-file (concat module ".el"))
49                    (elc-file (concat module ".elc"))
50                    )
51                (if (file-newer-than-file-p el-file elc-file)
52                    (byte-compile-file el-file)
53                  )
54                )))
55           modules))
56
57 (defun install-tm-gnus ()
58   (erase-buffer)
59   (call-process SHELL
60                 nil t t
61                 SHELLOPTION
62                 (format
63                  TM_GNUS_INSTALL_FORMAT
64                  (car command-line-args) TM_GNUS_DIR)
65                 )
66   (princ (buffer-string))
67   )
68
69 (defun compile-tm ()
70   (require 'tm-rich)
71   (require 'mel-u)
72   (require 'tm-edit)
73   (load "rmailsum")
74   (require 'tm-mh-e)
75   (make-mime-setup TL_DIR MEL_DIR TM_KERNEL_DIR)
76   (compile-el-files "../tl/"  tl-modules)
77   (compile-el-files "../mel/" mel-modules)
78   (compile-el-files "./"      tm-modules)
79   (compile-el-files "mh-e/"   tm-mh-e-modules)
80   (compile-el-files "./"      '("mime-setup"))
81   (save-excursion
82     (set-buffer (get-buffer-create ".gnus-compile"))
83     (let ((emacs (car command-line-args)))
84       (insert (format "cd gnus\nmake gnus EMACS=%s PWD=`pwd`\n" emacs))
85       (cond ((string-match "XEmacs" emacs-version)
86              (insert (format "make sgnus EMACS=%s PWD=`pwd`\n" emacs))
87              )
88             (t (cond ((<= emacs-major-version 18)
89                       (insert (format "make gnus3 EMACS=%s PWD=`pwd`\n" emacs))
90                       (insert (format "make gnus4 EMACS=%s PWD=`pwd`\n" emacs))
91                       )
92                      ((< emacs-minor-version 30)
93                       (insert (format "make gnus4 EMACS=%s PWD=`pwd`\n" emacs))
94                       (insert (format "make gnus5 EMACS=%s PWD=`pwd`\n" emacs))
95                       )
96                      (t
97                       (insert (format "make sgnus EMACS=%s PWD=`pwd`\n" emacs))
98                       )))))
99     (write-file ".gnus-compile")
100     )
101   )
102
103 (defun install-el-file (src dest file)
104   (let ((src-file (expand-file-name file src)))
105     (if (file-exists-p src-file)
106         (let ((full-path (expand-file-name file dest)))
107           (if (file-exists-p full-path)
108               (set-file-modes full-path el-file-mode)
109             )
110           (copy-file src-file full-path t t)
111           (princ (format "%s -> %s\n" file dest))
112           ))
113     ))
114
115 (defun install-el-files (src dest &rest files)
116   (mapcar (function (lambda (file)
117                       (install-el-file src dest file)
118                       ))
119           files))
120
121 (defun install-elc (src dest file)
122   (let ((src-file (expand-file-name file src)))
123     (if (file-exists-p src-file)
124         (let ((full-path (expand-file-name file dest)))
125           (copy-file src-file full-path t t)
126           (delete-file src-file)
127           (princ (format "%s -> %s\n" file dest))
128           ))
129     ))
130
131 (defun install-elc-files (src dest &rest files)
132   (mapcar (function (lambda (file)
133                       (install-elc src dest file)
134                       ))
135           files))
136
137 (defun install-el-and-elc-files (src dest el-files elc-files)
138   (if (not (file-exists-p dest))
139       (make-directory dest t)
140     )
141   (apply (function install-el-files)  src dest el-files)
142   (apply (function install-elc-files) src dest elc-files)
143   )
144
145 (defun install-tm ()
146   (princ (format "%s\n" emacs-version))
147   (print TL_DIR)
148   (install-el-and-elc-files "../tl/" TL_DIR tl-el-files tl-elc-files)
149   (install-el-and-elc-files "../mel/" MEL_DIR mel-el-files mel-elc-files)
150   (install-el-and-elc-files "./" TM_KERNEL_DIR tm-el-files tm-elc-files)
151   (install-el-and-elc-files "mh-e/" TM_MHE_DIR
152                             tm-mh-e-el-files tm-mh-e-elc-files)
153   (install-tm-gnus)
154   (install-el-and-elc-files "./" SETUP_FILE_DIR setup-el-files setup-elc-files)
155   )
156
157 (defun install-execs ()
158   (apply (function install-el-files) BIN_SRC_DIR BIN_DIR BINS)
159   (apply (function install-el-files) METHOD_SRC_DIR METHOD_DIR METHODS)
160   )