Mercurial > hg > xemacs-beta
annotate Makefile.in.in @ 5497:70af4098e14f
Merge by hand with the changeset that backed out e82f5b7010fe.
man/ChangeLog addition:
2011-05-02 Aidan Kehoe <kehoea@parhasard.net>
* Makefile:
* texinfo.tex:
Merge by hand with the changeset that backed out e82f5b7010fe
(e82f5b7010fe is incompatible with deployed versions of makeinfo
as of today).
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Mon, 02 May 2011 10:51:26 +0100 |
parents | 308d34e9f07d |
children | 4aa8ee813265 |
rev | line source |
---|---|
4939
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
1 ## Copyright (C) 2003, 2005, 2010 Ben Wing. |
1314 | 2 |
380 | 3 ## DIST: This is the distribution Makefile for XEmacs. configure can |
4 ## DIST: make most of the changes to this file you might want, so try | |
5 ## DIST: that first. | |
6 | |
7 ## This file is part of XEmacs. | |
8 | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
4939
diff
changeset
|
9 ## XEmacs is free software: you can redistribute it and/or modify it |
380 | 10 ## under the terms of the GNU General Public License as published by the |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
4939
diff
changeset
|
11 ## Free Software Foundation, either version 3 of the License, or (at your |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
4939
diff
changeset
|
12 ## option) any later version. |
380 | 13 |
14 ## XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
15 ## ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
16 ## FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
17 ## for more details. | |
18 | |
19 ## You should have received a copy of the GNU General Public License | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
4939
diff
changeset
|
20 ## along with XEmacs. If not, see <http://www.gnu.org/licenses/>. |
380 | 21 |
22 ## make all to compile and build XEmacs. | |
23 ## make install to build and install it. | |
24 ## make install-only to install after a previous complete build | |
25 ## make TAGS to update tags tables. | |
26 | |
27 ## make clean or make mostlyclean | |
28 ## Delete all files from the current directory that are normally | |
29 ## created by building the program. Don't delete the files that | |
30 ## record the configuration. Also preserve files that could be made | |
31 ## by building, but normally aren't because the distribution comes | |
32 ## with them. | |
33 | |
34 ## Delete `.dvi' files here if they are not part of the distribution. | |
35 | |
36 ## make distclean | |
37 ## Delete all files from the current directory that are created by | |
38 ## configuring or building the program. If you have unpacked the | |
39 ## source and built the program without creating any other files, | |
40 ## `make distclean' should leave only the files that were in the | |
41 ## distribution. | |
42 | |
43 ## make realclean | |
44 ## Delete everything from the current directory that can be | |
45 ## reconstructed with this Makefile. This typically includes | |
46 ## everything deleted by distclean, plus more: C source files | |
47 ## produced by Bison, tags tables, info files, and so on. | |
48 | |
49 ## make extraclean | |
50 ## Still more severe - delete backup and autosave files, too. | |
51 | |
424 | 52 #define NOT_C_CODE |
53 #include "src/config.h" | |
54 | |
380 | 55 #ifdef USE_GNU_MAKE |
2427 | 56 RECURSIVE_MAKE_ARGS= |
380 | 57 #else |
58 @SET_MAKE@ | |
2427 | 59 RECURSIVE_MAKE_ARGS=@RECURSIVE_MAKE_ARGS@ |
380 | 60 #endif |
61 | |
62 SHELL = /bin/sh | |
63 LANG = C | |
396 | 64 LC_ALL = C |
380 | 65 RM = rm -f |
426 | 66 MAKEPATH=./lib-src/make-path |
380 | 67 pwd = /bin/pwd |
430 | 68 TAR = tar |
380 | 69 |
70 ## ==================== Things `configure' Might Edit ==================== | |
71 | |
72 CC=@CC@ | |
73 CPP=@CPP@ | |
74 LN_S=@LN_S@ | |
75 CFLAGS=@CFLAGS@ | |
76 CPPFLAGS=@CPPFLAGS@ | |
708 | 77 LDFLAGS=@LDFLAGS@ |
380 | 78 |
79 ## These help us choose version- and architecture-specific directories | |
80 ## to install files in. | |
81 | |
82 ## This should be the number of the XEmacs version we're building, | |
83 ## like `19.12' or `19.13'. | |
84 version=@version@ | |
85 | |
86 ## This should be the name of the configuration we're building XEmacs | |
87 ## for, like `mips-dec-ultrix' or `sparc-sun-sunos'. | |
88 configuration=@configuration@ | |
89 | |
90 ## This will be the name of the generated binary and is set automatically | |
91 ## by configure. | |
92 PROGNAME=@PROGNAME@ | |
4448
fd8a9a4d81d9
Support #!, to allow XEmacs to be called as a script interpreter.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4374
diff
changeset
|
93 SHEBANG_PROGNAME=@SHEBANG_PROGNAME@ |
380 | 94 |
95 ## ==================== Where To Install Things ==================== | |
96 | |
97 ## The default location for installation. Everything is placed in | |
98 ## subdirectories of this directory. The default values for many of | |
99 ## the variables below are expressed in terms of this one, so you may | |
100 ## not need to change them. This defaults to /usr/local. | |
101 prefix=@prefix@ | |
102 | |
422 | 103 ## Variable data (as per each program update) goes here |
104 ## The default is ${PROGNAME} | |
105 inststaticdir=@inststaticdir@ | |
106 | |
107 ## Static data (constant across program updates) goes here | |
108 ## The default is ${PROGNAME}-${version} | |
109 instvardir=@instvardir@ | |
110 | |
380 | 111 ## Like `prefix', but used for architecture-specific files. |
112 exec_prefix=@exec_prefix@ | |
113 | |
114 ## Where to install XEmacs and other binaries that people will want to | |
115 ## run directly (like etags). | |
116 bindir=@bindir@ | |
117 | |
4118 | 118 ## Base for installing architecture-independent data files. |
119 ## ${infodir} and ${mandir} are subdirectories of this. | |
120 datarootdir=@datarootdir@ | |
121 | |
380 | 122 ## Where to install architecture-independent data files. |
123 ## ${lispdir} and ${etcdir} are subdirectories of this. | |
124 datadir=@datadir@ | |
125 | |
126 ## Where to install and expect the files that XEmacs modifies as it runs. | |
127 ## These files are all architecture-independent. Right now, the | |
128 ## only such data is the locking directory; | |
129 statedir=@statedir@ | |
130 | |
131 ## Where to install and expect executable files to be run by XEmacs | |
132 ## rather than directly by users, and other architecture-dependent data | |
133 ## ${archlibdir} is a subdirectory of this. | |
134 libdir=@libdir@ | |
135 | |
136 ## Where to install XEmacs's man pages, and what extension they should have. | |
137 mandir=@mandir@ | |
138 manext=.1 | |
139 | |
140 ## Where to install and expect the info files describing XEmacs. In the | |
141 ## past, this defaulted to a subdirectory of ${prefix}/lib/xemacs, but | |
142 ## since there are now many packages documented with the texinfo | |
143 ## system, it is inappropriate to imply that it is part of XEmacs. | |
144 infodir=@infodir@ | |
145 | |
146 ## Document me. | |
147 ## See callproc.c for code which references this. | |
148 infopath=@infopath@ | |
149 | |
150 ## Where to find the source code. The source code for XEmacs's C kernel is | |
151 ## expected to be in ${srcdir}/src, and the source code for XEmacs's | |
152 ## utility programs is expected to be in ${srcdir}/lib-src. This is | |
153 ## set by the configure script's `--srcdir' option. | |
154 srcdir=@srcdir@ | |
155 | |
156 ## Where the build is done. | |
157 blddir=@blddir@ | |
158 | |
159 ## ==================== XEmacs-specific directories ==================== | |
160 | |
161 ## These variables hold the values XEmacs will actually use. They are | |
162 ## based on the values of the standard Make variables above. | |
163 | |
164 ## Where to install the lisp files distributed with | |
165 ## XEmacs. This includes the XEmacs version, so that the | |
166 ## lisp files for different versions of XEmacs will install | |
167 ## themselves in separate directories. | |
168 lispdir=@lispdir@ | |
169 | |
388 | 170 ## Where to install the module files distributed with |
171 ## XEmacs. This includes the XEmacs version, so that the | |
172 ## module files for different versions of XEmacs will install | |
173 ## themselves in separate directories. | |
174 moduledir=@moduledir@ | |
175 | |
380 | 176 ## Directory XEmacs should search for lisp files specific |
177 ## to this site (i.e. customizations), before consulting | |
178 ## ${lispdir}. | |
179 sitelispdir=@sitelispdir@ | |
180 | |
388 | 181 ## Directory XEmacs should search for module files specific |
182 ## to this site (i.e. customizations), before consulting | |
183 ## ${moduledir}. | |
184 sitemoduledir=@sitemoduledir@ | |
185 | |
380 | 186 ## Where XEmacs will search for its lisp files while |
187 ## building. This is only used during the process of | |
188 ## compiling XEmacs, to help XEmacs find its lisp files | |
189 ## before they've been installed in their final location. | |
190 ## It's usually identical to lispdir, except that the | |
191 ## entry for the directory containing the installed lisp | |
192 ## files has been replaced with ../lisp. This should be a | |
193 ## colon-separated list of directories. | |
194 buildlispdir=${srcdir}/lisp | |
195 | |
196 ## Where to install the other architecture-independent | |
197 ## data files distributed with XEmacs (like the tutorial, | |
198 ## the cookie recipes and the Zippy database). This path | |
199 ## usually contains the XEmacs version number, so the data | |
200 ## files for multiple versions of XEmacs may be installed | |
201 ## at once. | |
202 etcdir=@etcdir@ | |
203 | |
424 | 204 ## Where to put the DOC file. |
420 | 205 docdir=@docdir@ |
206 | |
380 | 207 ## Where to put executables to be run by XEmacs rather than |
208 ## the user. This path usually includes the XEmacs version | |
209 ## and configuration name, so that multiple configurations | |
210 ## for multiple versions of XEmacs may be installed at | |
211 ## once. | |
212 archlibdir=@archlibdir@ | |
213 | |
214 ## ==================== Utility Programs for the Build ==================== | |
215 | |
216 ## Allow the user to specify the install program. | |
217 INSTALL = @install_pp@ @INSTALL@ | |
218 INSTALL_PROGRAM = @INSTALL_PROGRAM@ | |
219 INSTALL_DATA = @INSTALL_DATA@ | |
220 | |
221 ## ============================= Targets ============================== | |
222 | |
3062 | 223 ## Subdirectories to make recursively. `lisp' is not included currently; |
224 ## rebuilding the compiled lisp files is done in the `src' make and requires | |
225 ## building XEmacs first. | |
380 | 226 MAKE_SUBDIR = @MAKE_SUBDIR@ |
227 | |
228 ## Subdirectories that can be made recursively. | |
424 | 229 SUBDIR = ${MAKE_SUBDIR} man |
230 | |
380 | 231 ## The makefiles of the directories in ${MAKE_SUBDIR}. |
232 SUBDIR_MAKEFILES = @SUBDIR_MAKEFILES@ | |
233 | |
234 ## Subdirectories to `make install-arch-dep' recursively | |
235 INSTALL_ARCH_DEP_SUBDIR = @INSTALL_ARCH_DEP_SUBDIR@ | |
236 | |
237 ## Subdirectories to install, and where they'll go. | |
238 ## lib-src's makefile knows how to install it, so we don't do that here. | |
239 ## When installing the info files, we need to do special things to | |
240 ## avoid nuking an existing dir file, so we don't do that here; | |
241 ## instead, we have written out explicit code in the `install' targets. | |
242 COPYDIR = ${srcdir}/etc ${srcdir}/lisp | |
243 COPYDESTS = ${etcdir} ${lispdir} | |
4939
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
244 GENERATED_HEADERS = src/paths.h src/Emacs.ad.h src/config.h lwlib/config.h src/sheap-adjust.h src/xemacs.def etc/PROBLEMS src/.gdbinit |
380 | 245 |
1314 | 246 ## MAKE_SUBDIR will always be of the form lib-src ... src, where |
247 ## `...' includes various other directories that may be inserted by | |
248 ## configure. | |
249 all: Makefile ${GENERATED_HEADERS} ${MAKE_SUBDIR} info | |
380 | 250 |
251 ## For performance and consistency, no built-in rules | |
252 .SUFFIXES: | |
253 | |
1314 | 254 .NO_PARALLEL: ${GENERATED_HEADERS} ${MAKE_SUBDIR} |
255 .PHONY: ${SUBDIR} all beta | |
380 | 256 |
257 ## Convenience target for XEmacs beta testers | |
4419
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
258 beta: elcclean update-version all |
380 | 259 |
260 ## Convenience target for XEmacs maintainers | |
261 ## This would run `make-xemacsdist' if I were really confident that everything | |
262 ## was turnkey. | |
1314 | 263 dist: all |
380 | 264 |
265 ## Convenience target for XEmacs maintainers | |
266 ## Updates some rarely generated files: | |
3752 | 267 ## - configure from configure.ac |
380 | 268 ## - config.values.in from configure |
269 ## - src/depend from src/*.[ch] | |
270 .PHONY: config configure depend | |
271 config: configure depend | |
426 | 272 configure: ${srcdir}/configure ${srcdir}/lib-src/config.values.in |
273 | |
3752 | 274 ${srcdir}/configure : ${srcdir}/configure.ac |
380 | 275 cd ${srcdir} && autoconf |
276 | |
426 | 277 ${srcdir}/lib-src/config.values.in : ${srcdir}/configure |
278 cd ${srcdir} && $(SHELL) lib-src/config.values.sh | |
279 | |
442 | 280 depend ${srcdir}/src/depend: |
2427 | 281 cd ./src && $(MAKE) $(RECURSIVE_MAKE_ARGS) depend |
380 | 282 |
4939
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
283 .PHONY: config-changed |
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
284 config-changed: |
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
285 cd ./src && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@ |
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
286 |
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
287 .PHONY: check |
1314 | 288 check: |
2427 | 289 cd ./src && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@ |
380 | 290 |
4939
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
291 .PHONY: check-features |
1314 | 292 check-features: all |
2427 | 293 cd ./src && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@ |
380 | 294 |
295 ## We have to force the building of Emacs.ad.h as well in order to get it | |
296 ## updated correctly when VPATH is being used. Since we use move-if-change, | |
297 ## it will only actually change if the user modified ${etcdir}/Emacs.ad. | |
298 src/Emacs.ad.h: ${srcdir}/etc/Emacs.ad | |
299 @echo "Producing \`src/Emacs.ad.h' from \`etc/Emacs.ad'." | |
300 @$(RM) src/Emacs.ad.h | |
301 @(echo "/* Do not edit this file!" ; \ | |
302 echo " Automatically generated from ${srcdir}/etc/Emacs.ad" ; \ | |
303 echo " */" ; \ | |
426 | 304 $(SHELL) ${srcdir}/lib-src/ad2c ${srcdir}/etc/Emacs.ad ) > \ |
380 | 305 src/Emacs.ad.h |
306 | |
307 src/sheap-adjust.h: | |
308 @echo "Resetting \`src/sheap-adjust.h'."; \ | |
309 (echo "/* Do not edit this file!" ; \ | |
310 echo " Automatically generated by XEmacs */" ; \ | |
1157 | 311 echo "#define SHEAP_ADJUSTMENT 0") > $@ |
380 | 312 |
313 src: @SRC_SUBDIR_DEPS@ FRC.src | |
314 pkg-src/tree-x: pkg-src/FRC.tree-x | |
315 lib-src: FRC.lib-src | |
316 lwlib: FRC.lwlib | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4663
diff
changeset
|
317 FRC.src FRC.lib-src FRC.lwlib pkg-src/FRC.tree-x: |
380 | 318 FRC.lisp.finder-inf.el: |
319 | |
320 ${SUBDIR}: ${SUBDIR_MAKEFILES} ${GENERATED_HEADERS} FRC | |
2427 | 321 cd ./$@ && $(MAKE) $(RECURSIVE_MAKE_ARGS) all |
2259 | 322 |
4419
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
323 ## This should be the same code as in configure.ac. |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
324 update-version: |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
325 cp ${srcdir}/version.sh.in ${srcdir}/version.sh |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
326 if test -d ${srcdir}/.hg; then \ |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
327 (cd ${srcdir}; hg identify | cut -d " " -f 1 >> version.sh); \ |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
328 fi |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4374
diff
changeset
|
329 |
2259 | 330 ## Building modules depends on ellcc, found in lib-src. |
2973 | 331 modules/sample modules/ldap modules/zlib modules/base64: lib-src |
332 modules/postgresql modules/canna: lib-src | |
380 | 333 |
801 | 334 Makefile: ${srcdir}/Makefile.in.in config.status |
380 | 335 ./config.status |
2427 | 336 $(MAKE) $(RECURSIVE_MAKE_ARGS) all |
380 | 337 |
338 src/Makefile: ${srcdir}/src/Makefile.in.in ${srcdir}/src/depend config.status | |
339 ./config.status | |
340 | |
341 lib-src/Makefile: ${srcdir}/lib-src/Makefile.in.in config.status | |
342 ./config.status | |
343 | |
344 lwlib/Makefile: ${srcdir}/lwlib/Makefile.in.in config.status | |
345 ./config.status | |
346 | |
347 pkg-src/tree-x/Makefile: ${srcdir}/pkg-src/tree-x/Makefile.in.in config.status | |
348 ./config.status | |
349 | |
350 src/config.h: ${srcdir}/src/config.h.in | |
351 ./config.status && touch $@ | |
352 | |
353 src/paths.h: ${srcdir}/src/paths.h.in | |
354 ./config.status && touch $@ | |
355 | |
356 lwlib/config.h: ${srcdir}/lwlib/config.h.in | |
357 ./config.status && touch $@ | |
358 | |
1633 | 359 src/xemacs.def: $(srcdir)/src/xemacs.def.in.in |
360 ./config.status && touch $@ | |
361 | |
4939
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
362 src/.gdbinit: ${srcdir}/src/.gdbinit.in.in |
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
363 ./config.status && touch $@ |
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4850
diff
changeset
|
364 |
3074 | 365 etc/PROBLEMS: $(srcdir)/PROBLEMS |
366 cp $^ $@ | |
367 | |
380 | 368 ## ==================== Installation ==================== |
369 | |
370 ## If we let lib-src do its own installation, that means we | |
371 ## don't have to duplicate the list of utilities to install in | |
372 ## this Makefile as well. | |
373 | |
374 ## On AIX, use tar xBf. | |
375 | |
376 .PHONY: install-only install install-arch-dep install-arch-indep gzip.el mkdir | |
377 | |
378 ## We delete each directory in ${COPYDESTS} before we copy into it; | |
379 ## that way, we can reinstall over directories that have been put in | |
380 ## place with their files read-only (perhaps because they are checked | |
381 ## into RCS). In order to make this safe, we make sure that the | |
382 ## source exists and is distinct from the destination. | |
383 | |
384 ## FSF doesn't depend on `all', but rather on ${MAKE_SUBDIR}, so that | |
385 ## they "won't ever modify src/paths.h". But that means you can't do | |
386 ## 'make install' right off the bat because src/paths.h won't exist. | |
387 ## And, in XEmacs case, src/Emacs.ad.h won't exist either. I also | |
388 ## don't see the point in avoiding modifying paths.h. It creates an | |
389 ## inconsistency in the build process. So we go ahead and depend on | |
390 ## all. --cet | |
391 | |
392 install-only: ${MAKE_SUBDIR} check-features install-arch-dep install-arch-indep | |
393 | |
394 install: all check-features install-arch-dep install-arch-indep | |
395 | |
396 install-arch-dep: mkdir | |
397 for subdir in ${INSTALL_ARCH_DEP_SUBDIR}; do \ | |
2427 | 398 (cd ./$${subdir} && $(MAKE) $(RECURSIVE_MAKE_ARGS) install prefix=${prefix} \ |
380 | 399 exec_prefix=${exec_prefix} bindir=${bindir} libdir=${libdir} \ |
400 archlibdir=${archlibdir}) ; done | |
401 if test "`(cd ${archlibdir} && $(pwd))`" != \ | |
402 "`(cd ./lib-src && $(pwd))`"; then \ | |
403 if test -f ../Installation; then \ | |
404 ${INSTALL_DATA} ../Installation ${archlibdir}/Installation; \ | |
405 fi; \ | |
422 | 406 ${INSTALL_DATA} lib-src/config.values ${docdir}/config.values; \ |
420 | 407 ${INSTALL_DATA} lib-src/DOC ${docdir}/DOC; \ |
380 | 408 for subdir in `find ${archlibdir} -type d ! -name RCS ! -name SCCS ! -name CVS -print` ; \ |
409 do (cd $${subdir} && $(RM) -r RCS CVS SCCS \#* *~) ; done ; \ | |
410 else true; fi | |
2720 | 411 #if (defined(PDUMP) && !defined (DUMP_IN_EXEC)) || (defined (PDUMP) && defined(WIN32_NATIVE)) |
442 | 412 ${INSTALL_DATA} src/${PROGNAME}.dmp ${bindir}/${PROGNAME}-${version}-`src/${PROGNAME} -sd`.dmp |
413 #endif | |
414 #ifdef WIN32_NATIVE | |
424 | 415 ${INSTALL_PROGRAM} src/${PROGNAME} ${bindir}/${PROGNAME} |
416 -chmod 0755 ${bindir}/${PROGNAME} | |
417 #else | |
2388 | 418 # ifdef CYGWIN |
419 ${INSTALL_PROGRAM} src/${PROGNAME} ${bindir}/${PROGNAME}-${version}.exe | |
420 -chmod 0755 ${bindir}/${PROGNAME}-${version}.exe | |
421 cd ${bindir} && $(RM) ./${PROGNAME} && ${LN_S} ${PROGNAME}-${version}.exe ./${PROGNAME} | |
4448
fd8a9a4d81d9
Support #!, to allow XEmacs to be called as a script interpreter.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4374
diff
changeset
|
422 cd ${bindir} && $(RM) ./${SHEBANG_PROGNAME} && ${LN_S} ${PROGNAME}-${version}.exe ./${SHEBANG_PROGNAME} |
2388 | 423 # else |
380 | 424 ${INSTALL_PROGRAM} src/${PROGNAME} ${bindir}/${PROGNAME}-${version} |
425 -chmod 0755 ${bindir}/${PROGNAME}-${version} | |
426 cd ${bindir} && $(RM) ./${PROGNAME} && ${LN_S} ${PROGNAME}-${version} ./${PROGNAME} | |
4449
13ce402e1736
Call AC_SUBST on SHEBANG_PATHNAME, for #! support.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4448
diff
changeset
|
427 cd ${bindir} && $(RM) ./${SHEBANG_PROGNAME} && ${LN_S} ${PROGNAME}-${version} ./${SHEBANG_PROGNAME} |
442 | 428 # endif /* CYGWIN */ |
429 #endif /* WIN32_NATIVE */ | |
997 | 430 #ifdef HAVE_SHLIB |
431 $(INSTALL_DATA) $(srcdir)/modules/auto-autoloads.* $(moduledir) | |
432 #endif | |
380 | 433 |
434 install-arch-indep: mkdir info | |
435 -@set ${COPYDESTS} ; \ | |
436 for dir in ${COPYDIR} ; do \ | |
437 if test "`(cd $$1 && $(pwd))`" != \ | |
438 "`(cd $${dir} && $(pwd))`"; then \ | |
439 : do nothing - echo "rm -rf $$1" ; \ | |
440 fi ; \ | |
441 shift ; \ | |
442 done | |
443 -set ${COPYDESTS} ; \ | |
444 for dir in ${COPYDESTS} ; do \ | |
445 if test ! -d $${dir} ; then mkdir $${dir} ; fi ; \ | |
446 done ; \ | |
447 for dir in ${COPYDIR} ; do \ | |
448 dest=$$1 ; shift ; \ | |
449 test -d $${dir} \ | |
450 -a "`(cd $${dir} && $(pwd))`" != \ | |
451 "`(cd $${dest} && $(pwd))`" \ | |
452 && (echo "Copying $${dir}..." ; \ | |
430 | 453 (cd $${dir} && $(TAR) -cf - . ) | \ |
454 (cd $${dest} && umask 022 && $(TAR) -xf - );\ | |
380 | 455 chmod 0755 $${dest}; \ |
456 for subdir in `find $${dest} -type d ! -name RCS ! -name SCCS ! -name CVS -print` ; do \ | |
457 (cd $${subdir} && $(RM) -r RCS CVS SCCS \#* *~) ; \ | |
458 done) ; \ | |
459 done | |
460 if test "`(cd ${srcdir}/info && $(pwd))`" != \ | |
461 "`(cd ${infodir} && $(pwd))`" && cd ${srcdir}/info; then \ | |
462 if test ! -f ${infodir}/dir -a -f dir ; then \ | |
463 ${INSTALL_DATA} ${srcdir}/info/dir ${infodir}/dir ; \ | |
464 fi ; \ | |
465 for file in *.info* ; do \ | |
466 ${INSTALL_DATA} $${file} ${infodir}/$${file} ; \ | |
467 chmod 0644 ${infodir}/$${file}; \ | |
468 done ; \ | |
469 fi | |
470 cd ${srcdir}/etc && \ | |
471 for page in xemacs etags ctags gnuserv gnuclient gnuattach gnudoit; do \ | |
472 ${INSTALL_DATA} ${srcdir}/etc/$${page}.1 ${mandir}/$${page}${manext} ; \ | |
473 chmod 0644 ${mandir}/$${page}${manext} ; \ | |
474 done | |
2128 | 475 @echo "If you would like to save approximately 4M of disk space, do" |
380 | 476 @echo "make gzip-el" |
477 @echo "or you may run " | |
478 @echo ${srcdir}/lib-src/gzip-el.sh lispdir " from the command line." | |
479 @echo "Where lispdir is where the lisp files were installed, i.e.," | |
480 @echo "${lispdir}" | |
481 | |
482 gzip-el: | |
426 | 483 $(SHELL) ${srcdir}/lib-src/gzip-el.sh ${lispdir} |
380 | 484 |
485 ## Build all the directories to install XEmacs in. | |
486 ## Since we may be creating several layers of directories, | |
487 ## (e.g. /usr/local/lib/${PROGNAME}-20.5/sparc-sun-solaris2.6), we use | |
488 ## make-path instead of mkdir. Not all mkdirs have the `-p' flag. | |
489 mkdir: FRC.mkdir | |
444 | 490 ${MAKEPATH} ${COPYDESTS} ${docdir} ${infodir} ${archlibdir} \ |
1349 | 491 ${mandir} ${bindir} ${datadir} ${libdir} \ |
598 | 492 #ifdef HAVE_SHLIB |
493 ${moduledir} ${sitemoduledir} \ | |
494 #endif | |
495 ${sitelispdir} | |
380 | 496 |
4354
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
497 ## Install bundled packages, if present. |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
498 |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
499 package_path = @LATE_PACKAGE_DIRECTORIES@ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
500 pkgsrcdir = ${srcdir}/etc/bundled-packages |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
501 |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
502 ## #### Probably we should add a rule for lib-src/make-path here. |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
503 |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
504 check-available-packages: |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
505 @if test -r ${pkgsrcdir}/bootstrap.tar.gz; \ |
4357
3af63264d320
Make check-available-packages announce where to install packages.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4354
diff
changeset
|
506 then echo "To install a set of bootstrap packages in"; \ |
3af63264d320
Make check-available-packages announce where to install packages.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4354
diff
changeset
|
507 echo "${package_path}/xemacs-packages, type:"; \ |
4354
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
508 echo " make install-bootstrap-packages"; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
509 fi; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
510 if test -r ${pkgsrcdir}/xemacs-sumo.tar.gz; \ |
4357
3af63264d320
Make check-available-packages announce where to install packages.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4354
diff
changeset
|
511 then echo "To install the full set of non-mule packages in"; \ |
3af63264d320
Make check-available-packages announce where to install packages.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4354
diff
changeset
|
512 echo "${package_path}/xemacs-packages, type:"; \ |
4354
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
513 echo " make install-nonmule-packages"; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
514 fi; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
515 if test -r ${pkgsrcdir}/xemacs-mule-sumo.tar.gz; \ |
4357
3af63264d320
Make check-available-packages announce where to install packages.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4354
diff
changeset
|
516 then echo "To install the full set of packages with mule in"; \ |
3af63264d320
Make check-available-packages announce where to install packages.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4354
diff
changeset
|
517 echo "${package_path}/mule-packages, type:"; \ |
4354
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
518 echo " make install-all-packages"; \ |
4361
146742e30f05
Ensure LATE_PACKAGES_DIRECTORIES is a trivial search path.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4357
diff
changeset
|
519 fi |
146742e30f05
Ensure LATE_PACKAGES_DIRECTORIES is a trivial search path.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4357
diff
changeset
|
520 |
4374
4939bde48d12
Fix incorrect comment convention.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4361
diff
changeset
|
521 ## The test for a non-trivial path simply checks for the conventional Unix |
4939bde48d12
Fix incorrect comment convention.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4361
diff
changeset
|
522 ## path separator ":". This is reasonable because this is basically just |
4939bde48d12
Fix incorrect comment convention.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4361
diff
changeset
|
523 ## a convenience feature, anyway. |
4354
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
524 |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
525 mkpkgdir: FRC.mkdir ${MAKEPATH} |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
526 @if test -z ${package_path}; \ |
4361
146742e30f05
Ensure LATE_PACKAGES_DIRECTORIES is a trivial search path.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4357
diff
changeset
|
527 then echo "Not configured --with-late-packages; no place to install."; \ |
146742e30f05
Ensure LATE_PACKAGES_DIRECTORIES is a trivial search path.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4357
diff
changeset
|
528 exit -1; \ |
146742e30f05
Ensure LATE_PACKAGES_DIRECTORIES is a trivial search path.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4357
diff
changeset
|
529 elif echo ${package_path} | grep ":"; \ |
146742e30f05
Ensure LATE_PACKAGES_DIRECTORIES is a trivial search path.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4357
diff
changeset
|
530 then echo "Configured with multiple late package directories; you decide where to install."; \ |
4354
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
531 exit -1; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
532 elif test -e ${package_path}/xemacs-packages \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
533 -o -e ${package_path}/mule-packages; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
534 then echo "${package_path} is installed; won't overwrite packages."; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
535 exit -1; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
536 fi |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
537 ${MAKEPATH} ${package_path}; |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
538 |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
539 install-bootstrap-packages: mkpkgdir |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
540 cd ${package_path}; tar xvzf ${pkgsrcdir}/bootstrap.tar.gz |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
541 |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
542 install-nonmule-packages: mkpkgdir |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
543 cd ${package_path}; tar xvzf ${pkgsrcdir}/xemacs-sumo.tar.gz |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
544 |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
545 install-all-packages: mkpkgdir |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
546 cd ${package_path}; tar xvzf ${pkgsrcdir}/xemacs-sumo.tar.gz; \ |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
547 cd ${package_path}; tar xvzf ${pkgsrcdir}/xemacs-mule-sumo.tar.gz |
232d873b9705
Add support for installing bundled patches.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4197
diff
changeset
|
548 |
380 | 549 ## Delete all the installed files that the `install' target would |
550 ## create (but not the noninstalled files such as `make all' would | |
551 ## create). | |
552 | |
553 #### Don't delete the lisp and etc directories if they're in the source tree. | |
554 #### This target has not been updated in sometime and until it is it | |
555 #### would be extremely dangerous for anyone to use it. | |
556 ##uninstall: | |
557 ## (cd ./lib-src; \ | |
2427 | 558 ## $(MAKE) $(RECURSIVE_MAKE_ARGS) uninstall \ |
380 | 559 ## prefix=${prefix} exec_prefix=${exec_prefix} \ |
560 ## bindir=${bindir} libdir=${libdir} archlibdir=${archlibdir}) | |
561 ## for dir in ${lispdir} ${etcdir} ; do \ | |
562 ## case `(cd $${dir} ; $(pwd))` in \ | |
563 ## `(cd ${srcdir} ; $(pwd))`* ) ;; \ | |
564 ## * ) $(RM) $${dir} ;; \ | |
565 ## esac ; \ | |
566 ## case $${dir} in \ | |
567 ## ${datadir}/${PROGNAME}/${version}/* ) \ | |
568 ## $(RM) -r ${datadir}/${PROGNAME}/${version} \ | |
569 ## ;; \ | |
570 ## esac ; \ | |
571 ## done | |
572 ## cd ${infodir} && $(RM) cl* ${PROGNAME}* forms* info* vip* | |
573 ## cd ${mandir} && $(RM) xemacs.1 etags.1 ctags.1 gnuserv.1 | |
574 ## cd ${bindir} && $(RM) ${PROGNAME}-${version} ${PROGNAME} | |
575 | |
576 | |
577 ## Some makes seem to remember that they've built something called FRC, | |
578 ## so you can only use a given FRC once per makefile. | |
579 FRC FRC.src.paths.h FRC.mkdir FRC.dump-elcs FRC.info: | |
3062 | 580 FRC.mostlyclean FRC.clean FRC.distclean FRC.realclean FRC.extraclean FRC.tags: |
581 FRC.distclean-noconfig FRC.realclean-noconfig FRC.extraclean-noconfig: | |
380 | 582 |
583 ## ==================== Cleaning up and miscellanea ==================== | |
584 | |
3062 | 585 .PHONY: mostlyclean clean distclean realclean extraclean elcclean |
586 .PHONY: distclean-noconfig realclean-noconfig extraclean-noconfig | |
587 .PHONY: top-mostlyclean top-clean top-distclean top-realclean top-extraclean | |
588 .PHONY: top-distclean-noconfig top-realclean-noconfig top-extraclean-noconfig | |
380 | 589 |
590 ## `mostlyclean' | |
591 ## Like `clean', but may refrain from deleting a few files that people | |
592 ## normally don't want to recompile. For example, the `mostlyclean' | |
593 ## target for GCC does not delete `libgcc.a', because recompiling it | |
594 ## is rarely necessary and takes a lot of time. | |
3062 | 595 top-mostlyclean: FRC.mostlyclean |
3083 | 596 -$(RM) core |
3062 | 597 |
598 mostlyclean: top-mostlyclean | |
2427 | 599 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done |
380 | 600 |
601 ## `clean' | |
602 ## Delete all files from the current directory that are normally | |
603 ## created by building the program. Don't delete the files that | |
604 ## record the configuration. Also preserve files that could be made | |
605 ## by building, but normally aren't because the distribution comes | |
606 ## with them. | |
607 | |
608 ## Delete `.dvi' files here if they are not part of the distribution. | |
1889 | 609 |
610 ## Remove the generated load files here; they cause lots of problems | |
611 ## when they don't work right. (beta can't depend on distclean, which | |
612 ## removes necessary files generated by configure.) | |
3062 | 613 top-clean: FRC.clean |
3083 | 614 -$(RM) core lisp/auto-autoloads.el* lisp/custom-load.el* |
615 -$(RM) lisp/mule/auto-autoloads.el* lisp/mule/custom-load.el* | |
616 -$(RM) modules/auto-autoloads.el* modules/custom-load.el* | |
617 -$(RM) etc/PROBLEMS | |
380 | 618 |
3062 | 619 clean: top-mostlyclean top-clean |
620 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done | |
621 | |
622 ## `distclean-noconfig' | |
623 ## Like `distclean' but don't delete files created by `configure'. | |
624 top-distclean-noconfig: FRC.distclean-noconfig | |
3083 | 625 -$(RM) TAGS .sbinit lock/* lisp/finder-inf.el* |
3062 | 626 |
627 distclean-noconfig: top-mostlyclean top-clean top-distclean-noconfig | |
628 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done | |
629 | |
380 | 630 ## `distclean' |
631 ## Delete all files from the current directory that are created by | |
632 ## configuring or building the program. If you have unpacked the | |
633 ## source and built the program without creating any other files, | |
634 ## `make distclean' should leave only the files that were in the | |
635 ## distribution. | |
3062 | 636 top-distclean: FRC.distclean |
3083 | 637 -$(RM) config.status config.log confdefs.h config-tmp-* build-install Installation |
638 -$(RM) GNUmakefile Makefile Makefile.in | |
639 -$(RM) Installation.el Installation.elc | |
3062 | 640 |
641 distclean: top-mostlyclean top-clean top-distclean-noconfig top-distclean | |
642 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done | |
380 | 643 |
3062 | 644 ## `realclean-noconfig' |
645 ## Delete everything that can be reconstructed by `make'. Don't delete | |
646 ## anything requiring reconfiguration. | |
647 top-realclean-noconfig: FRC.realclean-noconfig | |
3083 | 648 -$(RM) *.elc lisp/*.elc lisp/mule/*.elc lisp/term/*.elc modules/*.elc |
3062 | 649 |
650 realclean-noconfig: top-mostlyclean top-clean top-distclean-noconfig top-realclean-noconfig | |
2427 | 651 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done |
3062 | 652 |
653 top-realclean: FRC.realclean | |
654 | |
655 elcclean: realclean-noconfig | |
380 | 656 |
657 ## `realclean' | |
658 ## Delete everything from the current directory that can be | |
659 ## reconstructed with this Makefile. This typically includes | |
660 ## everything deleted by distclean, plus more: C source files | |
661 ## produced by Bison, tags tables, info files, and so on. | |
662 | |
663 ## One exception, however: `make realclean' should not delete | |
664 ## `configure' even if `configure' can be remade using a rule in the | |
665 ## Makefile. More generally, `make realclean' should not delete | |
666 ## anything that needs to exist in order to run `configure' and then | |
667 ## begin to build the program. | |
3062 | 668 realclean: top-mostlyclean top-clean top-distclean-noconfig top-distclean top-realclean-noconfig top-realclean |
2427 | 669 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done |
3062 | 670 |
671 ## `extraclean-noconfig' | |
672 ## Like `extraclean' but don't delete anything requiring reconfiguration. | |
673 top-extraclean-noconfig: FRC.extraclean-noconfig | |
3083 | 674 -$(RM) *~ \#* |
3062 | 675 |
676 extraclean-noconfig: top-mostlyclean top-clean top-distclean-noconfig top-realclean-noconfig top-extraclean-noconfig | |
677 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done | |
380 | 678 |
679 ## This doesn't actually appear in the coding standards, but Karl | |
680 ## says GCC supports it, and that's where the configuration part of | |
681 ## the coding standards seem to come from. It's like distclean, but | |
682 ## it deletes backup and autosave files too. | |
3062 | 683 top-extraclean: FRC.extraclean |
684 | |
685 extraclean: top-mostlyclean top-clean top-distclean-noconfig top-distclean top-realclean-noconfig top-realclean top-extraclean-noconfig top-extraclean | |
2427 | 686 for d in $(SUBDIR); do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done |
380 | 687 |
688 ## Unlocking and relocking. The idea of these productions is to reduce | |
689 ## hassles when installing an incremental tar of XEmacs. Do `make unlock' | |
690 ## before unlocking the file to take the write locks off all sources so | |
691 ## that tar xvof will overwrite them without fuss. Then do `make relock' | |
692 ## afterward so that VC mode will know which files should be checked in | |
693 ## if you want to mung them. | |
694 | |
695 ## Note: it's no disaster if these productions miss a file or two; tar | |
696 ## and VC will swiftly let you know if this happens, and it is easily | |
697 ## corrected. | |
2536 | 698 SOURCES = ChangeLog INSTALL Makefile.in.in PROBLEMS \ |
380 | 699 README build-install.in configure make-dist move-if-change |
700 | |
1314 | 701 .PHONY: unlock relock TAGS tags dist info dvi mcs |
380 | 702 |
703 unlock: | |
704 chmod u+w $(SOURCES) cpp/* | |
705 -cd ./elisp && chmod u+w Makefile README *.texi | |
2427 | 706 for d in src etc lib-src lisp; do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done |
380 | 707 cd ./lisp/term && chmod u+w README *.el |
708 cd ./man && chmod u+w *texi* ChangeLog split-man | |
709 cd ./lwlib && chmod u+w *.[ch] Makefile.in.in | |
710 | |
711 relock: | |
712 chmod u-w $(SOURCES) cpp/* | |
713 -cd ./elisp && chmod u-w Makefile README *.texi | |
2427 | 714 for d in src etc lib-src lisp; do (cd ./$$d && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@); done |
380 | 715 cd ./lisp/term && chmod u+w README *.el |
716 cd ./man && chmod u+w *texi* ChangeLog split-man | |
717 cd ./lwlib && chmod u+w *.[ch] Makefile.in.in | |
718 | |
719 PRUNE_VC = -name SCCS -prune -o -name RCS -prune -o -name CVS -prune -o | |
720 tagslisp = lisp | |
721 TAGS tags: FRC.tags | |
722 @echo "If you don't have a copy of etags around, then do 'make lib-src' first." | |
3083 | 723 -$(RM) ${srcdir}/TAGS |
380 | 724 @PATH=`$(pwd)`/lib-src:$$PATH HOME=/-=-; export PATH HOME; \ |
725 echo "Using etags from `which etags`." | |
726 PATH=`$(pwd)`/lib-src:$$PATH ; export PATH; cd ${srcdir} && \ | |
1011 | 727 find src lwlib lib-src modules ${PRUNE_VC} -name '*.[ch]' -print | \ |
1441 | 728 xargs etags -a \ |
729 -r '/[ ]*DEF\(VAR\|INE\)_[A-Z_]+[ ]*([ ]*"\([^"]+\)"/\2/' \ | |
730 -r '/^DEFUN[ ]*([ ]*"\([^"]+\)"[ ]*,[ ]*\([A-Za-z0-9_]+\)/\2/'; \ | |
380 | 731 find ${tagslisp} ${PRUNE_VC} -name '*.el' ! -name 'auto-autoloads.el' -print | \ |
732 xargs etags -a -l none -r "/^(def\\(var\\|un\\|alias\\|const\\|macro\\|subst\\|struct\\|face\\|group\\|custom\\|ine-\\(function\\|compiler-macro\\|[a-z-]+alias\\)\\)[ ]+'?\\([^ ]+\\)/\\3/" | |
733 | |
734 info: FRC.info | |
2427 | 735 cd ${srcdir}/man && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@ |
380 | 736 |
737 dvi: | |
2427 | 738 cd ${srcdir}/man && $(MAKE) $(RECURSIVE_MAKE_ARGS) $@ |
380 | 739 |
740 ## Fix up version information in executables (Solaris-only) | |
741 mcs: | |
742 date=`LANG=C LC_ALL=C date -u '+%e %b %Y'`; \ | |
743 ident="@(#)RELEASE VERSION XEmacs ${version} $${date}"; \ | |
744 for f in `file lib-src/* src/${PROGNAME} | grep ELF | sed -e 's/:.*//'`; do \ | |
745 mcs -da "$${ident} `echo $${f} | sed 's/.*\///'`" $${f}; \ | |
746 done | |
4850
2727d0d8ef07
Fix executable permissions on source files
Ben Wing <ben@xemacs.org>
parents:
4759
diff
changeset
|
747 |
2727d0d8ef07
Fix executable permissions on source files
Ben Wing <ben@xemacs.org>
parents:
4759
diff
changeset
|
748 ## Fix up permissions on source/build files |
2727d0d8ef07
Fix executable permissions on source files
Ben Wing <ben@xemacs.org>
parents:
4759
diff
changeset
|
749 .PHONY: fix-perms |
2727d0d8ef07
Fix executable permissions on source files
Ben Wing <ben@xemacs.org>
parents:
4759
diff
changeset
|
750 FRC.fix-perms: |
2727d0d8ef07
Fix executable permissions on source files
Ben Wing <ben@xemacs.org>
parents:
4759
diff
changeset
|
751 fix-perms: FRC.fix-perms |
2727d0d8ef07
Fix executable permissions on source files
Ben Wing <ben@xemacs.org>
parents:
4759
diff
changeset
|
752 cd ${srcdir} && sh lib-src/fix-perms.sh |