Commit | Line | Data |
---|---|---|
46947372 JB |
1 | # DIST: This is the distribution Makefile for Emacs. configure can |
2 | # DIST: make most of the changes to this file you might want, so try | |
3 | # DIST: that first. | |
86a5659e | 4 | |
46947372 JB |
5 | # make all to compile and build Emacs. |
6 | # make install to install it. | |
78008d14 | 7 | # make TAGS to update tags tables. |
86a5659e | 8 | # |
78008d14 JB |
9 | # make clean or make mostlyclean |
10 | # Delete all files from the current directory that are normally | |
868e080d | 11 | # created by building the program. Don't delete the files that |
78008d14 JB |
12 | # record the configuration. Also preserve files that could be made |
13 | # by building, but normally aren't because the distribution comes | |
14 | # with them. | |
15 | # | |
16 | # Delete `.dvi' files here if they are not part of the distribution. | |
17 | # | |
18 | # make distclean | |
19 | # Delete all files from the current directory that are created by | |
20 | # configuring or building the program. If you have unpacked the | |
21 | # source and built the program without creating any other files, | |
22 | # `make distclean' should leave only the files that were in the | |
23 | # distribution. | |
24 | # | |
25 | # make realclean | |
26 | # Delete everything from the current directory that can be | |
27 | # reconstructed with this Makefile. This typically includes | |
28 | # everything deleted by distclean, plus more: C source files | |
29 | # produced by Bison, tags tables, info files, and so on. | |
30 | # | |
31 | # make extraclean | |
32 | # Still more severe - delete backup and autosave files, too. | |
86a5659e JB |
33 | |
34 | SHELL = /bin/sh | |
2dc44cb5 RS |
35 | |
36 | # If Make doesn't predefine MAKE, set it here. | |
37 | @SET_MAKE@ | |
86a5659e | 38 | |
78008d14 | 39 | # ==================== Things `configure' Might Edit ==================== |
86a5659e | 40 | |
c75ff9db | 41 | CC=@CC@ |
d4acf74f | 42 | CPP=@CPP@ |
c75ff9db | 43 | C_SWITCH_SYSTEM=@c_switch_system@ |
d3245f70 | 44 | ALLOCA=@ALLOCA@ |
b6472fc1 JB |
45 | LN_S=@LN_S@ |
46 | CFLAGS=@CFLAGS@ | |
46af2ed8 | 47 | C_SWITCH_X_SITE=@C_SWITCH_X_SITE@ |
09b89128 | 48 | LD_SWITCH_X_SITE=@LD_SWITCH_X_SITE@ |
4b5a51c1 | 49 | YACC=@YACC@ |
78008d14 JB |
50 | |
51 | ### These help us choose version- and architecture-specific directories | |
52 | ### to install files in. | |
53 | ||
54 | ### This should be the number of the Emacs version we're building, | |
55 | ### like `18.59' or `19.0'. | |
c75ff9db | 56 | version=@version@ |
78008d14 JB |
57 | |
58 | ### This should be the name of the configuration we're building Emacs | |
59 | ### for, like `mips-dec-ultrix' or `sparc-sun-sunos'. | |
c75ff9db JB |
60 | configuration=@configuration@ |
61 | ||
78008d14 JB |
62 | # ==================== Where To Install Things ==================== |
63 | ||
46947372 | 64 | # The default location for installation. Everything is placed in |
78008d14 JB |
65 | # subdirectories of this directory. The default values for many of |
66 | # the variables below are expressed in terms of this one, so you may | |
8d467c70 JB |
67 | # not need to change them. This defaults to /usr/local. |
68 | prefix=@prefix@ | |
86a5659e | 69 | |
78008d14 | 70 | # Like `prefix', but used for architecture-specific files. |
86ddcc58 | 71 | exec_prefix=@exec_prefix@ |
78008d14 | 72 | |
46947372 JB |
73 | # Where to install Emacs and other binaries that people will want to |
74 | # run directly (like etags). | |
0e265b72 | 75 | bindir=@bindir@ |
86a5659e | 76 | |
868e080d | 77 | # Where to install architecture-independent data files. ${lispdir} |
78008d14 | 78 | # and ${etcdir} are subdirectories of this. |
0e265b72 | 79 | datadir=@datadir@ |
0c22fbca JB |
80 | |
81 | # Where to install and expect the files that Emacs modifies as it | |
868e080d | 82 | # runs. These files are all architecture-independent. Right now, the |
78008d14 JB |
83 | # only such data is the locking directory; ${lockdir} is a |
84 | # subdirectory of this. | |
0e265b72 | 85 | statedir=@statedir@ |
0c22fbca JB |
86 | |
87 | # Where to install and expect executable files to be run by Emacs | |
88 | # rather than directly by users, and other architecture-dependent | |
868e080d | 89 | # data. ${archlibdir} is a subdirectory of this. |
653ddcc3 | 90 | libdir=@libdir@ |
0c22fbca JB |
91 | |
92 | # Where to install Emacs's man pages, and what extension they should have. | |
0e265b72 | 93 | mandir=@mandir@ |
0c22fbca JB |
94 | manext=.1 |
95 | ||
96 | # Where to install and expect the info files describing Emacs. In the | |
97 | # past, this defaulted to a subdirectory of ${prefix}/lib/emacs, but | |
98 | # since there are now many packages documented with the texinfo | |
99 | # system, it is inappropriate to imply that it is part of Emacs. | |
0e265b72 | 100 | infodir=@infodir@ |
86a5659e | 101 | |
00c29909 | 102 | # Where to find the source code. The source code for Emacs's C kernel is |
78008d14 JB |
103 | # expected to be in ${srcdir}/src, and the source code for Emacs's |
104 | # utility programs is expected to be in ${srcdir}/lib-src. This is | |
105 | # set by the configure script's `--srcdir' option. | |
d3245f70 | 106 | srcdir=@srcdir@ |
86a5659e | 107 | |
f854bb66 RM |
108 | # Tell make where to find source files; this is needed for the makefiles. |
109 | VPATH=@srcdir@ | |
110 | ||
0c22fbca JB |
111 | # ==================== Emacs-specific directories ==================== |
112 | ||
78008d14 JB |
113 | # These variables hold the values Emacs will actually use. They are |
114 | # based on the values of the standard Make variables above. | |
115 | ||
0e265b72 BF |
116 | # Where to install the lisp files distributed with |
117 | # Emacs. This includes the Emacs version, so that the | |
118 | # lisp files for different versions of Emacs will install | |
119 | # themselves in separate directories. | |
120 | lispdir=@lispdir@ | |
d3245f70 | 121 | |
0e265b72 BF |
122 | # Directories Emacs should search for lisp files specific |
123 | # to this site (i.e. customizations), before consulting | |
124 | # ${lispdir}. This should be a colon-separated list of | |
125 | # directories. | |
126 | locallisppath=@locallisppath@ | |
d3245f70 JB |
127 | |
128 | # Where Emacs will search to find its lisp files. Before | |
129 | # changing this, check to see if your purpose wouldn't | |
130 | # better be served by changing locallisppath. This | |
46947372 | 131 | # should be a colon-separated list of directories. |
0e265b72 | 132 | lisppath=@lisppath@ |
86a5659e | 133 | |
d3245f70 JB |
134 | # Where Emacs will search for its lisp files while |
135 | # building. This is only used during the process of | |
136 | # compiling Emacs, to help Emacs find its lisp files | |
137 | # before they've been installed in their final location. | |
90ac71dc RS |
138 | # It's usually identical to lisppath, except that |
139 | # it does not include locallisppath, and the | |
d3245f70 JB |
140 | # entry for the directory containing the installed lisp |
141 | # files has been replaced with ../lisp. This should be a | |
142 | # colon-separated list of directories. | |
3dbc7e32 | 143 | buildlisppath=${srcdir}/lisp |
86a5659e | 144 | |
0e265b72 BF |
145 | # Where to install the other architecture-independent |
146 | # data files distributed with Emacs (like the tutorial, | |
147 | # the cookie recipes and the Zippy database). This path | |
148 | # usually contains the Emacs version number, so the data | |
149 | # files for multiple versions of Emacs may be installed | |
150 | # at once. | |
151 | etcdir=@etcdir@ | |
152 | ||
153 | # Where to create and expect the locking directory, where | |
154 | # the Emacs locking code keeps track of which files are | |
155 | # currently being edited. | |
156 | lockdir=@lockdir@ | |
157 | ||
158 | # Where to put executables to be run by Emacs rather than | |
159 | # the user. This path usually includes the Emacs version | |
160 | # and configuration name, so that multiple configurations | |
161 | # for multiple versions of Emacs may be installed at | |
162 | # once. | |
163 | archlibdir=@archlibdir@ | |
a34902ab | 164 | |
e408046f KH |
165 | # Where to put the docstring file. |
166 | docdir=@docdir@ | |
167 | ||
46947372 JB |
168 | # ==================== Utility Programs for the Build ==================== |
169 | ||
170 | # Allow the user to specify the install program. | |
19697295 | 171 | INSTALL = @INSTALL@ |
86ddcc58 JB |
172 | INSTALL_PROGRAM = @INSTALL_PROGRAM@ |
173 | INSTALL_DATA = @INSTALL_DATA@ | |
46947372 | 174 | |
46947372 | 175 | # ============================= Targets ============================== |
86a5659e | 176 | |
9ef7f9f0 KH |
177 | # What emacs should be called when installed. |
178 | EMACS = emacs | |
179 | ||
86a5659e JB |
180 | # Subdirectories to make recursively. `lisp' is not included |
181 | # because the compiled lisp files are part of the distribution | |
182 | # and you cannot remake them without installing Emacs first. | |
46947372 | 183 | SUBDIR = lib-src src |
86a5659e | 184 | |
78008d14 | 185 | # The makefiles of the directories in $SUBDIR. |
98dfba1b | 186 | SUBDIR_MAKEFILES = lib-src/Makefile src/Makefile oldXMenu/Makefile lwlib/Makefile |
78008d14 | 187 | |
83f6a565 JB |
188 | # Subdirectories to install, and where they'll go. |
189 | # lib-src's makefile knows how to install it, so we don't do that here. | |
190 | # When installing the info files, we need to do special things to | |
191 | # avoid nuking an existing dir file, so we don't do that here; | |
192 | # instead, we have written out explicit code in the `install' targets. | |
78c7997f RS |
193 | COPYDIR = ${srcdir}/etc ${srcdir}/lisp |
194 | COPYDESTS = ${etcdir} ${lispdir} | |
86a5659e | 195 | |
8672a560 | 196 | all: paths-force ${SUBDIR} |
86a5659e | 197 | |
309848ba | 198 | removenullpaths=sed -e 's/^://g' -e 's/:$$//g' -e 's/::/:/g' |
46947372 | 199 | |
8672a560 RS |
200 | # Note that sed is not in /bin on 386bsd. |
201 | src/paths.h: Makefile ${srcdir}/src/paths.h.in | |
202 | @echo "Producing \`src/paths.h' from \`src/paths.h.in'." | |
203 | @(lisppath=`echo ${lisppath} | ${removenullpaths}` ; \ | |
204 | buildlisppath=`echo ${buildlisppath} | ${removenullpaths}` ; \ | |
270cc80e | 205 | sed < ${srcdir}/src/paths.h.in > paths.h.tmp$$$$ \ |
8672a560 RS |
206 | -e 's;\(#.*PATH_LOADSEARCH\).*$$;\1 "'$${lisppath}'";' \ |
207 | -e 's;\(#.*PATH_DUMPLOADSEARCH\).*$$;\1 "'$${buildlisppath}'";' \ | |
208 | -e 's;\(#.*PATH_EXEC\).*$$;\1 "${archlibdir}";' \ | |
209 | -e 's;\(#.*PATH_INFO\).*$$;\1 "${infodir}";' \ | |
210 | -e 's;\(#.*PATH_DATA\).*$$;\1 "${etcdir}";' \ | |
211 | -e 's;\(#.*PATH_DOC\).*$$;\1 "${docdir}";' \ | |
270cc80e RS |
212 | -e 's;\(#.*PATH_LOCK\).*$$;\1 "${lockdir}/";') && \ |
213 | ${srcdir}/move-if-change paths.h.tmp$$$$ src/paths.h | |
8672a560 RS |
214 | |
215 | # For `make all', | |
216 | # we force the rebuilding of src/paths.h because the user might give | |
78008d14 JB |
217 | # make different values for the various directories. Since we use |
218 | # move-if-change, src/paths.h only actually changes if the user did | |
219 | # something notable, so the only unnecessary work we do is in building | |
270cc80e | 220 | # paths.h.tmp$$$$, which isn't much. |
692f9ac6 | 221 | # Note that sed is not in /bin on 386bsd. |
8672a560 | 222 | paths-force: FRC.src.paths.h |
7987a169 JB |
223 | @echo "Producing \`src/paths.h' from \`src/paths.h.in'." |
224 | @(lisppath=`echo ${lisppath} | ${removenullpaths}` ; \ | |
225 | buildlisppath=`echo ${buildlisppath} | ${removenullpaths}` ; \ | |
270cc80e | 226 | sed < ${srcdir}/src/paths.h.in > paths.h.tmp$$$$ \ |
7987a169 JB |
227 | -e 's;\(#.*PATH_LOADSEARCH\).*$$;\1 "'$${lisppath}'";' \ |
228 | -e 's;\(#.*PATH_DUMPLOADSEARCH\).*$$;\1 "'$${buildlisppath}'";' \ | |
229 | -e 's;\(#.*PATH_EXEC\).*$$;\1 "${archlibdir}";' \ | |
8b14d296 | 230 | -e 's;\(#.*PATH_INFO\).*$$;\1 "${infodir}";' \ |
7987a169 | 231 | -e 's;\(#.*PATH_DATA\).*$$;\1 "${etcdir}";' \ |
e408046f | 232 | -e 's;\(#.*PATH_DOC\).*$$;\1 "${docdir}";' \ |
270cc80e RS |
233 | -e 's;\(#.*PATH_LOCK\).*$$;\1 "${lockdir}/";') && \ |
234 | ${srcdir}/move-if-change paths.h.tmp$$$$ src/paths.h | |
86a5659e | 235 | |
8672a560 | 236 | src: lib-src FRC.src src/paths.h |
a874c104 | 237 | |
485c9046 RS |
238 | # This ought to depend on src/paths.h, so that in parallel make |
239 | # src/paths.h will be available for the compilations in lib-src. | |
240 | # But that causes trouble in `make install' if a different prefix | |
241 | # is specified at that time. | |
8672a560 | 242 | lib-src: FRC.lib-src src/paths.h |
86a5659e JB |
243 | |
244 | .RECURSIVE: ${SUBDIR} | |
245 | ||
78008d14 | 246 | ${SUBDIR}: ${SUBDIR_MAKEFILES} FRC |
0e265b72 | 247 | cd $@; $(MAKE) all $(MFLAGS) \ |
7c811eec RS |
248 | CC='${CC}' CFLAGS='${CFLAGS}' CPPFLAGS='${CPPFLAGS}' \ |
249 | LDFLAGS='${LDFLAGS}' MAKE='${MAKE}' | |
0e265b72 | 250 | |
8672a560 | 251 | blessmail: ${SUBDIR_MAKEFILES} src FRC |
d541babe RS |
252 | cd lib-src; $(MAKE) maybe-blessmail $(MFLAGS) MAKE='${MAKE}' |
253 | ||
0e265b72 BF |
254 | Makefile: Makefile.in config.status |
255 | ./config.status | |
256 | ||
257 | src/Makefile: src/Makefile.in.in config.status | |
258 | ./config.status | |
259 | ||
260 | lib-src/Makefile: lib-src/Makefile.in config.status | |
261 | ./config.status | |
262 | ||
263 | oldXMenu/Makefile: oldXMenu/Makefile.in config.status | |
78008d14 JB |
264 | ./config.status |
265 | ||
98dfba1b RS |
266 | lwlib/Makefile: lwlib/Makefile.in config.status |
267 | ./config.status | |
268 | ||
78008d14 JB |
269 | # ==================== Installation ==================== |
270 | ||
dbc4e1c1 JB |
271 | ## If we let lib-src do its own installation, that means we |
272 | ## don't have to duplicate the list of utilities to install in | |
273 | ## this Makefile as well. | |
d3245f70 | 274 | |
3dbc7e32 JB |
275 | ## On AIX, use tar xBf. |
276 | ## On Xenix, use tar xpf. | |
277 | ||
9ef7f9f0 | 278 | .PHONY: install mkdir |
98dfba1b | 279 | |
d3245f70 JB |
280 | ## We delete each directory in ${COPYDESTS} before we copy into it; |
281 | ## that way, we can reinstall over directories that have been put in | |
282 | ## place with their files read-only (perhaps because they are checked | |
283 | ## into RCS). In order to make this safe, we make sure that the | |
284 | ## source exists and is distinct from the destination. | |
653ddcc3 RS |
285 | ## We don't depend on `all', but rather on ${SUBDIR}, so that we won't |
286 | ## ever modify src/paths.h. | |
f512d050 | 287 | install: ${SUBDIR} install-arch-dep install-arch-indep blessmail; |
8b14d296 | 288 | |
af1d3b64 RS |
289 | ### Note that we copy the DOC-* files from the build etc directory |
290 | ### as well as lots of things from ${srcdir}/etc. | |
3be1f08e | 291 | install-arch-dep: mkdir |
8b14d296 | 292 | (cd lib-src; \ |
0e265b72 | 293 | $(MAKE) install $(MFLAGS) prefix=${prefix} \ |
8b14d296 JB |
294 | exec_prefix=${exec_prefix} bindir=${bindir} libdir=${libdir} \ |
295 | archlibdir=${archlibdir}) | |
08068cb6 RS |
296 | ${INSTALL_PROGRAM} src/emacs ${bindir}/emacs-${version} |
297 | -chmod 1755 ${bindir}/emacs-${version} | |
9ef7f9f0 KH |
298 | rm -f ${bindir}/$(EMACS) |
299 | -ln ${bindir}/emacs-${version} ${bindir}/$(EMACS) | |
08068cb6 | 300 | |
3be1f08e RS |
301 | ### Note that we copy the DOC-* files from the build etc directory |
302 | ### as well as lots of things from ${srcdir}/etc. | |
08068cb6 | 303 | install-arch-indep: mkdir |
46947372 | 304 | -set ${COPYDESTS} ; \ |
005775ce | 305 | for dir in ${COPYDIR} ; do \ |
8672a560 | 306 | if [ `(cd $$1 && /bin/pwd)` != `(cd $${dir} && /bin/pwd)` ] ; then \ |
88190b54 | 307 | rm -rf $$1 ; \ |
005775ce | 308 | fi ; \ |
335bb18d | 309 | shift ; \ |
005775ce JB |
310 | done |
311 | -set ${COPYDESTS} ; \ | |
8b14d296 | 312 | mkdir ${COPYDESTS} ; \ |
46947372 JB |
313 | for dir in ${COPYDIR} ; do \ |
314 | dest=$$1 ; shift ; \ | |
d3245f70 | 315 | [ -d $${dir} ] \ |
8fd812d1 | 316 | && [ `(cd $${dir} && /bin/pwd)` != `(cd $${dest} && /bin/pwd)` ] \ |
3dbc7e32 | 317 | && (echo "Copying $${dir}..." ; \ |
5d9e58e8 | 318 | (cd $${dir}; tar -cf - . )|(cd $${dest};umask 022; tar -xvf - ); \ |
d3245f70 JB |
319 | for subdir in `find $${dest} -type d ! -name RCS -print` ; do \ |
320 | rm -rf $${subdir}/RCS ; \ | |
321 | rm -rf $${subdir}/CVS ; \ | |
322 | rm -f $${subdir}/\#* ; \ | |
323 | rm -f $${subdir}/*~ ; \ | |
324 | done) ; \ | |
46947372 | 325 | done |
3be1f08e RS |
326 | if [ `(cd ./etc; /bin/pwd)` != `(cd ${docdir}; /bin/pwd)` ]; \ |
327 | then \ | |
328 | echo "Copying etc/DOC* ..." ; \ | |
329 | (cd etc; tar -cf - DOC*)|(cd ${docdir}; umask 0; tar -xvf - ); \ | |
330 | else true; fi | |
8672a560 | 331 | thisdir=`/bin/pwd`; \ |
21e8e1db | 332 | if [ `(cd ${srcdir}/info && /bin/pwd)` != `(cd ${infodir} && /bin/pwd)` ]; \ |
5e9e88fd | 333 | then \ |
ce0b6622 RS |
334 | (cd ${srcdir}/info ; \ |
335 | if [ ! -f ${infodir}/dir ] && [ -f dir ]; then \ | |
d59d49d3 | 336 | (cd $${thisdir}; ${INSTALL_DATA} ${srcdir}/info/dir ${infodir}/dir); \ |
ce0b6622 | 337 | fi ; \ |
3be1f08e | 338 | for f in cl* dired-x* emacs* forms* gnus* info* sc* vip* ; do \ |
d59d49d3 | 339 | (cd $${thisdir}; ${INSTALL_DATA} ${srcdir}/info/$$f ${infodir}/$$f); \ |
ce0b6622 | 340 | done); \ |
21e8e1db | 341 | else true; fi |
8672a560 | 342 | thisdir=`/bin/pwd`; cd ${srcdir}/etc; for page in emacs etags ctags ; do \ |
d59d49d3 | 343 | (cd $${thisdir}; ${INSTALL_DATA} ${srcdir}/etc/$${page}.1 ${mandir}/$${page}${manext}); \ |
868e080d | 344 | done |
badb0a97 | 345 | |
868e080d | 346 | ### Build all the directories we're going to install Emacs in. Since |
78008d14 JB |
347 | ### we may be creating several layers of directories (for example, |
348 | ### /usr/local/lib/emacs/19.0/mips-dec-ultrix4.2), we use make-path | |
349 | ### instead of mkdir. Not all systems' mkdirs have the `-p' flag. | |
b305e8e5 | 350 | mkdir: FRC.mkdir |
8b14d296 | 351 | ./lib-src/make-path ${COPYDESTS} ${lockdir} ${infodir} ${mandir} \ |
a1a7207a | 352 | ${bindir} ${datadir} ${docdir} ${libdir} \ |
309848ba | 353 | `echo ${locallisppath} | sed 's/:/ /g'` |
653ddcc3 | 354 | -chmod 777 ${lockdir} |
86a5659e | 355 | |
d4acf74f JB |
356 | ### Delete all the installed files that the `install' target would |
357 | ### create (but not the noninstalled files such as `make all' would | |
358 | ### create). | |
44257b1a JB |
359 | ### |
360 | ### Don't delete the lisp and etc directories if they're in the source tree. | |
d4acf74f | 361 | uninstall: |
44257b1a | 362 | (cd lib-src; \ |
0e265b72 | 363 | $(MAKE) $(MFLAGS) uninstall \ |
44257b1a | 364 | prefix=${prefix} exec_prefix=${exec_prefix} \ |
d4acf74f | 365 | bindir=${bindir} libdir=${libdir} archlibdir=${archlibdir}) |
44257b1a | 366 | for dir in ${lispdir} ${etcdir} ; do \ |
726d0798 | 367 | if [ -d $${dir} ]; then \ |
8672a560 RS |
368 | case `(cd $${dir} ; /bin/pwd)` in \ |
369 | `(cd ${srcdir} ; /bin/pwd)`* ) ;; \ | |
726d0798 RS |
370 | * ) rm -rf $${dir} ;; \ |
371 | esac ; \ | |
372 | case $${dir} in \ | |
373 | ${datadir}/emacs/${version}/* ) \ | |
374 | rm -rf ${datadir}/emacs/${version} \ | |
375 | ;; \ | |
376 | esac ; \ | |
377 | fi ; \ | |
44257b1a | 378 | done |
d4acf74f JB |
379 | (cd ${infodir}; rm -f cl* emacs* forms* info* vip*) |
380 | (cd ${mandir}; rm -f emacs.1 etags.1 ctags.1) | |
2ec5f0cd | 381 | (cd ${bindir}; rm -f emacs-${version} $(EMACS)) |
d4acf74f JB |
382 | |
383 | ||
04d9326a JB |
384 | ### Some makes seem to remember that they've built something called FRC, |
385 | ### so you can only use a given FRC once per makefile. | |
b305e8e5 | 386 | FRC FRC.src.paths.h FRC.src FRC.lib-src FRC.mkdir: |
d4acf74f | 387 | FRC.mostlyclean FRC.clean FRC.distclean FRC.realclean: |
78008d14 JB |
388 | |
389 | # ==================== Cleaning up and miscellanea ==================== | |
390 | ||
98dfba1b RS |
391 | .PHONY: mostlyclean clean distclean realclean extraclean |
392 | ||
78008d14 | 393 | ### `mostlyclean' |
d4acf74f JB |
394 | ### Like `clean', but may refrain from deleting a few files that people |
395 | ### normally don't want to recompile. For example, the `mostlyclean' | |
396 | ### target for GCC does not delete `libgcc.a', because recompiling it | |
397 | ### is rarely necessary and takes a lot of time. | |
398 | mostlyclean: FRC.mostlyclean | |
0e265b72 BF |
399 | (cd src; $(MAKE) $(MFLAGS) mostlyclean) |
400 | (cd oldXMenu; $(MAKE) $(MFLAGS) mostlyclean) | |
98dfba1b | 401 | (cd lwlib; $(MAKE) $(MFLAGS) mostlyclean) |
0e265b72 | 402 | (cd lib-src; $(MAKE) $(MFLAGS) mostlyclean) |
e6124e9d | 403 | -(cd man && $(MAKE) $(MFLAGS) mostlyclean) |
d4acf74f JB |
404 | |
405 | ### `clean' | |
406 | ### Delete all files from the current directory that are normally | |
407 | ### created by building the program. Don't delete the files that | |
408 | ### record the configuration. Also preserve files that could be made | |
409 | ### by building, but normally aren't because the distribution comes | |
410 | ### with them. | |
78008d14 | 411 | ### |
d4acf74f JB |
412 | ### Delete `.dvi' files here if they are not part of the distribution. |
413 | clean: FRC.clean | |
0e265b72 BF |
414 | (cd src; $(MAKE) $(MFLAGS) clean) |
415 | (cd oldXMenu; $(MAKE) $(MFLAGS) clean) | |
98dfba1b | 416 | (cd lwlib; $(MAKE) $(MFLAGS) clean) |
0e265b72 | 417 | (cd lib-src; $(MAKE) $(MFLAGS) clean) |
e6124e9d | 418 | -(cd man && $(MAKE) $(MFLAGS) clean) |
46947372 | 419 | |
78008d14 | 420 | ### `distclean' |
d4acf74f JB |
421 | ### Delete all files from the current directory that are created by |
422 | ### configuring or building the program. If you have unpacked the | |
423 | ### source and built the program without creating any other files, | |
424 | ### `make distclean' should leave only the files that were in the | |
425 | ### distribution. | |
426 | top_distclean=\ | |
427 | rm -f config.status build-install ; \ | |
428 | rm -f Makefile ${SUBDIR_MAKEFILES} ; \ | |
39b62b3b | 429 | (cd lock ; rm -f *) |
d4acf74f | 430 | distclean: FRC.distclean |
0e265b72 BF |
431 | (cd src; $(MAKE) $(MFLAGS) distclean) |
432 | (cd oldXMenu; $(MAKE) $(MFLAGS) distclean) | |
98dfba1b | 433 | (cd lwlib; $(MAKE) $(MFLAGS) distclean) |
0e265b72 | 434 | (cd lib-src; $(MAKE) $(MFLAGS) distclean) |
e6124e9d | 435 | (cd man && $(MAKE) $(MFLAGS) distclean) |
d4acf74f JB |
436 | ${top_distclean} |
437 | ||
46947372 | 438 | |
78008d14 | 439 | ### `realclean' |
d4acf74f JB |
440 | ### Delete everything from the current directory that can be |
441 | ### reconstructed with this Makefile. This typically includes | |
442 | ### everything deleted by distclean, plus more: C source files | |
443 | ### produced by Bison, tags tables, info files, and so on. | |
444 | ### | |
445 | ### One exception, however: `make realclean' should not delete | |
446 | ### `configure' even if `configure' can be remade using a rule in the | |
447 | ### Makefile. More generally, `make realclean' should not delete | |
448 | ### anything that needs to exist in order to run `configure' and then | |
449 | ### begin to build the program. | |
450 | realclean: FRC.realclean | |
0e265b72 BF |
451 | (cd src; $(MAKE) $(MFLAGS) realclean) |
452 | (cd oldXMenu; $(MAKE) $(MFLAGS) realclean) | |
98dfba1b | 453 | (cd lwlib; $(MAKE) $(MFLAGS) realclean) |
0e265b72 | 454 | (cd lib-src; $(MAKE) $(MFLAGS) realclean) |
e6124e9d | 455 | -(cd man && $(MAKE) $(MFLAGS) realclean) |
d4acf74f | 456 | ${top_distclean} |
46947372 | 457 | |
78008d14 JB |
458 | ### This doesn't actually appear in the coding standards, but Karl |
459 | ### says GCC supports it, and that's where the configuration part of | |
460 | ### the coding standards seem to come from. It's like distclean, but | |
461 | ### it deletes backup and autosave files too. | |
462 | extraclean: | |
0e265b72 | 463 | for i in ${SUBDIR}; do (cd $$i; $(MAKE) $(MFLAGS) extraclean); done |
78008d14 JB |
464 | -(cd lock; rm *) |
465 | -rm config.status config-tmp-* | |
466 | -rm -f *~ \#* | |
467 | ||
29c0047b ER |
468 | ### Unlocking and relocking. The idea of these productions is to reduce |
469 | ### hassles when installing an incremental tar of Emacs. Do `make unlock' | |
470 | ### before unlocking the file to take the write locks off all sources so | |
471 | ### that tar xvof will overwrite them without fuss. Then do `make relock' | |
472 | ### afterward so that VC mode will know which files should be checked in | |
473 | ### if you want to mung them. | |
474 | ### | |
475 | ### Note: it's no disaster if these productions miss a file or two; tar | |
476 | ### and VC will swiftly let you know if this happens, and it is easily | |
477 | ### corrected. | |
478 | SOURCES = ChangeLog GETTING.GNU.SOFTWARE INSTALL Makefile.in PROBLEMS \ | |
479 | README build-install.in configure make-dist move-if-change | |
480 | ||
98dfba1b RS |
481 | .PHONY: unlock relock |
482 | ||
29c0047b ER |
483 | unlock: |
484 | chmod u+w $(SOURCES) cpp/* | |
485 | -(cd elisp; chmod u+w Makefile README *.texi) | |
0e265b72 BF |
486 | (cd etc; $(MAKE) $(MFLAGS) unlock) |
487 | (cd lib-src; $(MAKE) $(MFLAGS) unlock) | |
488 | (cd lisp; $(MAKE) $(MFLAGS) unlock) | |
29c0047b ER |
489 | (cd lisp/term; chmod u+w README *.el) |
490 | (cd man; chmod u+w *texi* ChangeLog split-man) | |
491 | (cd oldXMenu; chmod u+w *.[ch] Makefile README) | |
98dfba1b | 492 | (cd lwlib; chmod u+w *.[ch] Makefile README) |
0e265b72 | 493 | (cd src; $(MAKE) $(MFLAGS) unlock) |
29c0047b ER |
494 | |
495 | relock: | |
496 | chmod u-w $(SOURCES) cpp/* | |
497 | -(cd elisp; chmod u-w Makefile README *.texi) | |
0e265b72 BF |
498 | (cd etc; $(MAKE) $(MFLAGS) relock) |
499 | (cd lib-src; $(MAKE) $(MFLAGS) relock) | |
500 | (cd lisp; $(MAKE) $(MFLAGS) relock) | |
29c0047b ER |
501 | (cd lisp/term; chmod u+w README *.el) |
502 | (cd man; chmod u+w *texi* ChangeLog split-man) | |
503 | (cd oldXMenu; chmod u+w *.[ch] Makefile README) | |
98dfba1b | 504 | (cd lwlib; chmod u+w *.[ch] Makefile README) |
0e265b72 | 505 | (cd src; $(MAKE) $(MFLAGS) relock) |
78008d14 | 506 | |
46947372 | 507 | TAGS tags: lib-src |
928cf895 | 508 | cd ${srcdir}/src; $(MAKE) tags |
46947372 JB |
509 | |
510 | check: | |
511 | @echo "We don't have any tests for GNU Emacs yet." | |
4746118a JB |
512 | |
513 | dist: | |
78008d14 | 514 | cd ${srcdir}; make-dist |
d4acf74f | 515 | |
653ddcc3 RS |
516 | .PHONY: info dvi dist check |
517 | force-info: | |
518 | info: force-info | |
0e265b72 | 519 | (cd ${srcdir}/man; $(MAKE) $(MFLAGS) info) |
d4acf74f | 520 | dvi: |
0e265b72 | 521 | (cd ${srcdir}/man; $(MAKE) $(MFLAGS) dvi) |