1 # Maintenance productions for the Lisp directory
2 # Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
4 # This file is part of GNU Emacs.
6 # GNU Emacs is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 2, or (at your option)
11 # GNU Emacs is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with GNU Emacs; see the file COPYING. If not, write to
18 # the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19 # Boston, MA 02110-1301, USA.
27 # You can specify a different executable on the make command line,
28 # e.g. "make EMACS=../src/emacs ...".
32 # Command line flags for Emacs. This must include --multibyte,
33 # otherwise some files will not compile.
35 EMACSOPT
= -batch
--no-site-file
--multibyte
37 SOURCES
= *.el COPYING Makefile
38 lisptagsfiles1
= $(lisp
)/[a-zA-Z
]*.el
39 lisptagsfiles2
= $(lisp
)/[a-zA-Z
]*/[a-zA-Z
]*.el
40 ETAGS
= ..
/lib-src
/etags
42 # Elisp files auto-generated.
43 AUTOGENEL
= loaddefs.el \
47 eshell
/esh-groups.el \
50 # Files to compile before others during a bootstrap. This is done to
51 # speed up the bootstrap process. The CC files are compiled first
52 # because CC mode tweaks the compilation process, and requiring
53 # cc-mode when it is not compiled doesn't work during the
57 $(lisp
)/emacs-lisp
/byte-opt.el \
58 $(lisp
)/emacs-lisp
/bytecomp.el \
60 $(lisp
)/progmodes
/cc-mode.el \
61 $(lisp
)/progmodes
/cc-vars.el
63 # The actual Emacs command run in the targets below.
65 emacs
= EMACSLOADPATH
=$(lisp
) $(EMACS
) $(EMACSOPT
)
67 # Common command to find subdirectories
69 setwins
=subdirs
=`(cd $$wd; find . -type d -print)`; \
70 for file in
$$subdirs; do \
71 case
$$file in
*/Old |
*/RCS |
*/CVS |
*/CVS
/* |
*/.
* |
*/.
*/* |
*/=* ) ;; \
72 *) wins
="$$wins $$wd/$$file" ;; \
76 setwins_almost
=subdirs
=`(cd $$wd; find . -type d -print)`; \
77 for file in
$$subdirs; do \
78 case
$$file in
*/Old |
*/RCS |
*/CVS |
*/CVS
/* |
*/.
* |
*/.
*/* |
*/=* |
*/obsolete |
*/term
) ;; \
79 *) wins
="$$wins $$wd/$$file" ;; \
87 custom-deps
: $(lisp
)/cus-load.el doit
88 wd
=$(lisp
); $(setwins_almost
); \
89 echo Directories
: $$wins; \
90 $(EMACS
) $(EMACSOPT
) -l cus-dep
--eval
'(setq generated-custom-dependencies-file "$(lisp)/cus-load.el")' -f custom-make-dependencies
$$wins
93 wd
=$(lisp
); $(setwins_almost
); \
94 echo Directories
: $$wins; \
95 $(EMACS
) $(EMACSOPT
) -l finder
--eval
'(setq generated-finder-keywords-file "$(lisp)/finder-inf.el")' -f finder-compile-keywords-make-dist
$$wins
98 echo
";;; loaddefs.el --- automatically extracted autoloads" >> $@
99 echo
";;" >> $@
; echo
";;; Code:" >> $@
101 echo
";; Local Variables:" >> $@
102 echo
";; version-control: never" >> $@
103 echo
";; no-byte-compile: t" >> $@
104 echo
";; no-update-autoloads: t" >> $@
106 echo
";;; loaddefs.el ends here" >> $@
107 autoloads
: $(lisp
)/loaddefs.el doit
108 wd
=$(lisp
); $(setwins
); \
109 echo Directories
: $$wins; \
110 $(EMACS
) $(EMACSOPT
) -l autoload
--eval
'(setq generated-autoload-file "$(lisp)/loaddefs.el")' -f batch-update-autoloads
$$wins
113 $(MAKE
) $(MFLAGS
) update-subdirs
115 wd
=$(lisp
); $(setwins
); \
116 for file in
$$wins; do \
117 $(srcdir)/update-subdirs
$$file; \
120 updates
: update-subdirs autoloads mh-autoloads finder-data custom-deps
122 # This is useful after "cvs up".
123 cvs-update
: recompile autoloads finder-data custom-deps
125 # Update the AUTHORS file.
128 $(emacs
) -l authors
-f batch-update-authors
$(srcdir)/AUTHORS
$(srcdir)
130 TAGS
: $(lisptagsfiles1
) $(lisptagsfiles2
)
131 els
=`echo $(lisptagsfiles1) $(lisptagsfiles2) | sed -e "s,$(lisp)/loaddefs[^ ]*,," -e "s,$(lisp)/ldefs-boot[^ ]*,,"`; \
134 TAGS-LISP
: $(lisptagsfiles1
) $(lisptagsfiles2
)
135 els
=`echo $(lisptagsfiles1) $(lisptagsfiles2) | sed -e "s,$(lisp)/loaddefs[^ ]*,," -e "s,$(lisp)/ldefs-boot[^ ]*,,"`; \
136 ${ETAGS} -o TAGS-LISP
$$els
140 .el.elc
: $(lisp
)/subdirs.el
141 -$(emacs
) -f batch-byte-compile
$<
143 # Compile all Lisp files, but don't recompile those that are up to
144 # date. Some files don't actually get compiled because they set the
145 # local variable no-byte-compile.
147 # All .elc files are made writable before compilation in case we
148 # checked out read-only (CVS option -r). Files MUST be compiled one by
149 # one. If we compile several files in a row we can't make sure that
150 # the compilation environment is clean. We also set the load-path of
151 # the Emacs used for compilation to the current directory and its
152 # subdirectories, to make sure require's and load's in the files being
153 # compiled find the right files.
155 compile
: $(lisp
)/subdirs.el mh-autoloads doit
156 find
$(lisp
) -name
"*.elc" -print | xargs chmod
+w
>/dev
/null
2>&1; \
157 wd
=$(lisp
); $(setwins
); \
158 els
=`echo $$wins | tr ' \011' '\012\012' | \
159 sed -e 's|\(.\)$$|\1/|' -e 's|^\./||' -e 's|$$|*.el|'`; \
160 for el in
$(COMPILE_FIRST
) $$els; do \
163 echo Compiling
$$el; \
164 $(emacs
) -f batch-byte-compile-if-not-done
$$el || exit
1; \
168 # Compile all Lisp files. This is like `compile' but compiles files
169 # unconditionally. Some files don't actually get compiled because they
170 # set the local variable no-byte-compile.
172 compile-always
: $(lisp
)/subdirs.el doit
173 # `|| true' prevents old Bash versions from getting confused
175 find
$(lisp
) -name
"*.elc" -print | xargs chmod
+w
>/dev
/null
2>&1 || true
; \
176 wd
=$(lisp
); $(setwins
); \
177 els
=`echo $$wins | tr ' \011' '\012\012' | \
178 sed -e 's|\(.\)$$|\1/|' -e 's|^\./||' -e 's|$$|*.el|'`; \
179 for el in
$(COMPILE_FIRST
) $$els; do \
182 echo Compiling
$$el; \
183 $(emacs
) -f batch-byte-compile
$$el || exit
1; \
188 for el in
`find $(lisp)/calc -name '*.el'`; do \
189 echo Compiling
$$el; \
190 $(emacs
) -f batch-byte-compile
$$el || exit
1; \
193 # Backup compiled Lisp files in elc.tar.gz. If that file already
194 # exists, make a backup of it.
196 backup-compiled-files
:
197 -mv
$(lisp
)/elc.
tar.gz
$(lisp
)/elc.
tar.gz~
198 -tar czf
$(lisp
)/elc.
tar.gz
$(lisp
)/*.elc
$(lisp
)/*/*.elc
200 # Compile Lisp files, but save old compiled files first.
202 compile-after-backup
: backup-compiled-files compile-always
204 # Recompile all Lisp files which are newer than their .elc files.
205 # Note that this doesn't create .elc files. It only recompiles if an
208 recompile
: doit mh-autoloads
$(lisp
)/progmodes
/cc-mode.elc
209 $(EMACS
) $(EMACSOPT
) --eval
"(batch-byte-recompile-directory 0)" $(lisp
)
211 # CC Mode uses a compile time macro system which causes a compile time
212 # dependency in cc-mode.elc on the macros in cc-langs.el and the
213 # version string in cc-defs.el.
214 $(lisp
)/progmodes
/cc-mode.elc
: \
215 $(lisp
)/progmodes
/cc-mode.el \
216 $(lisp
)/progmodes
/cc-langs.el \
217 $(lisp
)/progmodes
/cc-defs.el
218 $(EMACS
) $(EMACSOPT
) -f batch-byte-compile
$(lisp
)/progmodes
/cc-mode.el
220 # Update MH-E internal autoloads. These are not to be confused with
221 # the autoloads for the MH-E entry points, which are already in
223 MH-E-SRC
= $(lisp
)/mh-e
/mh-acros.el
$(lisp
)/mh-e
/mh-alias.el \
224 $(lisp
)/mh-e
/mh-comp.el
$(lisp
)/mh-e
/mh-customize.el \
225 $(lisp
)/mh-e
/mh-e.el
$(lisp
)/mh-e
/mh-funcs.el \
226 $(lisp
)/mh-e
/mh-mime.el
$(lisp
)/mh-e
/mh-pick.el \
227 $(lisp
)/mh-e
/mh-print.el
$(lisp
)/mh-e
/mh-inc.el \
228 $(lisp
)/mh-e
/mh-init.el
$(lisp
)/mh-e
/mh-index.el \
229 $(lisp
)/mh-e
/mh-identity.el
$(lisp
)/mh-e
/mh-junk.el \
230 $(lisp
)/mh-e
/mh-seq.el
$(lisp
)/mh-e
/mh-speed.el \
231 $(lisp
)/mh-e
/mh-utils.el
233 mh-autoloads
: $(lisp
)/mh-e
/mh-loaddefs.el
234 $(lisp
)/mh-e
/mh-loaddefs.el
: $(MH-E-SRC
)
235 echo
";;; mh-loaddefs.el --- automatically extracted autoloads" > $@
237 echo
";; Copyright (C) 2003, 2004, 2005 Free Software Foundation, Inc." >> $@
238 echo
";; Author: Bill Wohler <wohler@newt.com>" >> $@
239 echo
";; Keywords: mail" >> $@
240 echo
";;; Commentary:" >> $@
241 echo
";;; Change Log:" >> $@
242 echo
";;; Code:" >> $@
243 $(EMACS
) $(EMACSOPT
) \
245 --eval
"(setq generate-autoload-cookie \";;;###mh-autoload\")" \
246 --eval
"(setq generated-autoload-file \"$(lisp)/mh-e/mh-loaddefs.el\")" \
247 --eval
"(setq make-backup-files nil)" \
248 -f batch-update-autoloads
$(lisp
)/mh-e
250 echo
"(provide 'mh-loaddefs)" >> $@
251 echo
";; Local Variables:" >> $@
252 echo
";; version-control: never" >> $@
253 echo
";; no-byte-compile: t" >> $@
254 echo
";; no-update-autoloads: t" >> $@
256 echo
";;; mh-loaddefs.el ends here" >> $@
258 # Prepare a bootstrap in the lisp subdirectory.
260 # Build loaddefs.el to make sure it's up-to-date. If it's not, that
261 # might lead to errors during the bootstrap because something fails to
262 # autoload as expected. If there is no emacs binary, then we can't
263 # build autoloads yet. In that case we have to use ldefs-boot.el.
264 # Bootstrap should always work with ldefs-boot.el. Therefore,
265 # whenever a new autoload cookie gets added that is necessary during
266 # bootstrapping, ldefs-boot.el should be updated by overwriting it with
267 # an up-to-date copy of loaddefs.el that is uncorrupted by
268 # local changes. (Because loaddefs.el is an automatically generated
269 # file, we don't want to store it in the source repository).
272 if
test -x
$(EMACS
); then \
273 $(MAKE
) $(MFLAGS
) autoloads
; \
275 cp
$(lisp
)/ldefs-boot.el
$(lisp
)/loaddefs.el
; \
278 maintainer-clean
: distclean
279 cd
$(lisp
); rm -f
*.elc
*/*.elc
$(AUTOGENEL
)
282 cd
$(lisp
); rm -f
*.elc
*/*.elc
284 # Generate/update files for the bootstrap process.
286 bootstrap
: update-subdirs autoloads mh-autoloads compile
288 # Generate/update files after the bootstrap process.
289 # custom-deps needs `preloaded-file-list'.
291 bootstrap-after
: finder-data custom-deps
296 # Makefile ends here.