tm 7.52.2.
[elisp/tm.git] / inst-tm
1 ;;; -*-Emacs-Lisp-*-
2 ;;;
3 ;;; $Id: inst-tm,v 5.0 1996/04/21 19:43:46 morioka Exp morioka $
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   (print load-path)
71   (require 'tm-rich)
72   (require 'mel-u)
73   (require 'tm-edit)
74   (load "rmailsum")
75   (require 'tm-mh-e)
76   (make-mime-setup TL_DIR MEL_DIR TM_KERNEL_DIR)
77   (compile-el-files "../tl/"  tl-modules)
78   (compile-el-files "../mel/" mel-modules)
79   (compile-el-files "./"      tm-modules)
80   (compile-el-files "mh-e/"   tm-mh-e-modules)
81   (compile-el-files "./"      '("mime-setup"))
82   (save-excursion
83     (set-buffer (get-buffer-create ".gnus-compile"))
84     (let ((emacs (car command-line-args)))
85       (insert (format "cd gnus\nmake gnus EMACS=%s PWD=`pwd`\n" emacs))
86       (cond ((string-match "XEmacs" emacs-version)
87              (insert (format "make sgnus EMACS=%s PWD=`pwd`\n" emacs))
88              )
89             (t (cond ((<= emacs-major-version 18)
90                       (insert (format "make gnus3 EMACS=%s PWD=`pwd`\n" emacs))
91                       (insert (format "make gnus4 EMACS=%s PWD=`pwd`\n" emacs))
92                       )
93                      ((< emacs-minor-version 30)
94                       (insert (format "make gnus4 EMACS=%s PWD=`pwd`\n" emacs))
95                       (insert (format "make gnus5 EMACS=%s PWD=`pwd`\n" emacs))
96                       )
97                      (t
98                       (insert (format "make sgnus EMACS=%s PWD=`pwd`\n" emacs))
99                       )))))
100     (write-file ".gnus-compile")
101     )
102   )
103
104 (defun install-el-file (src dest file)
105   (let ((src-file (expand-file-name file src)))
106     (if (file-exists-p src-file)
107         (let ((full-path (expand-file-name file dest)))
108           (if (file-exists-p full-path)
109               (set-file-modes full-path el-file-mode)
110             )
111           (copy-file src-file full-path t t)
112           (princ (format "%s -> %s\n" file dest))
113           ))
114     ))
115
116 (defun install-el-files (src dest &rest files)
117   (mapcar (function (lambda (file)
118                       (install-el-file src dest file)
119                       ))
120           files))
121
122 (defun install-elc (src dest file)
123   (let ((src-file (expand-file-name file src)))
124     (if (file-exists-p src-file)
125         (let ((full-path (expand-file-name file dest)))
126           (copy-file src-file full-path t t)
127           (delete-file src-file)
128           (princ (format "%s -> %s\n" file dest))
129           ))
130     ))
131
132 (defun install-elc-files (src dest &rest files)
133   (mapcar (function (lambda (file)
134                       (install-elc src dest file)
135                       ))
136           files))
137
138 (defun install-el-and-elc-files (src dest el-files elc-files)
139   (if (not (file-exists-p dest))
140       (make-directory dest t)
141     )
142   (apply (function install-el-files)  src dest el-files)
143   (apply (function install-elc-files) src dest elc-files)
144   )
145
146 (defun install-tm ()
147   (princ (format "%s\n" emacs-version))
148   (print TL_DIR)
149   (install-el-and-elc-files "../tl/" TL_DIR tl-el-files tl-elc-files)
150   (install-el-and-elc-files "../mel/" MEL_DIR mel-el-files mel-elc-files)
151   (install-el-and-elc-files "./" TM_KERNEL_DIR tm-el-files tm-elc-files)
152   (install-el-and-elc-files "mh-e/" TM_MHE_DIR
153                             tm-mh-e-el-files tm-mh-e-elc-files)
154   (install-tm-gnus)
155   (install-el-and-elc-files "./" SETUP_FILE_DIR setup-el-files setup-elc-files)
156   )
157
158 (defun install-execs ()
159   (apply (function install-el-files) BIN_SRC_DIR BIN_DIR BINS)
160   (apply (function install-el-files) METHOD_SRC_DIR METHOD_DIR METHODS)
161   )