Mercurial > hg > xemacs-beta
annotate nt/xemacs.mak @ 4719:bd51ab22afa8
Make it possible to silence warnings issued when #'mapcar's result is discarded.
lisp/ChangeLog addition:
2009-10-19 Aidan Kehoe <kehoea@parhasard.net>
* bytecomp.el (byte-compile-default-warnings):
Add two new warning types, discarded-consing (basically use of
mapcar instead of mapc where its result is discarded) and
quoted-lambda (use of a lambda expression quoted as data in a
function context).
(byte-compile-warnings): Document the new warnings.
(byte-compile-fset, byte-compile-funarg): Implement the
quoted-lambda warning option.
(byte-compile-mapcar): Renamed to byte-compile-maybe-mapc.
(byte-compile-maybe-mapc, byte-compile-maplist):
Implement the discarded-consing warning option.
Add more functions that should be compiled using
byte-compile-funarg, notably mapvector, mapc-internal,
map-char-table.
* cl-macs.el (mapcar*):
If we know at compile time that there are no CL options being
used, use the mapcar subr, not the byte-coded function.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Mon, 19 Oct 2009 12:47:21 +0100 |
parents | 985886265686 |
children | 80d74fed5399 |
rev | line source |
---|---|
795 | 1 # Makefile for Microsoft NMAKE -*- Makefile -*- |
2 # | |
428 | 3 # Copyright (C) 1995 Board of Trustees, University of Illinois. |
2951 | 4 # Copyright (C) 1995, 1996, 2000, 2001, 2002, 2003, 2004, 2005 Ben Wing. |
795 | 5 # Copyright (C) 1997, 1998, 2000 Jonathan Harris. |
428 | 6 # Copyright (C) 1995 Sun Microsystems, Inc. |
7 # Copyright (C) 1998 Free Software Foundation, Inc. | |
8 # | |
9 # This file is part of XEmacs. | |
10 # | |
11 # XEmacs is free software; you can redistribute it and/or modify it | |
12 # under the terms of the GNU General Public License as published by the | |
13 # Free Software Foundation; either version 2, or (at your option) any | |
14 # later version. | |
15 # | |
16 # XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
17 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
18 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
19 # for more details. | |
20 # | |
21 # You should have received a copy of the GNU General Public License | |
22 # along with XEmacs; see the file COPYING. If not, write to | |
23 # the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
24 # Boston, MA 02111-1307, USA. | |
25 # | |
26 # Synched up with: Not in FSF. | |
27 # | |
28 | |
442 | 29 default: all |
30 | |
444 | 31 # APA: Since there seems to be no way to determine the directory where |
32 # xemacs.mak is located (from within nmake) we just insist on the user | |
33 # to invoke nmake in the directory where xemacs.mak is. | |
34 !if !exist("$(MAKEDIR)\xemacs.mak") | |
35 !error Please run nmake from the directory of this makefile (xemacs\nt). | |
36 !endif | |
37 | |
1330 | 38 MAKEROOT=$(MAKEDIR:\nt=) |
442 | 39 |
1330 | 40 ########################### Common commands. |
428 | 41 |
1330 | 42 # Put these before including config.inc so they can be overridden there. |
637 | 43 # Note that some versions of some commands are deficient. |
428 | 44 |
2106 | 45 # Define a variable for the 'del' command to use. |
637 | 46 # WinME's DEL command can only handle one argument and only has the /P flag. |
47 # So only delete one glob at a time. Override flags in config.inc. | |
2106 | 48 DEL=-del |
637 | 49 |
1001 | 50 # Tell COPY, MOVE, and XCOPY to suppress confirmation for overwriting |
51 # files. | |
2106 | 52 COPYCMD=/y |
1001 | 53 # Define the 'copy' command to use. |
2106 | 54 COPY=xcopy /q |
55 COPYDIR=xcopy /q /e | |
583 | 56 |
1330 | 57 ########################### Includes, and source and build tree determination. |
442 | 58 |
59 !include "config.inc" | |
428 | 60 |
1330 | 61 !if defined(BUILD_DIR) |
62 SEPARATE_BUILD=1 | |
63 SRCROOT=$(MAKEROOT) | |
64 BLDROOT=$(BUILD_DIR) | |
65 !else | |
66 !if defined(SOURCE_DIR) | |
67 SEPARATE_BUILD=1 | |
68 SRCROOT=$(SOURCE_DIR) | |
69 BLDROOT=$(MAKEROOT) | |
70 !else | |
71 SEPARATE_BUILD=0 | |
72 SRCROOT=$(MAKEROOT) | |
73 BLDROOT=$(MAKEROOT) | |
74 !endif | |
75 !endif | |
76 | |
4419
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
77 !if [copy $(SRCROOT)\version.sh.in $(SRCROOT)\version.sh] |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
78 !endif |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
79 !if exist($(SRCROOT)\.hg) |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
80 !if [hg identify >> $(SRCROOT)\version.sh] |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
81 !endif |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
82 !endif |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
83 |
1330 | 84 # Program name and version |
85 !include "$(SRCROOT)\version.sh" | |
86 | |
87 ########################### Basic vars referring to directories, both in | |
88 ########################### the source and build trees. | |
89 | |
90 LISP=$(SRCROOT)\lisp | |
91 LIB_SRC=$(SRCROOT)\lib-src | |
92 NT=$(SRCROOT)\nt | |
93 SRC=$(SRCROOT)\src | |
94 ETC=$(SRCROOT)\etc | |
1346 | 95 INFO=$(SRCROOT)\info |
1330 | 96 |
97 BLDLIB_SRC=$(BLDROOT)\lib-src | |
98 BLDNT=$(BLDROOT)\nt | |
99 OUTDIR=$(BLDNT)\obj | |
100 BLDSRC=$(BLDROOT)\src | |
101 | |
102 # This appears in the dependency file | |
103 LWLIB_SRCDIR=$(SRCROOT)\lwlib | |
104 | |
2951 | 105 ########################### Figure out current version of VC++. |
106 | |
3054 | 107 !if [if not exist $(OUTDIR) mkdir "$(OUTDIR)"] |
108 !endif | |
2951 | 109 !if [echo MSC_VER=_MSC_VER > $(OUTDIR)\vcversion.c] |
110 !endif | |
111 !if [cl /nologo /EP $(OUTDIR)\vcversion.c > $(OUTDIR)\vcversion.tmp] | |
112 !endif | |
113 !include "$(OUTDIR)\vcversion.tmp" | |
114 | |
1330 | 115 ########################### Process the config.inc options. |
116 | |
428 | 117 !if !defined(INFODOCK) |
118 INFODOCK=0 | |
119 !endif | |
771 | 120 !if !defined(MULE) |
121 MULE=0 | |
428 | 122 !endif |
442 | 123 !if !defined(HAVE_MS_WINDOWS) |
124 HAVE_MS_WINDOWS=1 | |
428 | 125 !endif |
126 !if !defined(HAVE_XPM) | |
127 HAVE_XPM=0 | |
128 !endif | |
129 !if !defined(HAVE_PNG) | |
130 HAVE_PNG=0 | |
131 !endif | |
632 | 132 !if !defined(HAVE_ZLIB) |
133 HAVE_ZLIB=$(HAVE_PNG) | |
134 !endif | |
428 | 135 !if !defined(HAVE_TIFF) |
136 HAVE_TIFF=0 | |
137 !endif | |
138 !if !defined(HAVE_JPEG) | |
139 HAVE_JPEG=0 | |
140 !endif | |
141 !if !defined(HAVE_XFACE) | |
142 HAVE_XFACE=0 | |
143 !endif | |
144 !if !defined(HAVE_GIF) | |
4708
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4603
diff
changeset
|
145 HAVE_GIF=0 |
428 | 146 !endif |
488 | 147 !if !defined(HAVE_GTK) |
148 HAVE_GTK=0 | |
149 !endif | |
827 | 150 !if !defined(HAVE_MENUBARS) |
151 HAVE_MENUBARS=1 | |
152 !endif | |
153 !if !defined(HAVE_SCROLLBARS) | |
154 HAVE_SCROLLBARS=1 | |
155 !endif | |
428 | 156 !if !defined(HAVE_TOOLBARS) |
157 HAVE_TOOLBARS=$(HAVE_XPM) | |
158 !endif | |
159 !if !defined(HAVE_DIALOGS) | |
160 HAVE_DIALOGS=1 | |
161 !endif | |
162 !if !defined(HAVE_NATIVE_SOUND) | |
163 HAVE_NATIVE_SOUND=1 | |
164 !endif | |
165 !if !defined(HAVE_WIDGETS) | |
166 HAVE_WIDGETS=1 | |
167 !endif | |
2951 | 168 !if !defined(HAVE_DATABASE) |
169 HAVE_DATABASE=0 | |
170 !endif | |
171 !if !defined(BUILD_DATABASE_SHARED) | |
172 BUILD_DATABASE_SHARED=0 | |
173 !endif | |
174 !if !defined(HAVE_POSTGRESQL) | |
175 HAVE_POSTGRESQL=0 | |
176 !endif | |
177 !if !defined(HAVE_LDAP) | |
178 HAVE_LDAP=0 | |
179 !endif | |
180 !if !defined(HAVE_BIGNUM) | |
181 HAVE_BIGNUM=0 | |
182 !endif | |
3034 | 183 !if !defined(BUILD_BIGNUM_MINGW_SHARED) |
184 BUILD_BIGNUM_MINGW_SHARED=0 | |
185 !endif | |
186 !if !defined(BUILD_BIGNUM_NATIVE_SHARED) | |
187 BUILD_BIGNUM_NATIVE_SHARED=0 | |
188 !endif | |
872 | 189 !if !defined(OPTIMIZED_BUILD) |
190 OPTIMIZED_BUILD=1 | |
191 !endif | |
192 !if !defined(USE_FASTCALL) | |
193 # #### Change to 1 when I check in the ws with support for fastcall | |
194 USE_FASTCALL=0 | |
195 !endif | |
196 !if !defined(PROFILE_SUPPORT) | |
197 PROFILE_SUPPORT=0 | |
198 !endif | |
428 | 199 !if !defined(DEBUG_XEMACS) |
200 DEBUG_XEMACS=0 | |
201 !endif | |
1333 | 202 !if !defined(SUPPORT_EDIT_AND_CONTINUE) |
203 SUPPORT_EDIT_AND_CONTINUE=0 | |
834 | 204 !endif |
4405
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
205 !if !defined(BUILD_FOR_SETUP_KIT) |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
206 BUILD_FOR_SETUP_KIT=0 |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
207 !endif |
1203 | 208 |
4405
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
209 !if !$(BUILD_FOR_SETUP_KIT) |
3741 | 210 OK_TO_USE_MSVCRTD=1 |
211 !else | |
212 OK_TO_USE_MSVCRTD=0 | |
213 !endif | |
214 | |
800 | 215 !if !defined(ERROR_CHECK_ALL) |
1203 | 216 !if "$(emacs_is_beta)" != "" |
800 | 217 ERROR_CHECK_ALL=1 |
1203 | 218 !else |
219 ERROR_CHECK_ALL=0 | |
220 !endif | |
221 !endif | |
222 | |
223 !if !defined(CPLUSPLUS_COMPILE) | |
224 !if $(ERROR_CHECK_ALL) | |
225 CPLUSPLUS_COMPILE=1 | |
226 !else | |
227 CPLUSPLUS_COMPILE=0 | |
228 !endif | |
229 !endif | |
230 | |
231 !if !defined(USE_KKCC) | |
232 USE_KKCC=0 | |
233 !endif | |
3092 | 234 !if !defined(NEW_GC) |
235 NEW_GC=0 | |
236 !endif | |
1203 | 237 !if !defined(USE_UNION_TYPE) |
238 USE_UNION_TYPE=0 | |
800 | 239 !endif |
442 | 240 !if !defined(QUICK_BUILD) |
241 QUICK_BUILD=0 | |
242 !endif | |
872 | 243 !if !defined(VERBOSECC) |
244 VERBOSECC=0 | |
245 !endif | |
246 !if !defined(DEPEND) | |
247 DEPEND=0 | |
248 !endif | |
249 !if !defined(USE_PORTABLE_DUMPER) | |
250 USE_PORTABLE_DUMPER=1 | |
251 !endif | |
438 | 252 !if !defined(USE_MINITAR) |
632 | 253 USE_MINITAR=$(HAVE_ZLIB) |
438 | 254 !endif |
428 | 255 |
440 | 256 # A little bit of adhockery. Default to use system malloc and |
257 # DLL version of the C runtime library when using portable | |
258 # dumping. These are the optimal settings. | |
2500 | 259 # |
260 # NOTE: The various graphics libraries are generally compiled to use | |
261 # MSVCRT.DLL (the same that we use in USE_CRTDLL, more or less), so using | |
262 # this is a good thing. | |
263 | |
440 | 264 !if !defined(USE_SYSTEM_MALLOC) |
265 USE_SYSTEM_MALLOC=$(USE_PORTABLE_DUMPER) | |
266 !endif | |
267 !if !defined(USE_CRTDLL) | |
268 USE_CRTDLL=$(USE_PORTABLE_DUMPER) | |
269 !endif | |
270 | |
1330 | 271 ########################### Check for incompatible options. |
428 | 272 |
273 CONFIG_ERROR=0 | |
274 !if $(INFODOCK) && !exist("..\..\Infodock.rules") | |
275 !message Cannot build InfoDock without InfoDock sources | |
276 CONFIG_ERROR=1 | |
277 !endif | |
440 | 278 !if !$(USE_PORTABLE_DUMPER) && $(USE_SYSTEM_MALLOC) |
279 !message Cannot use system allocator when dumping old way, use portable dumper. | |
280 CONFIG_ERROR=1 | |
281 !endif | |
282 !if !$(USE_PORTABLE_DUMPER) && $(USE_CRTDLL) | |
283 !message Cannot use C runtime DLL when dumping old way, use portable dumper. | |
284 CONFIG_ERROR=1 | |
285 !endif | |
286 !if !$(USE_SYSTEM_MALLOC) && $(USE_CRTDLL) | |
287 !message GNU malloc currently cannot be used with CRT DLL. | |
288 !message [[[Developer note: If you want to fix it, read Q112297 first]]] #### | |
289 CONFIG_ERROR=1 | |
290 !endif | |
1330 | 291 !if !$(HAVE_MS_WINDOWS) && !$(HAVE_GTK) |
292 !message Please specify at least one HAVE_MS_WINDOWS=1 and/or HAVE_GTK=1 | |
428 | 293 CONFIG_ERROR=1 |
294 !endif | |
488 | 295 !if $(HAVE_MS_WINDOWS) && $(HAVE_GTK) && !defined(GTK_DIR) |
296 !message Please specify root directory for your GTK installation: GTK_DIR=path | |
297 CONFIG_ERROR=1 | |
298 !endif | |
2951 | 299 |
442 | 300 !if $(HAVE_MS_WINDOWS) && $(HAVE_XPM) && !defined(XPM_DIR) |
428 | 301 !message Please specify root directory for your XPM installation: XPM_DIR=path |
302 CONFIG_ERROR=1 | |
303 !endif | |
442 | 304 !if $(HAVE_MS_WINDOWS) && $(HAVE_XPM) && defined(XPM_DIR) && !exist("$(XPM_DIR)\lib\Xpm.lib") |
428 | 305 !message Specified XPM directory does not contain "$(XPM_DIR)\lib\Xpm.lib" |
306 CONFIG_ERROR=1 | |
307 !endif | |
2951 | 308 |
442 | 309 !if $(HAVE_MS_WINDOWS) && $(HAVE_PNG) && !defined(PNG_DIR) |
428 | 310 !message Please specify root directory for your PNG installation: PNG_DIR=path |
311 CONFIG_ERROR=1 | |
312 !endif | |
442 | 313 !if $(HAVE_MS_WINDOWS) && $(HAVE_PNG) && defined(PNG_DIR) && !exist("$(PNG_DIR)\libpng.lib") |
428 | 314 !message Specified PNG directory does not contain "$(PNG_DIR)\libpng.lib" |
315 CONFIG_ERROR=1 | |
316 !endif | |
2951 | 317 |
442 | 318 !if $(HAVE_MS_WINDOWS) && $(HAVE_PNG) && !defined(ZLIB_DIR) |
428 | 319 !message Please specify root directory for your ZLIB installation: ZLIB_DIR=path |
320 CONFIG_ERROR=1 | |
321 !endif | |
442 | 322 !if $(HAVE_MS_WINDOWS) && $(HAVE_PNG) && defined(ZLIB_DIR) && !exist("$(ZLIB_DIR)\zlib.lib") |
428 | 323 !message Specified ZLIB directory does not contain "$(ZLIB_DIR)\zlib.lib" |
324 CONFIG_ERROR=1 | |
325 !endif | |
2951 | 326 |
442 | 327 !if $(HAVE_MS_WINDOWS) && $(HAVE_TIFF) && !defined(TIFF_DIR) |
428 | 328 !message Please specify root directory for your TIFF installation: TIFF_DIR=path |
329 CONFIG_ERROR=1 | |
330 !endif | |
442 | 331 !if $(HAVE_MS_WINDOWS) && $(HAVE_TIFF) && !exist("$(TIFF_DIR)\libtiff\libtiff.lib") |
428 | 332 !message Specified TIFF directory does not contain "$(TIFF_DIR)\libtiff\libtiff.lib" |
333 CONFIG_ERROR=1 | |
334 !endif | |
2951 | 335 |
442 | 336 !if $(HAVE_MS_WINDOWS) && $(HAVE_JPEG) && !defined(JPEG_DIR) |
428 | 337 !message Please specify root directory for your JPEG installation: JPEG_DIR=path |
338 CONFIG_ERROR=1 | |
339 !endif | |
442 | 340 !if $(HAVE_MS_WINDOWS) && $(HAVE_JPEG) && !exist("$(JPEG_DIR)\libjpeg.lib") |
428 | 341 !message Specified JPEG directory does not contain "$(JPEG_DIR)\libjpeg.lib" |
342 CONFIG_ERROR=1 | |
343 !endif | |
2951 | 344 |
442 | 345 !if $(HAVE_MS_WINDOWS) && $(HAVE_XFACE) && !defined(COMPFACE_DIR) |
428 | 346 !message Please specify root directory for your COMPFACE installation: COMPFACE_DIR=path |
347 CONFIG_ERROR=1 | |
348 !endif | |
442 | 349 !if $(HAVE_MS_WINDOWS) && $(HAVE_XFACE) && !exist("$(COMPFACE_DIR)\libcompface.lib") |
428 | 350 !message Specified COMPFACE directory does not contain "$(COMPFACE_DIR)\libcompface.lib" |
351 CONFIG_ERROR=1 | |
352 !endif | |
2951 | 353 |
442 | 354 !if $(HAVE_MS_WINDOWS) && $(HAVE_TOOLBARS) && !$(HAVE_XPM) |
428 | 355 !message Toolbars require XPM support |
356 CONFIG_ERROR=1 | |
357 !endif | |
2951 | 358 |
359 !if $(HAVE_MS_WINDOWS) && $(HAVE_BIGNUM) && !defined(BIGNUM_DIR) | |
360 !message Please specify root directory for your BIGNUM installation: BIGNUM_DIR=path | |
361 CONFIG_ERROR=1 | |
362 !endif | |
363 !if $(HAVE_MS_WINDOWS) && $(HAVE_BIGNUM) && defined(BIGNUM_DIR) | |
364 !if $(BUILD_BIGNUM_MINGW_SHARED) | |
365 !if !exist("$(BIGNUM_DIR)\libgmp-3.lib") | |
366 !message Specified BIGNUM directory does not contain "$(BIGNUM_DIR)\libgmp-3.lib" | |
367 CONFIG_ERROR=1 | |
368 !endif | |
369 !else | |
370 !if $(BUILD_BIGNUM_NATIVE_SHARED) | |
371 !if !exist("$(BIGNUM_DIR)\gmp-dynamic\gmp.lib") | |
372 !message Specified BIGNUM directory does not contain "$(BIGNUM_DIR)\gmp-dynamic\gmp.lib" | |
373 CONFIG_ERROR=1 | |
374 !endif | |
375 !else | |
376 !if !exist("$(BIGNUM_DIR)\gmp-static\gmp.lib") | |
377 !message Specified BIGNUM directory does not contain "$(BIGNUM_DIR)\gmp-static\gmp.lib" | |
378 CONFIG_ERROR=1 | |
379 !endif | |
380 !endif | |
381 !endif | |
382 !endif | |
383 | |
384 !if $(HAVE_MS_WINDOWS) && $(HAVE_DATABASE) && !defined(DATABASE_DIR) | |
385 !message Please specify root directory for your DATABASE installation: DATABASE_DIR=path | |
386 CONFIG_ERROR=1 | |
387 !endif | |
388 !if $(HAVE_MS_WINDOWS) && $(HAVE_DATABASE) && defined(DATABASE_DIR) | |
389 !if $(BUILD_DATABASE_SHARED) | |
390 !if !exist("$(DATABASE_DIR)\build_win32\Release\libdb43.lib") | |
391 !message Specified DATABASE directory does not contain "$(DATABASE_DIR)\build_win32\Release\libdb43.lib" | |
392 CONFIG_ERROR=1 | |
393 !endif | |
394 !else | |
395 !if !exist("$(DATABASE_DIR)\build_win32\Release_static\libdb43s.lib") | |
396 !message Specified DATABASE directory does not contain "$(DATABASE_DIR)\build_win32\Release_static\libdb43s.lib" | |
397 CONFIG_ERROR=1 | |
398 !endif | |
399 !endif | |
400 !endif | |
401 | |
402 !if $(HAVE_MS_WINDOWS) && $(HAVE_POSTGRESQL) && !defined(POSTGRESQL_DIR) | |
403 !message Please specify root directory for your POSTGRESQL installation: POSTGRESQL_DIR=path | |
404 CONFIG_ERROR=1 | |
405 !endif | |
406 !if $(HAVE_MS_WINDOWS) && $(HAVE_POSTGRESQL) && defined(POSTGRESQL_DIR) && !exist("$(POSTGRESQL_DIR)\src\interfaces\libpq\Release\libpq.lib") | |
407 !message Specified POSTGRESQL directory does not contain "$(POSTGRESQL_DIR)\src\interfaces\libpq\Release\libpq.lib" | |
408 CONFIG_ERROR=1 | |
409 !endif | |
410 !if $(HAVE_MS_WINDOWS) && $(HAVE_LDAP) && !defined(LDAP_DIR) | |
411 !message Please specify root directory for your LDAP installation: LDAP_DIR=path | |
412 CONFIG_ERROR=1 | |
413 !endif | |
414 !if $(HAVE_MS_WINDOWS) && $(HAVE_LDAP) && defined(LDAP_DIR) && !exist("$(LDAP_DIR)\openldap.lib") | |
415 !message Specified LDAP directory does not contain "$(LDAP_DIR)\openldap.lib" | |
416 CONFIG_ERROR=1 | |
417 !endif | |
428 | 418 !if $(CONFIG_ERROR) |
419 !error Configuration error(s) found | |
420 !endif | |
421 | |
1330 | 422 ########################### Set version strings. |
423 | |
424 !if $(INFODOCK) | |
425 INFODOCK_VERSION_STRING=$(infodock_major_version).$(infodock_minor_version).$(infodock_build_version) | |
426 PROGRAM_DEFINES=-DINFODOCK \ | |
427 -DPATH_VERSION=\"$(INFODOCK_VERSION_STRING)\" \ | |
428 -DPATH_PROGNAME=\"infodock\" \ | |
429 -DEMACS_PROGNAME=\"infodock\" \ | |
4458
d9b9b5f90386
Provide SHEBANG_PROGNAME on Win32; correct a bug with it and string concat'ing
Aidan Kehoe <kehoea@parhasard.net>
parents:
4419
diff
changeset
|
430 -DSHEBANG_PROGNAME=\"infodock-script\" \ |
1330 | 431 -DEMACS_VERSION=\"$(INFODOCK_VERSION_STRING)\" \ |
432 -DINFODOCK_MAJOR_VERSION=$(infodock_major_version) \ | |
433 -DINFODOCK_MINOR_VERSION=$(infodock_minor_version) \ | |
434 -DINFODOCK_BUILD_VERSION=$(infodock_build_version) | |
435 !else | |
436 XEMACS_VERSION_STRING=$(emacs_major_version).$(emacs_minor_version) | |
437 !if "$(emacs_beta_version)" != "" | |
438 !if "$(emacs_is_beta)" != "" | |
439 XEMACS_VERSION_STRING=$(XEMACS_VERSION_STRING)-b$(emacs_beta_version) | |
440 !else | |
441 XEMACS_VERSION_STRING=$(XEMACS_VERSION_STRING).$(emacs_beta_version) | |
442 !endif | |
443 !endif | |
444 PROGRAM_DEFINES= \ | |
445 -DPATH_VERSION=\"$(XEMACS_VERSION_STRING)\" \ | |
446 -DPATH_PROGNAME=\"xemacs\" \ | |
447 -DEMACS_VERSION=\"$(XEMACS_VERSION_STRING)\" \ | |
4458
d9b9b5f90386
Provide SHEBANG_PROGNAME on Win32; correct a bug with it and string concat'ing
Aidan Kehoe <kehoea@parhasard.net>
parents:
4419
diff
changeset
|
448 -DEMACS_PROGNAME=\"xemacs\" -DSHEBANG_PROGNAME=\"xemacs-script\" |
1330 | 449 !endif |
450 | |
451 ########################### Set up installation and package directories. | |
452 | |
453 !if !defined(INSTALL_DIR) | |
454 ! if $(INFODOCK) | |
455 INSTALL_DIR=c:\Program Files\Infodock\Infodock-$(INFODOCK_VERSION_STRING) | |
456 ! else | |
457 INSTALL_DIR=c:\Program Files\XEmacs\XEmacs-$(XEMACS_VERSION_STRING) | |
442 | 458 ! endif |
1330 | 459 !endif |
3281 | 460 |
461 # If PACKAGE_PREFIX was defined, use it to generate a package path. | |
462 !if defined(PACKAGE_PREFIX) | |
463 PATH_LATE_PACKAGE_DIRECTORIES="$(PACKAGE_PREFIX:\=\\)" | |
442 | 464 !endif |
1330 | 465 |
466 !if $(INFODOCK) | |
467 PATH_PREFIX=../.. | |
468 !else | |
4413
dc84ec90b463
Fix build problems on Windows.
Mike Sperber <sperber@deinprogramm.de>
parents:
4405
diff
changeset
|
469 PATH_PREFIX="$(INSTALL_DIR)" |
1330 | 470 !endif |
471 | |
4413
dc84ec90b463
Fix build problems on Windows.
Mike Sperber <sperber@deinprogramm.de>
parents:
4405
diff
changeset
|
472 PATH_DEFINES=-DPATH_PREFIX=\"$(PATH_PREFIX:\=\\)\" |
1330 | 473 |
474 !if $(SEPARATE_BUILD) | |
1346 | 475 PATH_DEFINES=$(PATH_DEFINES) -DPATH_LOADSEARCH=\"$(LISP:\=\\)\" -DPATH_DATA=\"$(ETC:\=\\)\" -DPATH_INFO=\"$(INFO:\=\\)\" |
1330 | 476 !endif |
477 | |
478 ########################### Determine system configuration. | |
479 | |
480 !if !defined(OS) | |
481 OS=Windows_95/98 | |
482 EMACS_CONFIGURATION=i586-pc-win32 | |
483 !else if "$(PROCESSOR_ARCHITECTURE)" == "x86" | |
484 EMACS_CONFIGURATION=i586-pc-win32 | |
485 !else if "$(PROCESSOR_ARCHITECTURE)" == "MIPS" | |
486 EMACS_CONFIGURATION=mips-pc-win32 | |
487 !else if "$(PROCESSOR_ARCHITECTURE)" == "ALPHA" | |
488 EMACS_CONFIGURATION=alpha-pc-win32 | |
489 !else if "$(PROCESSOR_ARCHITECTURE)" == "PPC" | |
490 EMACS_CONFIGURATION=ppc-pc-win32 | |
491 !else | |
492 ! error Unknown processor architecture type $(PROCESSOR_ARCHITECTURE) | |
493 !endif | |
494 STACK_TRACE_EYE_CATCHER=$(XEMACS_VERSION_STRING:.=_) | |
495 STACK_TRACE_EYE_CATCHER=xemacs_$(STACK_TRACE_EYE_CATCHER:-=_)_$(EMACS_CONFIGURATION:-=_) | |
496 PROGRAM_DEFINES=$(PROGRAM_DEFINES) -DSTACK_TRACE_EYE_CATCHER=$(STACK_TRACE_EYE_CATCHER) | |
497 | |
2951 | 498 ########################### Determine includes/defines/object files/libraries |
499 ########################### for all configuration options given. | |
500 | |
501 OPT_DEFINES= | |
502 OPT_INCLUDES= | |
503 OPT_LIBS= | |
504 OPT_OBJS= | |
505 TEMACS_MODULE_OBJS= | |
506 TEMACS_MODULE_SRCS= | |
1330 | 507 |
508 !if $(HAVE_MS_WINDOWS) | |
2951 | 509 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_MS_WINDOWS |
510 OPT_LIBS=$(OPT_LIBS) comctl32.lib | |
511 OPT_OBJS=$(OPT_OBJS) \ | |
1330 | 512 $(OUTDIR)\console-msw.obj \ |
513 $(OUTDIR)\device-msw.obj \ | |
514 $(OUTDIR)\event-msw.obj \ | |
515 $(OUTDIR)\frame-msw.obj \ | |
516 $(OUTDIR)\glyphs-msw.obj \ | |
517 $(OUTDIR)\gui-msw.obj \ | |
518 $(OUTDIR)\objects-msw.obj \ | |
519 $(OUTDIR)\redisplay-msw.obj \ | |
520 $(OUTDIR)\select-msw.obj \ | |
2951 | 521 $(OUTDIR)\dired-msw.obj |
522 !if $(HAVE_MENUBARS) | |
523 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_MENUBARS | |
524 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\menubar.obj $(OUTDIR)\menubar-msw.obj | |
525 !endif | |
526 !if $(HAVE_SCROLLBARS) | |
527 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_SCROLLBARS | |
528 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\scrollbar.obj $(OUTDIR)\scrollbar-msw.obj | |
529 !endif | |
530 !if $(HAVE_TOOLBARS) | |
531 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_TOOLBARS | |
532 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\toolbar.obj $(OUTDIR)\toolbar-msw.obj | |
533 !endif | |
534 !if $(HAVE_WIDGETS) | |
535 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_WIDGETS | |
536 !endif | |
537 !if $(HAVE_DIALOGS) | |
538 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_DIALOGS | |
539 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\dialog.obj $(OUTDIR)\dialog-msw.obj | |
540 !endif | |
1330 | 541 # end !if $(HAVE_MS_WINDOWS) |
542 !endif | |
543 | |
2951 | 544 !if $(HAVE_XPM) |
545 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_XPM -DFOR_MSW | |
546 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(XPM_DIR)" -I"$(XPM_DIR)\lib" | |
547 OPT_LIBS=$(OPT_LIBS) "$(XPM_DIR)\lib\Xpm.lib" | |
548 !endif | |
549 !if $(HAVE_GIF) | |
550 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_GIF | |
4711
985886265686
Updates for external GIF support on Windows
Vin Shelton <acs@xemacs.org>
parents:
4708
diff
changeset
|
551 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(GIF_DIR)\include" |
985886265686
Updates for external GIF support on Windows
Vin Shelton <acs@xemacs.org>
parents:
4708
diff
changeset
|
552 OPT_LIBS=$(OPT_LIBS) "$(GIF_DIR)\lib\giflib.lib" |
2951 | 553 !endif |
554 !if $(HAVE_PNG) | |
555 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_PNG | |
556 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(PNG_DIR)" -I"$(ZLIB_DIR)" | |
557 OPT_LIBS=$(OPT_LIBS) "$(PNG_DIR)\libpng.lib" "$(ZLIB_DIR)\zlib.lib" | |
558 !endif | |
559 !if $(HAVE_TIFF) | |
560 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_TIFF | |
561 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(TIFF_DIR)\libtiff" | |
562 OPT_LIBS=$(OPT_LIBS) "$(TIFF_DIR)\libtiff\libtiff.lib" | |
563 !endif | |
564 !if $(HAVE_JPEG) | |
565 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_JPEG | |
566 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(JPEG_DIR)" | |
567 OPT_LIBS=$(OPT_LIBS) "$(JPEG_DIR)\libjpeg.lib" | |
568 !endif | |
569 !if $(HAVE_XFACE) | |
570 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_XFACE | |
571 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(COMPFACE_DIR)" | |
572 OPT_LIBS=$(OPT_LIBS) "$(COMPFACE_DIR)\libcompface.lib" | |
573 !endif | |
574 !if $(HAVE_ZLIB) | |
575 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_ZLIB | |
576 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(ZLIB_DIR)" | |
577 OPT_LIBS=$(OPT_LIBS) "$(ZLIB_DIR)\zlib.lib" | |
578 !endif | |
579 !if $(HAVE_BIGNUM) | |
580 OPT_DEFINES=$(OPT_DEFINES) -DWITH_NUMBER_TYPES -DWITH_GMP | |
581 !if $(BUILD_BIGNUM_MINGW_SHARED) | |
582 OPT_LIBS=$(OPT_LIBS) "$(BIGNUM_DIR)\libgmp-3.lib" | |
583 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(BIGNUM_DIR)" | |
584 !else | |
585 !if $(BUILD_BIGNUM_NATIVE_SHARED) | |
586 OPT_LIBS=$(OPT_LIBS) "$(BIGNUM_DIR)\gmp-dynamic\gmp.lib" | |
3034 | 587 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(BIGNUM_DIR)" |
2951 | 588 !else |
589 OPT_LIBS=$(OPT_LIBS) "$(BIGNUM_DIR)\gmp-static\gmp.lib" | |
3034 | 590 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(BIGNUM_DIR)" |
2951 | 591 !endif |
592 !endif | |
593 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\number-gmp.obj $(OUTDIR)\number.obj | |
594 !endif | |
595 !if $(HAVE_DATABASE) | |
596 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_DATABASE -DHAVE_BERKELEY_DB -DDB_H_FILE=\"db.h\" | |
597 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(DATABASE_DIR)\build_win32" | |
598 !if $(BUILD_DATABASE_SHARED) | |
599 OPT_LIBS=$(OPT_LIBS) "$(DATABASE_DIR)\build_win32\Release\libdb43.lib" | |
600 !else | |
601 OPT_LIBS=$(OPT_LIBS) "$(DATABASE_DIR)\build_win32\Release_static\libdb43s.lib" | |
602 !endif | |
603 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\database.obj | |
604 !endif | |
605 !if $(HAVE_POSTGRESQL) | |
606 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_POSTGRESQL -DHAVE_POSTGRESQLV7 -DLIBPQ_FE_H_FILE=\"libpq-fe.h\" | |
607 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(POSTGRESQL_DIR)\src\include" -I"$(POSTGRESQL_DIR)\src\interfaces\libpq" | |
608 OPT_LIBS=$(OPT_LIBS) "$(POSTGRESQL_DIR)\src\interfaces\libpq\Release\libpq.lib" | |
609 TEMACS_MODULE_OBJS=$(TEMACS_MODULE_OBJS) $(OUTDIR)\postgresql.obj | |
610 TEMACS_MODULE_SRCS=$(TEMACS_MODULE_SRCS) $(SRCROOT)\modules\postgresql\postgresql.c | |
611 !endif | |
612 !if $(HAVE_LDAP) | |
613 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_LDAP -DHAVE_LDAP_SET_OPTION -DHAVE_LDAP_RESULT2ERROR -DHAVE_LDAP_PARSE_RESULT | |
614 OPT_INCLUDES=$(OPT_INCLUDES) -I"$(LDAP_DIR)" | |
615 OPT_LIBS=$(OPT_LIBS) "$(LDAP_DIR)\openldap.lib" | |
616 TEMACS_MODULE_OBJS=$(TEMACS_MODULE_OBJS) $(OUTDIR)\eldap.obj | |
617 TEMACS_MODULE_SRCS=$(TEMACS_MODULE_SRCS) $(SRCROOT)\modules\ldap\eldap.c | |
618 !endif | |
619 !if $(HAVE_NATIVE_SOUND) | |
620 OPT_DEFINES=$(OPT_DEFINES) -DHAVE_NATIVE_SOUND | |
621 !endif | |
622 | |
1330 | 623 !if $(MULE) |
2951 | 624 OPT_DEFINES=$(OPT_DEFINES) -DMULE |
625 OPT_OBJS=$(OPT_OBJS) \ | |
1330 | 626 $(OUTDIR)\mule-ccl.obj \ |
627 $(OUTDIR)\mule-charset.obj \ | |
628 $(OUTDIR)\mule-coding.obj | |
629 !endif | |
630 | |
631 !if $(DEBUG_XEMACS) | |
2951 | 632 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\debug.obj $(OUTDIR)\tests.obj |
1330 | 633 !endif |
634 | |
635 !if $(QUICK_BUILD) | |
2951 | 636 OPT_DEFINES=$(OPT_DEFINES) -DQUICK_BUILD |
1330 | 637 !endif |
638 | |
639 !if $(ERROR_CHECK_ALL) | |
2951 | 640 OPT_DEFINES=$(OPT_DEFINES) -DERROR_CHECK_ALL |
1330 | 641 !endif |
642 | |
643 !if $(USE_UNION_TYPE) | |
2951 | 644 OPT_DEFINES=$(OPT_DEFINES) -DUSE_UNION_TYPE |
1330 | 645 !endif |
646 | |
647 !if $(USE_PORTABLE_DUMPER) | |
2951 | 648 OPT_DEFINES=$(OPT_DEFINES) -DPDUMP |
649 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\dumper.obj | |
1330 | 650 !else |
2951 | 651 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\unexnt.obj |
1330 | 652 !endif |
653 | |
3092 | 654 !if $(NEW_GC) |
655 OPT_DEFINES=$(OPT_DEFINES) -DNEW_GC | |
3263 | 656 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\vdb.obj $(OUTDIR)\vdb-win32.obj \ |
657 $(OUTDIR)\mc-alloc.obj | |
3092 | 658 USE_KKCC=1 |
659 !endif | |
660 | |
1330 | 661 !if $(USE_KKCC) |
2951 | 662 OPT_DEFINES=$(OPT_DEFINES) -DUSE_KKCC |
1330 | 663 !endif |
3092 | 664 |
1330 | 665 !if $(USE_SYSTEM_MALLOC) |
2951 | 666 OPT_DEFINES=$(OPT_DEFINES) -DSYSTEM_MALLOC |
1330 | 667 !else |
2951 | 668 OPT_DEFINES=$(OPT_DEFINES) -DGNU_MALLOC |
669 OPT_OBJS=$(OPT_OBJS) $(OUTDIR)\free-hook.obj $(OUTDIR)\gmalloc.obj \ | |
1330 | 670 $(OUTDIR)\ntheap.obj $(OUTDIR)\vm-limit.obj |
671 !endif | |
672 | |
4405
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
673 !if $(USE_INTEL_COMPILER) |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
674 CC=icl |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
675 # Use static library if possible |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
676 INTEL_LIBS=libircmt.lib libmmt.lib |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
677 # Debugging requires DLL version of libm |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
678 !if $(DEBUG_XEMACS) |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
679 INTEL_LIBS=libircmt.lib libmmd.lib |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
680 !endif |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
681 !endif |
4b62544f5139
Use debug version of Intel's math library when debugging.
Vin Shelton <acs@xemacs.org>
parents:
4403
diff
changeset
|
682 |
1330 | 683 ########################### Process options related to compilation. |
442 | 684 |
685 # | |
428 | 686 # Compiler command echo control. Define VERBOSECC=1 to get verbose compilation. |
687 # | |
688 !if $(VERBOSECC) | |
689 CCV=$(CC) | |
690 !else | |
691 CCV=@$(CC) | |
692 !endif | |
693 | |
694 !if $(DEBUG_XEMACS) | |
814 | 695 |
872 | 696 # ---- Debugging support ---- |
2951 | 697 ! if $(MSC_VER) >= 1400 |
698 # VC 7 sets opt:noref automatically with -debug. VC 8 apparently doesn't | |
699 # do this, and then complains if you try to use edit-and-continue without | |
700 # giving it. | |
701 DEBUG_FLAG_LINK_DEBUG=-debug -opt:noref | |
702 # This turns on additional run-time checking | |
4413
dc84ec90b463
Fix build problems on Windows.
Mike Sperber <sperber@deinprogramm.de>
parents:
4405
diff
changeset
|
703 # For some reason it causes spawning of make-docfile to crash in VC 7 and VC 8 |
dc84ec90b463
Fix build problems on Windows.
Mike Sperber <sperber@deinprogramm.de>
parents:
4405
diff
changeset
|
704 # DEBUG_FLAG_COMPILE_DEBUG=-RTC1 |
2951 | 705 ! else |
706 DEBUG_FLAG_LINK_DEBUG=-debug:full | |
707 DEBUG_FLAG_COMPILE_DEBUG= | |
708 ! endif | |
709 | |
1333 | 710 ! if $(SUPPORT_EDIT_AND_CONTINUE) |
872 | 711 # support edit-and-continue |
2951 | 712 DEBUG_FLAGS_COMPILE=$(DEBUG_FLAG_COMPILE_DEBUG) -ZI |
1333 | 713 # WARNING: There is a very good reason for -incremental:no, as it can cause |
714 # all sorts of weird crashes in or after a pdump load. We must allow | |
715 # incremental linking for edit-and-continue to work, however. | |
2951 | 716 DEBUG_FLAGS_LINK=$(DEBUG_FLAG_LINK_DEBUG) |
872 | 717 ! else |
2951 | 718 DEBUG_FLAGS_COMPILE=$(DEBUG_FLAG_COMPILE_DEBUG) -Zi |
719 DEBUG_FLAGS_LINK=$(DEBUG_FLAG_LINK_DEBUG) -incremental:no | |
872 | 720 ! endif |
2951 | 721 |
722 OPT_DEFINES=$(OPT_DEFINES) -DDEBUG_XEMACS -D_DEBUG | |
723 | |
724 ! if $(MSC_VER) >= 1300 | |
725 #BROWSERFLAGS=-FR -Fd$(OUTDIR)\temacs.pdb | |
726 BROWSERFLAGS=-FR$*.sbr -Fd$(OUTDIR)\temacs.pdb | |
727 ! else | |
872 | 728 #BROWSERFLAGS=-Fr -Fd$(OUTDIR)\temacs.pdb |
729 BROWSERFLAGS=-Fr$*.sbr -Fd$(OUTDIR)\temacs.pdb | |
2951 | 730 ! endif |
872 | 731 |
814 | 732 !else |
872 | 733 |
734 # ---- No debugging support ---- | |
735 DEBUG_FLAGS_COMPILE= | |
736 DEBUG_FLAGS_LINK=-incremental:no | |
737 BROWSERFLAGS= | |
738 | |
428 | 739 !endif |
740 | |
440 | 741 !if $(USE_CRTDLL) |
3741 | 742 ! if $(DEBUG_XEMACS) && "$(OK_TO_USE_MSVCRTD)" == "1" |
440 | 743 C_LIBFLAG=-MDd |
744 LIBC_LIB=msvcrtd.lib | |
3741 | 745 ! else |
440 | 746 C_LIBFLAG=-MD |
747 LIBC_LIB=msvcrt.lib | |
3741 | 748 ! endif |
440 | 749 !else |
750 C_LIBFLAG=-ML | |
751 LIBC_LIB=libc.lib | |
752 !endif | |
753 | |
872 | 754 !if $(OPTIMIZED_BUILD) |
2951 | 755 !if $(SUPPORT_EDIT_AND_CONTINUE) |
756 !error Edit-and-continue is not compatible with optimization. | |
757 !endif | |
872 | 758 # -G5 means optimize for Pentium. (According to the code-optimization |
759 # article, -GB is the same as -G5, and -G6, i.e. optimze for Pentium Pro, | |
760 # gains you little over -G5 for PPro's but causes big slowdowns for | |
761 # Pentiums.) -GF means put strings in read-only memory; -Gr means use | |
762 # fastcall convention. Another possible addition: -Ob2 -- allows inlining | |
763 # of any function, not just those declared inline. Potential code size | |
764 # increase, though. | |
765 # | |
766 # #### Note: fastcall doesn't actually seem to make any difference, at least | |
767 # not using the (admittedly unscientific) test of (hanoi 6). The | |
768 # optimization article claims 1-2% improvement in both speed and size. | |
769 OPTFLAGS_FASTCALL =-O2 -G5 -Gr -Ob2 | |
770 OPTFLAGS_CDECL =-O2 -G5 -Ob2 | |
771 !else | |
772 OPTFLAGS_FASTCALL =-Od | |
773 OPTFLAGS_CDECL =-Od | |
774 !endif | |
775 | |
776 !if $(USE_FASTCALL) | |
777 OPTFLAGS = $(OPTFLAGS_FASTCALL) | |
778 !else | |
779 OPTFLAGS = $(OPTFLAGS_CDECL) | |
780 !endif | |
781 | |
782 !if $(PROFILE_SUPPORT) | |
783 PROFILE_FLAGS=-profile | |
784 !else | |
785 PROFILE_FLAGS= | |
786 !endif | |
787 | |
1203 | 788 !if $(CPLUSPLUS_COMPILE) |
789 CPLUSPLUS_COMPILE_FLAGS=-TP | |
790 !else | |
791 CPLUSPLUS_COMPILE_FLAGS= | |
792 !endif | |
793 | |
1330 | 794 ########################### Determine generic includes/defines/flags. |
795 | |
2951 | 796 INCLUDES=-I$(NT)\inc -I$(SRC) $(OPT_INCLUDES) |
1330 | 797 |
2951 | 798 DEFINES=$(OPT_DEFINES) \ |
799 -DWIN32_LEAN_AND_MEAN -DWIN32_NATIVE -Demacs \ | |
1330 | 800 -DHAVE_CONFIG_H $(PROGRAM_DEFINES) $(PATH_DEFINES) |
801 | |
872 | 802 CFLAGS_NO_OPT=-nologo -W3 -DSTRICT $(DEBUG_FLAGS_COMPILE) |
803 | |
804 CFLAGS_NO_LIB=$(CFLAGS_NO_OPT) $(OPTFLAGS) | |
826 | 805 CFLAGS=$(CFLAGS_NO_LIB) $(C_LIBFLAG) |
806 | |
872 | 807 CFLAGS_CDECL_NO_LIB=$(CFLAGS_NO_OPT) $(OPTFLAGS_CDECL) |
808 CFLAGS_CDECL=$(CFLAGS_CDECL_NO_LIB) $(C_LIBFLAG) | |
809 | |
1330 | 810 ########################### Determine flags for XEmacs object files. |
428 | 811 |
812 # This may not exist | |
813 !if "$(emacs_beta_version)" != "" | |
496 | 814 !if "$(emacs_is_beta)" != "" |
428 | 815 EMACS_BETA_VERSION=-DEMACS_BETA_VERSION=$(emacs_beta_version) |
496 | 816 !else |
817 EMACS_PATCH_LEVEL=-DEMACS_PATCH_LEVEL=$(emacs_beta_version) | |
818 !endif | |
819 !endif | |
428 | 820 |
1203 | 821 TEMACS_CPP_FLAGS_NO_CFLAGS=-c $(CPLUSPLUS_COMPILE_FLAGS) \ |
1330 | 822 $(INCLUDES) $(DEFINES) \ |
428 | 823 -DEMACS_MAJOR_VERSION=$(emacs_major_version) \ |
824 -DEMACS_MINOR_VERSION=$(emacs_minor_version) \ | |
1330 | 825 $(EMACS_BETA_VERSION) $(EMACS_PATCH_LEVEL) \ |
442 | 826 -DXEMACS_CODENAME=\"$(xemacs_codename:&=and)\" \ |
2106 | 827 !if defined(xemacs_extra_name) |
4419
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4413
diff
changeset
|
828 -DXEMACS_EXTRA_NAME=\""$(xemacs_extra_name:"=)"\" \ |
2106 | 829 !endif |
3281 | 830 !if defined(PATH_LATE_PACKAGE_DIRECTORIES) |
831 -DPATH_LATE_PACKAGE_DIRECTORIES=\"$(PATH_LATE_PACKAGE_DIRECTORIES)\" \ | |
832 !endif | |
833 -DEMACS_CONFIGURATION=\"$(EMACS_CONFIGURATION)\" | |
872 | 834 TEMACS_CPP_FLAGS=$(CFLAGS) $(TEMACS_CPP_FLAGS_NO_CFLAGS) |
835 TEMACS_CPP_CDECL_FLAGS=$(CFLAGS_CDECL) $(TEMACS_CPP_FLAGS_NO_CFLAGS) | |
428 | 836 |
1330 | 837 ########################### Determine XEmacs object files. |
428 | 838 |
2951 | 839 TEMACS_COMMON_OBJS= \ |
840 $(OPT_OBJS)\ | |
428 | 841 $(OUTDIR)\abbrev.obj \ |
842 $(OUTDIR)\alloc.obj \ | |
851 | 843 $(OUTDIR)\alloca.obj \ |
428 | 844 $(OUTDIR)\blocktype.obj \ |
845 $(OUTDIR)\buffer.obj \ | |
846 $(OUTDIR)\bytecode.obj \ | |
847 $(OUTDIR)\callint.obj \ | |
848 $(OUTDIR)\casefiddle.obj \ | |
849 $(OUTDIR)\casetab.obj \ | |
850 $(OUTDIR)\chartab.obj \ | |
851 $(OUTDIR)\cmdloop.obj \ | |
852 $(OUTDIR)\cmds.obj \ | |
853 $(OUTDIR)\console-stream.obj \ | |
854 $(OUTDIR)\console.obj \ | |
855 $(OUTDIR)\data.obj \ | |
856 $(OUTDIR)\device.obj \ | |
857 $(OUTDIR)\dired.obj \ | |
858 $(OUTDIR)\doc.obj \ | |
859 $(OUTDIR)\doprnt.obj \ | |
860 $(OUTDIR)\dragdrop.obj \ | |
861 $(OUTDIR)\dynarr.obj \ | |
862 $(OUTDIR)\editfns.obj \ | |
863 $(OUTDIR)\elhash.obj \ | |
864 $(OUTDIR)\emacs.obj \ | |
1754 | 865 $(OUTDIR)\emodules.obj \ |
428 | 866 $(OUTDIR)\eval.obj \ |
867 $(OUTDIR)\event-stream.obj \ | |
868 $(OUTDIR)\events.obj \ | |
869 $(OUTDIR)\extents.obj \ | |
870 $(OUTDIR)\faces.obj \ | |
871 $(OUTDIR)\file-coding.obj \ | |
872 $(OUTDIR)\fileio.obj \ | |
873 $(OUTDIR)\filemode.obj \ | |
874 $(OUTDIR)\floatfns.obj \ | |
875 $(OUTDIR)\fns.obj \ | |
876 $(OUTDIR)\font-lock.obj \ | |
877 $(OUTDIR)\frame.obj \ | |
3092 | 878 $(OUTDIR)\gc.obj \ |
428 | 879 $(OUTDIR)\general.obj \ |
442 | 880 $(OUTDIR)\getloadavg.obj \ |
428 | 881 $(OUTDIR)\glyphs.obj \ |
882 $(OUTDIR)\glyphs-eimage.obj \ | |
587 | 883 $(OUTDIR)\glyphs-shared.obj \ |
428 | 884 $(OUTDIR)\glyphs-widget.obj \ |
885 $(OUTDIR)\gui.obj \ | |
886 $(OUTDIR)\gutter.obj \ | |
887 $(OUTDIR)\hash.obj \ | |
888 $(OUTDIR)\indent.obj \ | |
889 $(OUTDIR)\imgproc.obj \ | |
890 $(OUTDIR)\insdel.obj \ | |
891 $(OUTDIR)\intl.obj \ | |
771 | 892 $(OUTDIR)\intl-win32.obj \ |
893 $(OUTDIR)\intl-encap-win32.obj \ | |
894 $(OUTDIR)\intl-auto-encap-win32.obj \ | |
428 | 895 $(OUTDIR)\keymap.obj \ |
872 | 896 $(OUTDIR)\libinterface.obj \ |
428 | 897 $(OUTDIR)\line-number.obj \ |
898 $(OUTDIR)\lread.obj \ | |
899 $(OUTDIR)\lstream.obj \ | |
900 $(OUTDIR)\macros.obj \ | |
901 $(OUTDIR)\marker.obj \ | |
902 $(OUTDIR)\md5.obj \ | |
903 $(OUTDIR)\minibuf.obj \ | |
872 | 904 # #### Leave the next one out when integrating my working ws |
428 | 905 $(OUTDIR)\nt.obj \ |
906 $(OUTDIR)\ntplay.obj \ | |
907 $(OUTDIR)\objects.obj \ | |
908 $(OUTDIR)\opaque.obj \ | |
909 $(OUTDIR)\print.obj \ | |
910 $(OUTDIR)\process.obj \ | |
911 $(OUTDIR)\process-nt.obj \ | |
912 $(OUTDIR)\profile.obj \ | |
913 $(OUTDIR)\rangetab.obj \ | |
914 $(OUTDIR)\realpath.obj \ | |
915 $(OUTDIR)\redisplay-output.obj \ | |
916 $(OUTDIR)\redisplay.obj \ | |
917 $(OUTDIR)\regex.obj \ | |
918 $(OUTDIR)\search.obj \ | |
919 $(OUTDIR)\select.obj \ | |
920 $(OUTDIR)\signal.obj \ | |
921 $(OUTDIR)\sound.obj \ | |
922 $(OUTDIR)\specifier.obj \ | |
923 $(OUTDIR)\strftime.obj \ | |
924 $(OUTDIR)\symbols.obj \ | |
925 $(OUTDIR)\syntax.obj \ | |
926 $(OUTDIR)\sysdep.obj \ | |
771 | 927 $(OUTDIR)\text.obj \ |
428 | 928 $(OUTDIR)\tparam.obj \ |
929 $(OUTDIR)\undo.obj \ | |
771 | 930 $(OUTDIR)\unicode.obj \ |
428 | 931 $(OUTDIR)\widget.obj \ |
932 $(OUTDIR)\window.obj \ | |
442 | 933 $(OUTDIR)\win32.obj |
428 | 934 |
2951 | 935 TEMACS_OBJS= \ |
936 $(TEMACS_COMMON_OBJS) \ | |
937 $(TEMACS_MODULE_OBJS) | |
938 | |
939 TEMACS_DOC_SOURCES= \ | |
940 $(TEMACS_COMMON_OBJS) \ | |
941 $(TEMACS_MODULE_SRCS) | |
942 | |
1330 | 943 ######################################################################### |
944 ## Implicit rules ## | |
945 ######################################################################### | |
946 | |
428 | 947 # Rules |
948 | |
949 .SUFFIXES: | |
430 | 950 .SUFFIXES: .c .obj .texi .info |
428 | 951 |
872 | 952 # nmake rule with batching: |
1330 | 953 #{$(SRC)}.c{$(OUTDIR)}.obj: |
872 | 954 # echo $< >> $(OUTDIR)\listfile.tmp |
955 | |
1330 | 956 {$(SRC)}.c{$(OUTDIR)}.obj: |
872 | 957 $(CCV) $(TEMACS_CPP_FLAGS) $< -Fo$@ $(BROWSERFLAGS) |
428 | 958 |
1330 | 959 ######################################################################### |
960 ## Subsidiary dependency rules ## | |
961 ######################################################################### | |
962 | |
963 ###################### Include auto-generated dependencies. | |
964 | |
965 # | |
966 # Whether to use dependency information generated by make-src-depend | |
967 # | |
968 !if $(DEPEND) && exist("$(SRC)\depend") | |
3054 | 969 ! if [if not exist $(OUTDIR) mkdir "$(OUTDIR)"] |
1330 | 970 ! endif |
971 # This perl script used to be inline but that caused too many quoting problems | |
972 ! if [perl $(NT)\make-nt-depend -s=$(SRC) -c=$(NT) -o=$(OUTDIR) < $(SRC)\depend > $(OUTDIR)\depend.tmp] | |
973 ! endif | |
974 ! include "$(OUTDIR)\depend.tmp" | |
975 !else | |
976 ! if [echo WARNING: Compiling without dependency information.] | |
977 ! endif | |
978 !endif | |
979 | |
980 ###################### Build the output directory structure if not same as | |
981 ###################### source. | |
982 | |
983 !if $(SEPARATE_BUILD) | |
984 # #### `if not exist' does not like the quotes around file names. | |
985 # But what if one of them has spaces? Fucking Microsoft! | |
3054 | 986 ! if [if not exist $(BLDROOT) mkdir "$(BLDROOT)"] |
1330 | 987 ! endif |
3054 | 988 ! if [if not exist $(BLDLIB_SRC) mkdir "$(BLDLIB_SRC)"] |
1330 | 989 ! endif |
3054 | 990 ! if [if not exist $(BLDNT) mkdir "$(BLDNT)"] |
1330 | 991 ! endif |
3054 | 992 ! if [if not exist $(OUTDIR) mkdir "$(OUTDIR)"] |
1330 | 993 ! endif |
3054 | 994 ! if [if not exist $(BLDSRC) mkdir "$(BLDSRC)"] |
1330 | 995 ! endif |
996 # No point. | |
3054 | 997 # ! if [if not exist "$(BLDROOT)" mkdir "$(BLDROOT)"] |
1330 | 998 # ! endif |
999 !endif | |
1000 | |
1001 ###################### Random .obj dependencies | |
1002 | |
872 | 1003 # An explicit rule looks like this ($< works only in implicit rules): |
1330 | 1004 # $(OUTDIR)\foo.obj: $(SRC)\foo.c |
1005 # $(CCV) $(TEMACS_CPP_FLAGS) $(SRC)\$(@B).c -Fo$@ $(BROWSERFLAGS) | |
442 | 1006 |
1330 | 1007 $(OUTDIR)\emacs.obj: $(SRCROOT)\version.sh |
872 | 1008 |
1330 | 1009 $(OUTDIR)\libinterface.obj: $(SRC)\libinterface.c |
1010 $(CCV) $(TEMACS_CPP_CDECL_FLAGS) $(SRC)\$(@B).c -Fo$@ $(BROWSERFLAGS) | |
428 | 1011 |
2951 | 1012 $(OUTDIR)\postgresql.obj: $(SRCROOT)\modules\postgresql\postgresql.c |
1013 $(CCV) -I$(SRC) $(TEMACS_CPP_FLAGS) $(SRCROOT)\modules\postgresql\postgresql.c -Fo$@ $(BROWSERFLAGS) | |
1014 | |
1015 $(OUTDIR)\eldap.obj: $(SRCROOT)\modules\ldap\eldap.c | |
1016 $(CCV) -I$(SRC) $(TEMACS_CPP_FLAGS) $(SRCROOT)\modules\ldap\eldap.c -Fo$@ $(BROWSERFLAGS) | |
1017 | |
1330 | 1018 ###################### Generated source files |
1019 | |
3054 | 1020 $(OUTDIR): |
1330 | 1021 -@mkdir $(OUTDIR) |
872 | 1022 |
1330 | 1023 XEMACS_INCLUDES=\ |
1024 $(SRC)\config.h \ | |
1025 $(SRC)\Emacs.ad.h \ | |
1026 $(SRC)\paths.h | |
428 | 1027 |
1330 | 1028 # #### Copying is cheap, we should just force these |
1029 $(SRC)\config.h: $(SRC)\config.h.in | |
1030 # #### ms must have hired monkeys to design their shell commands. if | |
1031 # #### you use xcopy to copy a file from one name to another, it | |
1032 # #### PROMPTS you to see if you meant the second as a directory! and | |
1033 # #### no switch to mean "no of course, you idiots, it's a file!" | |
2106 | 1034 set COPYCMD=$(COPYCMD) |
1330 | 1035 @copy $(SRC)\config.h.in $(SRC)\config.h |
428 | 1036 |
1330 | 1037 #$(SRC)\Emacs.ad.h: $(SRCROOT)\etc\Emacs.ad |
1038 # !"sed -f ad2c.sed < $(SRCROOT)\etc\Emacs.ad > $(SRC)\Emacs.ad.h" | |
872 | 1039 |
1330 | 1040 #$(SRC)\paths.h: $(SRC)\paths.h.in |
1041 # !"cd $(SRC); cp paths.h.in paths.h" | |
1042 | |
1043 $(SRC)\Emacs.ad.h: $(NT)\Emacs.ad.h | |
2106 | 1044 set COPYCMD=$(COPYCMD) |
1330 | 1045 @$(COPY) $(NT)\Emacs.ad.h $(SRC) |
872 | 1046 |
1330 | 1047 $(SRC)\paths.h: $(NT)\paths.h |
2106 | 1048 set COPYCMD=$(COPYCMD) |
1330 | 1049 @$(COPY) $(NT)\paths.h $(SRC) |
872 | 1050 |
1330 | 1051 |
1052 ###################### lastfile.lib | |
872 | 1053 |
1330 | 1054 !if !$(USE_SYSTEM_MALLOC) || !$(USE_PORTABLE_DUMPER) |
872 | 1055 |
1330 | 1056 LASTFILE=$(OUTDIR)\lastfile.lib |
1057 LASTFILE_SRC=$(SRC) | |
1058 LASTFILE_FLAGS=$(CFLAGS) $(CPLUSPLUS_COMPILE_FLAGS) $(INCLUDES) -Fo$@ -Fd$* -c | |
1059 LASTFILE_OBJS= \ | |
1060 $(OUTDIR)\lastfile.obj | |
872 | 1061 |
1330 | 1062 $(LASTFILE): $(XEMACS_INCLUDES) $(LASTFILE_OBJS) |
1063 link.exe -lib -nologo -out:$@ $(LASTFILE_OBJS) | |
1064 | |
1065 $(OUTDIR)\lastfile.obj: $(LASTFILE_SRC)\lastfile.c | |
1066 $(CCV) $(LASTFILE_FLAGS) $(LASTFILE_SRC)\$(@B).c | |
1067 | |
872 | 1068 !endif |
1069 | |
1330 | 1070 ###################### lib-src programs |
1071 | |
1072 LIB_SRC_DEFINES = -DHAVE_CONFIG_H -DWIN32_NATIVE | |
1073 | |
1074 # | |
1075 # Creating config.values to be used by config.el | |
1076 # | |
1077 CONFIG_VALUES = $(BLDLIB_SRC)\config.values | |
1078 !if [echo Creating $(CONFIG_VALUES) && echo ;;; Do not edit this file!>$(CONFIG_VALUES)] | |
1079 !endif | |
1080 !if [echo blddir>>$(CONFIG_VALUES) && echo "$(BLDROOT:\=\\)">>$(CONFIG_VALUES)] | |
1081 !endif | |
1082 !if [echo srcdir>>$(CONFIG_VALUES) && echo "$(SRCROOT:\=\\)">>$(CONFIG_VALUES)] | |
1083 !endif | |
1084 !if [echo CC>>$(CONFIG_VALUES) && echo "$(CC:\=\\)">>$(CONFIG_VALUES)] | |
1085 !endif | |
1086 !if [echo CFLAGS>>$(CONFIG_VALUES) && echo "$(CFLAGS:\=\\)">>$(CONFIG_VALUES)] | |
1087 !endif | |
1088 !if [echo CPP>>$(CONFIG_VALUES) && echo "$(CPP:\=\\)">>$(CONFIG_VALUES)] | |
1089 !endif | |
1090 !if [echo CPPFLAGS>>$(CONFIG_VALUES) && echo "$(CPPFLAGS:\=\\)">>$(CONFIG_VALUES)] | |
1091 !endif | |
1092 !if [echo LISPDIR>>$(CONFIG_VALUES) && echo "\\$(LISP:\=\\)">>$(CONFIG_VALUES)] | |
1093 !endif | |
3281 | 1094 !if defined(PATH_LATE_PACKAGE_DIRECTORIES) |
1095 # PATH_LATE_PACKAGE_DIRECTORIES is already a quoted string. | |
1096 ! if [echo PATH_LATE_PACKAGE_DIRECTORIES>>$(CONFIG_VALUES) && echo $(PATH_LATE_PACKAGE_DIRECTORIES)>>$(CONFIG_VALUES)] | |
1097 ! endif | |
1330 | 1098 !endif |
1099 | |
1100 LINK_DEPENDENCY_ARGS = -Fe$@ -Fd$* $** -link $(DEBUG_FLAGS_LINK) | |
1101 LINK_STANDARD_LIBRARY_ARGS = setargv.obj user32.lib wsock32.lib | |
1102 | |
1333 | 1103 LIB_SRC_CFLAGS = $(CFLAGS) -I$(LIB_SRC) -I$(SRC) $(LIB_SRC_DEFINES) |
1104 | |
1330 | 1105 # Inferred rule |
1106 {$(LIB_SRC)}.c{$(BLDLIB_SRC)}.exe : | |
1333 | 1107 $(CCV) $(LIB_SRC_CFLAGS) $(LINK_DEPENDENCY_ARGS) $(LINK_STANDARD_LIBRARY_ARGS) |
4603
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1108 # If we're using Visual Studio 2005 or greater, |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1109 # embed the manifest into the executable. |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1110 !if $(MSC_VER) >= 1400 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1111 mt -manifest $@.manifest -outputresource:$@;1 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1112 !endif |
1330 | 1113 |
1114 # Individual dependencies | |
1115 ETAGS_DEPS = $(LIB_SRC)/getopt.c $(LIB_SRC)/getopt1.c $(SRC)/regex.c | |
1116 $(BLDLIB_SRC)/etags.exe : $(LIB_SRC)/etags.c $(ETAGS_DEPS) | |
1333 | 1117 $(CCV) $(LIB_SRC_CFLAGS) $(LINK_DEPENDENCY_ARGS) -stack:0x800000 $(LINK_STANDARD_LIBRARY_ARGS) |
4603
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1118 # If we're using Visual Studio 2005 or greater, |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1119 # embed the manifest into the executable. |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1120 !if $(MSC_VER) >= 1400 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1121 mt -manifest $@.manifest -outputresource:$@;1 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1122 !endif |
1330 | 1123 |
1124 $(BLDLIB_SRC)/movemail.exe : $(LIB_SRC)/movemail.c $(LIB_SRC)/pop.c $(ETAGS_DEPS) | |
1125 | |
1126 # Minitar uses zlib so just use cdecl to simplify things | |
1127 $(BLDLIB_SRC)/minitar.exe : $(NT)/minitar.c | |
2951 | 1128 $(CCV) -I$(SRC) -I"$(ZLIB_DIR)" $(LIB_SRC_DEFINES) $(CFLAGS_CDECL_NO_LIB) -MD $(LINK_DEPENDENCY_ARGS) "$(ZLIB_DIR)\zlib.lib" |
4603
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1129 # If we're using Visual Studio 2005 or greater, |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1130 # embed the manifest into the executable. |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1131 !if $(MSC_VER) >= 1400 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1132 mt -manifest $@.manifest -outputresource:$@;1 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1133 !endif |
1330 | 1134 |
1135 LIB_SRC_TOOLS = \ | |
1136 $(BLDLIB_SRC)/etags.exe \ | |
1137 $(BLDLIB_SRC)/hexl.exe \ | |
1138 $(BLDLIB_SRC)/i.exe \ | |
1139 $(BLDLIB_SRC)/winclient.exe \ | |
1140 $(BLDLIB_SRC)/make-docfile.exe \ | |
1141 $(BLDLIB_SRC)/mmencode.exe \ | |
1142 $(BLDLIB_SRC)/movemail.exe \ | |
1143 $(BLDLIB_SRC)/sorted-doc.exe \ | |
1144 $(BLDLIB_SRC)/wakeup.exe | |
1145 !if $(USE_MINITAR) | |
1146 LIB_SRC_TOOLS = \ | |
1147 $(LIB_SRC_TOOLS) \ | |
1148 $(BLDLIB_SRC)/minitar.exe | |
428 | 1149 !endif |
440 | 1150 !if $(USE_PORTABLE_DUMPER) |
1330 | 1151 LIB_SRC_TOOLS = \ |
1152 $(XEMACS_INCLUDES) \ | |
1153 $(BLDLIB_SRC)/make-dump-id.exe \ | |
1154 $(LIB_SRC_TOOLS) | |
442 | 1155 !endif |
428 | 1156 |
1330 | 1157 ########################### Create the Installation file |
428 | 1158 |
1330 | 1159 $(BLDROOT)\Installation:: installation |
440 | 1160 |
442 | 1161 installation:: |
1330 | 1162 @echo OS version:>$(BLDROOT)\Installation |
1163 @ver >> $(BLDROOT)\Installation | |
1164 @type >> $(BLDROOT)\Installation << | |
428 | 1165 !if defined(OS) |
1166 OS: $(OS) | |
1167 !endif | |
1168 | |
1370 | 1169 XEmacs $(XEMACS_VERSION_STRING) $(xemacs_codename) $(xemacs_extra_name:"=) configured for `$(EMACS_CONFIGURATION)'. |
428 | 1170 |
1052 | 1171 Building XEmacs using "$(MAKE:\=\\)". |
1172 Building XEmacs using make flags "$(MAKEFLAGS)". | |
1330 | 1173 Building XEmacs in source tree "$(SRCROOT:\=\\)". |
1174 !if $(SEPARATE_BUILD) | |
1175 Building XEmacs into compiled tree "$(BLDROOT:\=\\)". | |
1176 !endif | |
428 | 1177 !if defined(CCV) |
1333 | 1178 For src, using compiler "$(CC) $(TEMACS_CPP_FLAGS)". |
1179 For lib-src, using compiler "$(CC) $(LIB_SRC_CFLAGS)". | |
428 | 1180 !endif |
1203 | 1181 !if $(CPLUSPLUS_COMPILE) |
1182 Compiling as C++. | |
1183 !endif | |
1052 | 1184 Installing XEmacs in "$(INSTALL_DIR:\=\\)". |
3281 | 1185 !if defined(PATH_LATE_PACKAGE_DIRECTORIES) |
1186 Package path is $(PATH_LATE_PACKAGE_DIRECTORIES). | |
1187 !endif | |
428 | 1188 !if $(INFODOCK) |
1189 Building InfoDock. | |
1190 !endif | |
442 | 1191 !if $(HAVE_MS_WINDOWS) |
428 | 1192 Compiling in support for Microsoft Windows native GUI. |
1193 !endif | |
771 | 1194 !if $(MULE) |
1195 Compiling in international (MULE) support. | |
428 | 1196 !endif |
488 | 1197 !if $(HAVE_GTK) |
1198 -------------------------------------------------------------------- | |
1315 | 1199 NOTE: You specified HAVE_GTK=1, but we are compiling WITHOUT GTK support. |
1200 NOTE: gtk-xemacs is not currently supported on MS Windows (mingw or msvc). | |
1201 NOTE: Yes, we know that gtk has been ported to native MS Windows, but | |
1202 NOTE: XEmacs is not yet ready to use that port. | |
488 | 1203 -------------------------------------------------------------------- |
1204 !endif | |
428 | 1205 !if $(HAVE_XPM) |
1206 Compiling in support for XPM images. | |
1207 !else | |
1208 -------------------------------------------------------------------- | |
1315 | 1209 NOTE: Compiling without XPM support. |
1210 NOTE: You should strongly consider installing XPM. | |
1211 NOTE: Otherwise toolbars and other graphics will look suboptimal. | |
1212 NOTE: (a copy may be found in ftp://ftp.xemacs.org/pub/xemacs/aux) | |
428 | 1213 -------------------------------------------------------------------- |
1214 !endif | |
1215 !if $(HAVE_GIF) | |
1216 Compiling in support for GIF images. | |
1217 !endif | |
1218 !if $(HAVE_PNG) | |
1219 Compiling in support for PNG images. | |
1220 !else | |
1221 -------------------------------------------------------------------- | |
1315 | 1222 NOTE: Compiling without PNG image support. |
1223 NOTE: You should strongly consider installing the PNG libraries. | |
1224 NOTE: Otherwise certain images and glyphs may not display. | |
1225 NOTE: (a copy may be found in ftp://ftp.xemacs.org/pub/xemacs/aux | |
428 | 1226 -------------------------------------------------------------------- |
1227 !endif | |
1228 !if $(HAVE_TIFF) | |
1229 Compiling in support for TIFF images. | |
1230 !endif | |
1231 !if $(HAVE_JPEG) | |
1232 Compiling in support for JPEG images. | |
1233 !endif | |
1234 !if $(HAVE_XFACE) | |
1235 Compiling in support for X-Face message headers. | |
1236 !endif | |
771 | 1237 !if $(HAVE_ZLIB) |
1238 Compiling in support for GZIP compression/decompression. | |
1239 !endif | |
428 | 1240 !if $(HAVE_TOOLBARS) |
1241 Compiling in support for toolbars. | |
1242 !endif | |
1243 !if $(HAVE_DIALOGS) | |
1244 Compiling in support for dialogs. | |
1245 !endif | |
1246 !if $(HAVE_WIDGETS) | |
1247 Compiling in support for widgets. | |
1248 !endif | |
2951 | 1249 !if $(HAVE_BIGNUM) |
1250 Compiling in support for arbitrary-precision numbers. | |
1251 !endif | |
1252 !if $(HAVE_DATABASE) | |
1253 !if $(BUILD_DATABASE_SHARED) | |
1254 Compiling in support for Berkeley Databases (DLL version). | |
1255 !else | |
1256 Compiling in support for Berkeley Databases (static-library version). | |
1257 !endif | |
1258 !endif | |
1259 !if $(HAVE_POSTGRESQL) | |
1260 Compiling in support for PostgreSQL. | |
1261 !endif | |
1262 !if $(HAVE_LDAP) | |
1263 Compiling in support for LDAP. | |
1264 !endif | |
428 | 1265 !if $(HAVE_NATIVE_SOUND) |
1266 Compiling in support for native sounds. | |
1267 !endif | |
1268 !if $(USE_UNION_TYPE) | |
1269 Using union type for Lisp object storage. | |
1315 | 1270 NOTE: --------------------------------------------------------- |
1271 NOTE: This tends to trigger compiler bugs, especially when combined | |
1272 NOTE: with MULE and ERROR_CHECKING. Crashes in pdump have recently | |
1273 NOTE: been observed using Visual C++ in combination with union type, | |
1274 NOTE: MULE, and ERROR_CHECKING. | |
1275 NOTE: --------------------------------------------------------- | |
428 | 1276 !endif |
438 | 1277 !if $(USE_PORTABLE_DUMPER) |
1278 Using portable dumper. | |
1279 !endif | |
440 | 1280 !if $(USE_SYSTEM_MALLOC) |
1281 Using system malloc. | |
1282 !endif | |
1283 !if $(USE_CRTDLL) | |
942 | 1284 Using DLL version of C runtime library. |
440 | 1285 !endif |
814 | 1286 !if $(ERROR_CHECK_ALL) |
1203 | 1287 Compiling in extra internal error-checking. |
1315 | 1288 NOTE: --------------------------------------------------------- |
1289 NOTE: Compiling in support for runtime error-checking. | |
1290 NOTE: XEmacs will run noticeably more slowly as a result. | |
1291 NOTE: Error-checking is on by default for XEmacs beta releases. | |
1292 NOTE: --------------------------------------------------------- | |
814 | 1293 !endif |
428 | 1294 !if $(DEBUG_XEMACS) |
814 | 1295 Compiling in debugging support (no slowdown). |
1296 !endif | |
1297 !if $(OPTIMIZED_BUILD) | |
1298 Compiling with optimization. | |
428 | 1299 !endif |
442 | 1300 !if $(QUICK_BUILD) |
1301 Disabling non-essential build actions. Use with care! | |
1302 !endif | |
942 | 1303 !if $(USE_KKCC) |
3263 | 1304 Using new experimental GC mark algorithms. |
2720 | 1305 !endif |
3092 | 1306 !if $(NEW_GC) |
3263 | 1307 Using new experimental incremental garbage collector and new allocator. |
3092 | 1308 !endif |
428 | 1309 <<NOKEEP |
1310 @echo -------------------------------------------------------------------- | |
1330 | 1311 @type $(BLDROOT)\Installation |
428 | 1312 @echo -------------------------------------------------------------------- |
1313 | |
1330 | 1314 ######################################################################### |
1315 ## Primary rebuilding process ## | |
1316 ######################################################################### | |
1317 | |
1318 ########################### Definitions for linking temacs.exe | |
1319 | |
1320 !if !$(USE_PORTABLE_DUMPER) | |
1321 TEMACS_ENTRYPOINT=-entry:_start | |
1322 !else | |
1323 TEMACS_ENTRYPOINT=-entry:mainCRTStartup | |
1324 !endif | |
1325 | |
1326 TEMACS_BROWSE=$(BLDSRC)\temacs.bsc | |
2951 | 1327 TEMACS_LIBS=$(LASTFILE) $(OPT_LIBS) \ |
1330 | 1328 oldnames.lib kernel32.lib user32.lib gdi32.lib comdlg32.lib advapi32.lib \ |
1329 shell32.lib wsock32.lib netapi32.lib winmm.lib winspool.lib ole32.lib \ | |
4403
7080e020d700
Add support for the Intel compiler under Windows
Vin Shelton <acs@xemacs.org>
parents:
4225
diff
changeset
|
1330 mpr.lib uuid.lib imm32.lib $(INTEL_LIBS) $(LIBC_LIB) |
2524 | 1331 TEMACS_COMMON_LFLAGS=-nologo $(LIBRARIES) $(DEBUG_FLAGS_LINK) \ |
1333 | 1332 -base:0x1000000 -stack:0x800000 $(TEMACS_ENTRYPOINT) -subsystem:windows \ |
1330 | 1333 -heap:0x00100000 -nodefaultlib $(PROFILE_FLAGS) setargv.obj |
2524 | 1334 TEMACS_LFLAGS=$(TEMACS_COMMON_LFLAGS) \ |
1335 -pdb:$(BLDSRC)\temacs.pdb -map:$(BLDSRC)\temacs.map | |
1336 XEMACS_LFLAGS=$(TEMACS_COMMON_LFLAGS) \ | |
1337 -pdb:$(BLDSRC)\xemacs.pdb -map:$(BLDSRC)\xemacs.map | |
1330 | 1338 |
1339 ########################### Definitions for running temacs.exe/xemacs.exe | |
1340 | |
1341 RAW_EXE=$(BLDSRC)\temacs.exe | |
1342 DUMP_TARGET = $(BLDSRC)\xemacs.exe | |
1343 DO_TEMACS = "$(BLDLIB_SRC)\i" "$(RAW_EXE)" | |
1344 DO_XEMACS = "$(BLDLIB_SRC)\i" "$(DUMP_TARGET)" | |
1345 | |
1346 BATCH = -no-packages -batch | |
1347 BATCH_PACKAGES = -vanilla -batch | |
1348 TEMACS_BATCH = $(DO_TEMACS) -nd $(BATCH) | |
1349 XEMACS_BATCH = $(DO_XEMACS) $(BATCH) | |
1350 XEMACS_BATCH_PACKAGES = $(DO_XEMACS) $(BATCH_PACKAGES) | |
1351 temacs_loadup_args = -l $(LISP)/loadup.el | |
1352 dump_temacs_args = $(temacs_loadup_args) dump | |
1353 run_temacs_args = $(temacs_loadup_args) run-temacs | |
1354 dump_temacs = $(TEMACS_BATCH) $(dump_temacs_args) | |
1355 | |
1356 ########################### Build rules | |
1357 | |
1346 | 1358 ## Use this rule to build the complete system. We need both update-elc |
1359 ## and update-elc-2 due to the sideways dependency of NEEDTODUMP. See | |
1360 ## src/Makefile.in.in for a more detailed discussion of this. | |
1361 | |
3054 | 1362 all: installation $(OUTDIR) $(LIB_SRC_TOOLS) \ |
1346 | 1363 update-elc update-elc-2 \ |
1364 $(LISP)/finder-inf.el load-shadows info | |
1330 | 1365 |
1366 $(TEMACS_BROWSE): $(TEMACS_OBJS) | |
1367 @dir /b/s $(OUTDIR)\*.sbr > $(OUTDIR)\bscmake.tmp | |
1368 bscmake -nologo -o$(TEMACS_BROWSE) @$(OUTDIR)\bscmake.tmp | |
1369 -$(DEL) $(OUTDIR)\bscmake.tmp | |
1370 | |
1346 | 1371 ## (1) Compile all dependencies of the XEmacs executable |
1330 | 1372 |
1373 $(OUTDIR)\dump-id.obj : $(BLDSRC)\dump-id.c | |
1374 $(CCV) $(TEMACS_CPP_FLAGS) $(BLDSRC)\$(@B).c -Fo$@ $(BROWSERFLAGS) | |
1375 | |
1376 $(BLDSRC)\dump-id.c : $(BLDLIB_SRC)/make-dump-id.exe $(TEMACS_OBJS) | |
1377 cd $(BLDSRC) | |
1378 $(BLDLIB_SRC)\make-dump-id.exe | |
1379 | |
1380 $(OUTDIR)\temacs.res: $(NT)\xemacs.rc | |
1381 cd $(NT) | |
1382 rc -Fo$@ xemacs.rc | |
1383 | |
1346 | 1384 ## (2) Link the XEmacs executable |
1385 | |
1330 | 1386 !if $(USE_PORTABLE_DUMPER) |
1387 TEMACS_DUMP_DEP = $(OUTDIR)\dump-id.obj | |
1388 !else | |
1389 TEMACS_DUMP_DEP = $(OUTDIR)\temacs.res | |
1390 !endif | |
1391 | |
1392 $(RAW_EXE): $(TEMACS_OBJS) $(LASTFILE) $(TEMACS_DUMP_DEP) | |
4413
dc84ec90b463
Fix build problems on Windows.
Mike Sperber <sperber@deinprogramm.de>
parents:
4405
diff
changeset
|
1393 # Command line too long for some Windows installation: |
dc84ec90b463
Fix build problems on Windows.
Mike Sperber <sperber@deinprogramm.de>
parents:
4405
diff
changeset
|
1394 # @echo link $(TEMACS_LFLAGS) -out:$@ $(TEMACS_OBJS) $(TEMACS_DUMP_DEP) $(TEMACS_LIBS) |
1330 | 1395 link.exe @<< |
1396 $(TEMACS_LFLAGS) -out:$@ $(TEMACS_OBJS) $(TEMACS_DUMP_DEP) $(TEMACS_LIBS) | |
1397 << | |
1398 | |
1399 !if $(DEBUG_XEMACS) | |
1400 $(RAW_EXE): $(TEMACS_BROWSE) | |
1401 !endif | |
1402 | |
1346 | 1403 ## (3) Update the .elc's needed for dumping |
1404 | |
1405 update-elc: $(RAW_EXE) | |
1406 $(TEMACS_BATCH) -l $(LISP)\update-elc.el | |
1407 | |
1408 ## This file is touched by update-elc.el when redumping is necessary. | |
1409 $(BLDSRC)\NEEDTODUMP: | |
1410 @echo >$(BLDSRC)\NEEDTODUMP | |
1411 | |
1412 ## (4) Build the DOC file | |
1330 | 1413 |
1414 DOC=$(BLDLIB_SRC)\DOC | |
1415 | |
1416 docfile :: | |
1417 if exist $(DOC) $(DEL) $(DOC) | |
1418 docfile :: $(DOC) | |
1419 | |
1420 # We need to write the QUICK_BUILD stuff as-is (and not just have no | |
2951 | 1421 # dependencies for DOC) because DOC needs TEMACS_DOC_SOURCES as dependencies to |
1330 | 1422 # get $(**) right. The `touch' is needed because of the way nmake |
1423 # calculates dependencies; see comments in src/Makefile.in.in. | |
2951 | 1424 $(DOC): $(BLDLIB_SRC)\make-docfile.exe $(BLDSRC)\NEEDTODUMP $(TEMACS_DOC_SOURCES) |
1330 | 1425 !if $(QUICK_BUILD) |
1426 if not exist $(DOC) $(TEMACS_BATCH) -l $(LISP)\make-docfile.el -- -o $(DOC) -i $(SRCROOT)\site-packages @<< | |
1427 $(**) | |
1428 << | |
1429 -touch $(DOC) | |
1430 !else | |
1431 $(TEMACS_BATCH) -l $(LISP)\make-docfile.el -- -o $(DOC) -i $(SRCROOT)\site-packages @<< | |
1432 $(**) | |
1433 << | |
1434 !endif | |
1435 | |
1346 | 1436 ## (5) Dump |
1330 | 1437 |
1438 !if $(USE_PORTABLE_DUMPER) | |
1439 $(DUMP_TARGET): $(NT)\xemacs.rc | |
1440 !endif | |
1441 | |
1442 # This rule dumps xemacs and then possibly spawns sub-make if PURESPACE | |
1443 # requirements have changed. | |
1444 | |
1445 $(DUMP_TARGET): $(DOC) $(RAW_EXE) $(BLDSRC)\NEEDTODUMP | |
1446 $(TEMACS_BATCH) -l $(LISP)\loadup.el dump | |
1447 !if $(USE_PORTABLE_DUMPER) | |
1448 cd $(BLDSRC) | |
1449 rc -d INCLUDE_DUMP -Fo $(OUTDIR)\xemacs.res $(NT)\xemacs.rc | |
1450 # Make the resource section read/write since almost all of it is the dump | |
1451 # data which needs to be writable. This avoids having to copy it. | |
1452 link.exe @<< | |
2524 | 1453 $(XEMACS_LFLAGS) -section:.rsrc,rw -out:$(BLDSRC)\xemacs.exe $(TEMACS_OBJS) $(OUTDIR)\xemacs.res $(TEMACS_LIBS) $(OUTDIR)\dump-id.obj |
1330 | 1454 << |
1455 -$(DEL) $(BLDSRC)\xemacs.dmp | |
4603
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1456 # If we're using Visual Studio 2005 or greater, |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1457 # embed the manifest into the executable. |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1458 !if $(MSC_VER) >= 1400 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1459 mt -manifest $@.manifest -outputresource:$@;1 |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1460 !endif |
202cb69c4d87
Support VS 2005 manifest files
Vin Shelton <acs@xemacs.org>
parents:
4458
diff
changeset
|
1461 |
1330 | 1462 !endif |
1463 | |
1346 | 1464 ## (6) Update the remaining .elc's, post-dumping |
1465 | |
1466 update-elc-2: $(DUMP_TARGET) | |
1330 | 1467 $(XEMACS_BATCH) -no-autoloads -l update-elc-2.el -f batch-update-elc-2 $(LISP) |
1468 | |
1346 | 1469 ## (7) Other random stuff |
1470 | |
1471 $(LISP)/finder-inf.el: update-elc-2 | |
1330 | 1472 !if !$(QUICK_BUILD) |
1473 @echo Building finder database ... | |
1474 $(XEMACS_BATCH) -eval "(setq finder-compile-keywords-quiet t)" \ | |
1475 -l finder -f finder-compile-keywords | |
1476 @echo Building finder database ...(done) | |
1477 !endif | |
1478 | |
1346 | 1479 load-shadows: update-elc-2 |
1330 | 1480 !if !$(QUICK_BUILD) |
1481 @echo Testing for Lisp shadows ... | |
1482 @$(XEMACS_BATCH) -f list-load-path-shadows | |
1483 !endif | |
1484 | |
2948 | 1485 ###################### Building the info files |
1486 | |
1487 !if !defined(MAKEINFO) | |
1488 MAKEINFO=$(XEMACS_BATCH_PACKAGES) -l texinfmt -f batch-texinfo-format | |
1489 !endif | |
1490 | |
1491 MANDIR = $(SRCROOT)\man | |
1492 INFODIR = $(SRCROOT)\info | |
1493 INFO_FILES= \ | |
4225 | 1494 $(INFODIR)\beta.info \ |
2948 | 1495 $(INFODIR)\cl.info \ |
1496 $(INFODIR)\custom.info \ | |
1497 $(INFODIR)\emodules.info \ | |
1498 $(INFODIR)\external-widget.info \ | |
1499 $(INFODIR)\info.info \ | |
4225 | 1500 $(INFODIR)\internals.info \ |
1501 $(INFODIR)\lispref.info \ | |
1502 $(INFODIR)\new-users-guide.info \ | |
2948 | 1503 $(INFODIR)\standards.info \ |
1504 $(INFODIR)\term.info \ | |
1505 $(INFODIR)\termcap.info \ | |
1506 $(INFODIR)\texinfo.info \ | |
1507 $(INFODIR)\widget.info \ | |
1508 $(INFODIR)\xemacs-faq.info \ | |
4225 | 1509 $(INFODIR)\xemacs.info |
2948 | 1510 |
1511 {$(MANDIR)}.texi{$(INFODIR)}.info: | |
1512 cd $(MANDIR) | |
1513 $(MAKEINFO) $(**F) | |
1514 | |
1515 XEMACS_SRCS = \ | |
1516 $(MANDIR)\xemacs\abbrevs.texi \ | |
1517 $(MANDIR)\xemacs\basic.texi \ | |
1518 $(MANDIR)\xemacs\buffers.texi \ | |
1519 $(MANDIR)\xemacs\building.texi \ | |
1520 $(MANDIR)\xemacs\calendar.texi \ | |
1521 $(MANDIR)\xemacs\cmdargs.texi \ | |
1522 $(MANDIR)\xemacs\custom.texi \ | |
1523 $(MANDIR)\xemacs\display.texi \ | |
1524 $(MANDIR)\xemacs\entering.texi \ | |
1525 $(MANDIR)\xemacs\files.texi \ | |
1526 $(MANDIR)\xemacs\fixit.texi \ | |
1527 $(MANDIR)\xemacs\frame.texi \ | |
1528 $(MANDIR)\xemacs\glossary.texi \ | |
1529 $(MANDIR)\xemacs\gnu.texi \ | |
1530 $(MANDIR)\xemacs\help.texi \ | |
1531 $(MANDIR)\xemacs\indent.texi \ | |
1532 $(MANDIR)\xemacs\keystrokes.texi \ | |
1533 $(MANDIR)\xemacs\killing.texi \ | |
1534 $(MANDIR)\xemacs\m-x.texi \ | |
1535 $(MANDIR)\xemacs\major.texi \ | |
1536 $(MANDIR)\xemacs\mark.texi \ | |
1537 $(MANDIR)\xemacs\menus.texi \ | |
1538 $(MANDIR)\xemacs\mini.texi \ | |
1539 $(MANDIR)\xemacs\misc.texi \ | |
1540 $(MANDIR)\xemacs\mouse.texi \ | |
1541 $(MANDIR)\xemacs\mule.texi \ | |
1542 $(MANDIR)\xemacs\new.texi \ | |
1543 $(MANDIR)\xemacs\packages.texi \ | |
1544 $(MANDIR)\xemacs\picture.texi \ | |
1545 $(MANDIR)\xemacs\programs.texi \ | |
1546 $(MANDIR)\xemacs\reading.texi \ | |
1547 $(MANDIR)\xemacs\regs.texi \ | |
1548 $(MANDIR)\xemacs\search.texi \ | |
1549 $(MANDIR)\xemacs\sending.texi \ | |
1550 $(MANDIR)\xemacs\startup.texi \ | |
1551 $(MANDIR)\xemacs\text.texi \ | |
1552 $(MANDIR)\xemacs\trouble.texi \ | |
1553 $(MANDIR)\xemacs\undo.texi \ | |
1554 $(MANDIR)\xemacs\windows.texi \ | |
1555 $(MANDIR)\xemacs\xemacs.texi | |
1556 | |
1557 LISPREF_SRCS = \ | |
1558 $(MANDIR)\lispref\abbrevs.texi \ | |
1559 $(MANDIR)\lispref\annotations.texi \ | |
1560 $(MANDIR)\lispref\back.texi \ | |
1561 $(MANDIR)\lispref\backups.texi \ | |
1562 $(MANDIR)\lispref\buffers.texi \ | |
1563 $(MANDIR)\lispref\building.texi \ | |
1564 $(MANDIR)\lispref\commands.texi \ | |
1565 $(MANDIR)\lispref\compile.texi \ | |
1566 $(MANDIR)\lispref\consoles-devices.texi \ | |
1567 $(MANDIR)\lispref\control.texi \ | |
1568 $(MANDIR)\lispref\customize.texi \ | |
1569 $(MANDIR)\lispref\databases.texi \ | |
1570 $(MANDIR)\lispref\debugging.texi \ | |
1571 $(MANDIR)\lispref\dialog.texi \ | |
1572 $(MANDIR)\lispref\display.texi \ | |
1573 $(MANDIR)\lispref\dragndrop.texi \ | |
1574 $(MANDIR)\lispref\edebug-inc.texi \ | |
1575 $(MANDIR)\lispref\edebug.texi \ | |
1576 $(MANDIR)\lispref\errors.texi \ | |
1577 $(MANDIR)\lispref\eval.texi \ | |
1578 $(MANDIR)\lispref\extents.texi \ | |
1579 $(MANDIR)\lispref\faces.texi \ | |
1580 $(MANDIR)\lispref\files.texi \ | |
1581 $(MANDIR)\lispref\frames.texi \ | |
1582 $(MANDIR)\lispref\functions.texi \ | |
1583 $(MANDIR)\lispref\glyphs.texi \ | |
1584 $(MANDIR)\lispref\hash-tables.texi \ | |
1585 $(MANDIR)\lispref\help.texi \ | |
1586 $(MANDIR)\lispref\hooks.texi \ | |
1587 $(MANDIR)\lispref\index.texi \ | |
1588 $(MANDIR)\lispref\internationalization.texi \ | |
1589 $(MANDIR)\lispref\intro.texi \ | |
1590 $(MANDIR)\lispref\keymaps.texi \ | |
1591 $(MANDIR)\lispref\ldap.texi \ | |
1592 $(MANDIR)\lispref\lispref.texi \ | |
1593 $(MANDIR)\lispref\lists.texi \ | |
1594 $(MANDIR)\lispref\loading.texi \ | |
1595 $(MANDIR)\lispref\locals.texi \ | |
1596 $(MANDIR)\lispref\macros.texi \ | |
1597 $(MANDIR)\lispref\maps.texi \ | |
1598 $(MANDIR)\lispref\markers.texi \ | |
1599 $(MANDIR)\lispref\menus.texi \ | |
1600 $(MANDIR)\lispref\minibuf.texi \ | |
1601 $(MANDIR)\lispref\modes.texi \ | |
1602 $(MANDIR)\lispref\mouse.texi \ | |
1603 $(MANDIR)\lispref\mule.texi \ | |
1604 $(MANDIR)\lispref\numbers.texi \ | |
1605 $(MANDIR)\lispref\objects.texi \ | |
1606 $(MANDIR)\lispref\os.texi \ | |
4225 | 1607 $(MANDIR)\lispref\packaging.texi \ |
2948 | 1608 $(MANDIR)\lispref\positions.texi \ |
1609 $(MANDIR)\lispref\processes.texi \ | |
1610 $(MANDIR)\lispref\range-tables.texi \ | |
1611 $(MANDIR)\lispref\scrollbars.texi \ | |
1612 $(MANDIR)\lispref\searching.texi \ | |
1613 $(MANDIR)\lispref\sequences.texi \ | |
1614 $(MANDIR)\lispref\specifiers.texi \ | |
1615 $(MANDIR)\lispref\streams.texi \ | |
1616 $(MANDIR)\lispref\strings.texi \ | |
1617 $(MANDIR)\lispref\symbols.texi \ | |
1618 $(MANDIR)\lispref\syntax.texi \ | |
1619 $(MANDIR)\lispref\text.texi \ | |
1620 $(MANDIR)\lispref\tips.texi \ | |
1621 $(MANDIR)\lispref\toolbar.texi \ | |
1622 $(MANDIR)\lispref\tooltalk.texi \ | |
1623 $(MANDIR)\lispref\variables.texi \ | |
1624 $(MANDIR)\lispref\windows.texi \ | |
1625 $(MANDIR)\lispref\x-windows.texi | |
1626 | |
1627 INTERNALS_SRCS = \ | |
1628 $(MANDIR)\internals\internals.texi | |
1629 | |
1630 NEW_USERS_GUIDE_SRCS = \ | |
1631 $(MANDIR)\new-users-guide\custom1.texi \ | |
1632 $(MANDIR)\new-users-guide\custom2.texi \ | |
1633 $(MANDIR)\new-users-guide\edit.texi \ | |
1634 $(MANDIR)\new-users-guide\enter.texi \ | |
1635 $(MANDIR)\new-users-guide\files.texi \ | |
1636 $(MANDIR)\new-users-guide\help.texi \ | |
1637 $(MANDIR)\new-users-guide\modes.texi \ | |
1638 $(MANDIR)\new-users-guide\new-users-guide.texi \ | |
1639 $(MANDIR)\new-users-guide\region.texi \ | |
1640 $(MANDIR)\new-users-guide\search.texi \ | |
1641 $(MANDIR)\new-users-guide\xmenu.texi | |
1642 | |
1643 $(INFODIR)\xemacs.info: $(XEMACS_SRCS) | |
1644 cd $(MANDIR)\xemacs | |
1645 $(MAKEINFO) xemacs.texi | |
1646 | |
1647 $(INFODIR)\lispref.info: $(LISPREF_SRCS) | |
1648 cd $(MANDIR)\lispref | |
1649 $(MAKEINFO) lispref.texi | |
1650 | |
1651 $(INFODIR)\internals.info: $(INTERNALS_SRCS) | |
1652 cd $(MANDIR)\internals | |
1653 $(MAKEINFO) internals.texi | |
1654 | |
1655 $(INFODIR)\new-users-guide.info: $(NEW_USERS_GUIDE_SRCS) | |
1656 cd $(MANDIR)\new-users-guide | |
1657 $(MAKEINFO) new-users-guide.texi | |
1658 | |
1659 info: makeinfo-test $(INFO_FILES) | |
1660 | |
1330 | 1661 ######################################################################### |
2951 | 1662 ## Testing, TAGS, install, clean, etc. ## |
1330 | 1663 ######################################################################### |
1664 | |
1665 ########################### Automated tests | |
428 | 1666 |
1330 | 1667 testdir = ../tests/automated |
1668 batch_test_emacs = $(BATCH_PACKAGES) -l $(testdir)/test-harness.el -f batch-test-emacs $(testdir) | |
1669 | |
1670 check: | |
1671 cd $(BLDSRC) | |
1672 $(DO_XEMACS) $(batch_test_emacs) | |
1673 | |
1674 check-temacs: | |
1675 cd $(BLDSRC) | |
1680 | 1676 $(TEMACS_BATCH) $(run_temacs_args) $(batch_test_emacs) |
1330 | 1677 |
1678 check-features: all | |
1679 cd $(BLDSRC) | |
1680 $(XEMACS_BATCH) -l check-features.el | |
1681 | |
1682 | |
1683 ########################### Rebuilding TAGS | |
1684 | |
1685 tags: | |
1686 @echo If you do not have a copy of etags around, then do 'make lib-src' first. | |
1687 @echo To make use of the tags file, put the following in your .emacs: | |
1688 @echo (setq tag-table-alist | |
1689 @echo '(("$(SRCROOT:\=\\)\\" . "$(SRCROOT:\=\\)\\"))) | |
1690 cd $(SRCROOT) | |
1691 -$(DEL) TAGS | |
1692 set PATH=lib-src;%PATH% | |
1693 # we need to double ^, but only in one place, because (according to the | |
1694 # nmake manual), a ^ is used to quote certain special characters such as | |
1695 # backslash, but is treated literally within double quotes -- and notice | |
1696 # carefully the occurrences of double quotes in the first line below! | |
1697 etags -a -r "/[ ]*DEF\(VAR\|INE\)_[A-Z_]+[ ]*([ ]*\"\([^^\"]+\)\"/\2/" src\*.c src\*.h lwlib\*.c lwlib\*.h lib-src\*.c lib-src\*.h | |
1698 etags -a -l none -r "/^(def\(var\|un\|alias\|const\|macro\|subst\|struct\|face\|group\|custom\|ine-\(function\|compiler-macro\|[a-z-]+alias\)\)[ ]+'?\([^ ]+\)/\3/" $(LISP)\*.el $(LISP)\mule\*.el | |
1699 | |
1700 ########################### Install the system | |
1701 | |
1702 # use this rule to install the system | |
1703 install: all | |
1704 cd $(NT) | |
2106 | 1705 set COPYCMD=$(COPYCMD) |
1330 | 1706 @echo Installing in $(INSTALL_DIR) ... |
1707 @echo PlaceHolder > PlaceHolder | |
1393 | 1708 @$(COPY) $(SRCROOT)\PROBLEMS "$(INSTALL_DIR)\" |
2537 | 1709 @$(COPY) $(SRCROOT)\README "$(INSTALL_DIR)\" |
1710 @$(COPY) $(SRCROOT)\COPYING "$(INSTALL_DIR)\" | |
1711 @$(COPY) $(SRCROOT)\Installation "$(INSTALL_DIR)\" | |
1330 | 1712 @$(COPY) PlaceHolder "$(INSTALL_DIR)\lock\" |
1713 -$(DEL) "$(INSTALL_DIR)\lock\PlaceHolder" | |
2537 | 1714 # @$(COPY) $(BLDLIB_SRC)\*.exe "$(INSTALL_DIR)\lib-src\" |
1715 # @$(COPY) $(BLDLIB_SRC)\DOC "$(INSTALL_DIR)\lib-src\" | |
1716 # @$(COPY) $(CONFIG_VALUES) "$(INSTALL_DIR)\lib-src\" | |
1717 # @$(COPY) $(BLDSRC)\xemacs.exe "$(INSTALL_DIR)\bin\" | |
1330 | 1718 @$(COPY) $(BLDLIB_SRC)\*.exe "$(INSTALL_DIR)\$(EMACS_CONFIGURATION)\" |
1719 @$(COPY) $(BLDLIB_SRC)\DOC "$(INSTALL_DIR)\$(EMACS_CONFIGURATION)" | |
1720 @$(COPY) $(CONFIG_VALUES) "$(INSTALL_DIR)\$(EMACS_CONFIGURATION)" | |
1721 @$(COPY) $(BLDSRC)\xemacs.exe "$(INSTALL_DIR)\$(EMACS_CONFIGURATION)" | |
1657 | 1722 # APA: This is not good enough! It copies all .#* CVS files |
1723 # and the CVS directory too! | |
1330 | 1724 @$(COPYDIR) $(SRCROOT)\etc "$(INSTALL_DIR)\etc\" |
1725 @$(COPYDIR) $(SRCROOT)\info "$(INSTALL_DIR)\info\" | |
1726 @$(COPYDIR) $(SRCROOT)\lisp "$(INSTALL_DIR)\lisp\" | |
3281 | 1727 !if defined(PACKAGE_PREFIX) |
1330 | 1728 @echo Making skeleton package tree in $(PACKAGE_PREFIX) ... |
1729 @$(COPY) PlaceHolder "$(PACKAGE_PREFIX)\site-packages\" | |
1730 -$(DEL) "$(PACKAGE_PREFIX)\site-packages\PlaceHolder" | |
1731 @$(COPY) PlaceHolder "$(PACKAGE_PREFIX)\mule-packages\" | |
1732 -$(DEL) "$(PACKAGE_PREFIX)\mule-packages\PlaceHolder" | |
1733 @$(COPY) PlaceHolder "$(PACKAGE_PREFIX)\xemacs-packages\" | |
1734 -$(DEL) "$(PACKAGE_PREFIX)\xemacs-packages\PlaceHolder" | |
3281 | 1735 !endif |
1330 | 1736 -$(DEL) PlaceHolder |
1737 | |
1738 ########################### clean | |
1739 | |
1740 mostlyclean: | |
1741 -$(DEL) $(BLDROOT)\Installation | |
1742 -$(DEL) $(OUTDIR)\*.lib | |
1743 -$(DEL) $(OUTDIR)\*.obj | |
1744 -$(DEL) $(OUTDIR)\*.pdb | |
2951 | 1745 -$(DEL) $(OUTDIR)\*.idb |
1746 -$(DEL) $(OUTDIR)\*.ilk | |
1330 | 1747 -$(DEL) $(OUTDIR)\*.res |
1748 -$(DEL) $(OUTDIR)\*.sbr | |
1749 -$(DEL) $(BLDSRC)\*.exe | |
1750 -$(DEL) $(BLDSRC)\*.dmp | |
1751 -$(DEL) $(BLDSRC)\*.map | |
1752 -$(DEL) $(BLDSRC)\*.pdb | |
2951 | 1753 -$(DEL) $(BLDSRC)\*.idb |
1754 -$(DEL) $(BLDSRC)\*.ilk | |
1330 | 1755 -$(DEL) $(BLDSRC)\NEEDTODUMP |
1756 -$(DEL) $(BLDSRC)\dump-id.c | |
1757 -$(DEL) $(SRC)\*.bsc | |
1758 -$(DEL) $(BLDLIB_SRC)\*.exe | |
1759 -$(DEL) $(BLDLIB_SRC)\*.obj | |
1760 -$(DEL) $(BLDLIB_SRC)\*.pdb | |
2951 | 1761 -$(DEL) $(BLDLIB_SRC)\*.idb |
1762 -$(DEL) $(BLDLIB_SRC)\*.ilk | |
1330 | 1763 -$(DEL) $(BLDLIB_SRC)\*.res |
1764 | |
1765 versionclean: | |
1766 -$(DEL) $(BLDSRC)\xemacs.exe | |
1767 -$(DEL) $(BLDLIB_SRC)\DOC | |
1768 | |
1769 clean: mostlyclean versionclean | |
1770 -$(DEL) $(SRCROOT)\TAGS | |
1771 -$(DEL) $(LISP)\auto-autoloads.el* | |
1772 -$(DEL) $(LISP)\mule\auto-autoloads.el* | |
1773 -$(DEL) $(LISP)\custom-load.el* | |
1774 -$(DEL) $(LISP)\mule\custom-load.el* | |
1775 | |
1776 nicenclean: clean | |
1777 -$(DEL) $(NT)\*.bak | |
1778 -$(DEL) $(NT)\*.orig | |
1779 -$(DEL) $(NT)\*.rej | |
1780 -$(DEL) $(NT)\*.tmp | |
1781 -$(DEL) $(LIB_SRC)\*.bak | |
1782 -$(DEL) $(LIB_SRC)\*.orig | |
1783 -$(DEL) $(LIB_SRC)\*.rej | |
1784 -$(DEL) $(LIB_SRC)\*.tmp | |
1785 -$(DEL) $(SRC)\*.bak | |
1786 -$(DEL) $(SRC)\*.orig | |
1787 -$(DEL) $(SRC)\*.rej | |
1788 -$(DEL) $(SRC)\*.tmp | |
1789 -$(DEL) $(LISP)\*.bak | |
1790 -$(DEL) $(LISP)\*.orig | |
1791 -$(DEL) $(LISP)\*.rej | |
1792 -$(DEL) $(LISP)\*.tmp | |
1793 | |
1794 # Convenience target. | |
1795 # Reproducing the configuration is just a matter of copying, and if | |
1796 # we use the same directory for Cygwin builds these must go. We don't | |
1797 # want to use distclean. | |
1798 configclean: | |
1799 -$(DEL) $(SRC)\config.h | |
1800 -$(DEL) $(SRC)\paths.h | |
1801 -$(DEL) $(SRC)\Emacs.ad.h | |
1802 | |
1803 ## This is used in making a distribution. | |
1804 ## Do not use it on development directories! | |
1805 distclean: nicenclean configclean | |
1806 -$(DEL) $(BLDLIB_SRC)\$(CONFIG_VALUES) | |
1807 -$(DEL) $(INFODIR)\*.info* | |
1808 -$(DEL) $(LISP)\*.elc | |
1809 -$(DEL) $(LISP)\mule\*.elc | |
1810 -$(DEL) $(LISP)\term\*.elc | |
1811 | |
1812 realclean: distclean | |
1813 | |
1814 #not sure about those wildcards. DOS wildcards are stupid compared to Unix, | |
1815 #and could end up deleting *everything* instead of just backup files or | |
1816 #whatever. So just leave it at "realclean" | |
1817 extraclean: realclean | |
1818 # -$(DEL) *~ | |
1819 # -$(DEL) *.*~ | |
1820 # -$(DEL) #* | |
1821 # -$(DEL) m\*~ | |
1822 # -$(DEL) m\#* | |
1823 # -$(DEL) s\*~ | |
1824 # -$(DEL) s\#* | |
1825 | |
1826 ########################### Rebuild source dependency file | |
1827 | |
1828 depend: | |
1829 cd $(SRC) | |
1830 perl ./make-src-depend > depend.tmp | |
1831 perl -MFile::Compare -e "compare('depend.tmp', 'depend') && rename('depend.tmp', 'depend') or unlink('depend.tmp')" | |
1832 | |
1833 ########################### Redo Unicode-Encapsulation | |
1834 | |
1835 unicode-encapsulate: | |
1836 cd $(SRC) | |
1837 perl ../lib-src/make-mswin-unicode.pl --c-output intl-auto-encap-win32.c --h-output intl-auto-encap-win32.h intl-encap-win32.c | |
1838 | |
1657 | 1839 makeinfo-test: $(DUMP_TARGET) |
1840 @<<makeinfo_test.bat | |
1841 @echo off | |
1842 @"$(MAKEINFO)" --version | |
1843 @if not errorlevel 1 goto test_done | |
1844 @$(XEMACS_BATCH_PACKAGES) -eval "(condition-case nil (require (quote texinfo)) (t (kill-emacs 1)))" | |
1845 @if not errorlevel 1 goto suggest_makeinfo | |
1846 @echo XEmacs 'info' cannot be built! | |
1847 @echo Install XEmacs package 'texinfo' (see README.packages). | |
1848 :suggest_makeinfo | |
1849 @echo Consider specifying path to 'makeinfo' in config.inc. | |
1850 @echo as this will build the info docs much faster than XEmacs using 'texinfo'. | |
1851 @if errorlevel 1 exit 1 | |
1852 :test_done | |
1853 <<NOKEEP |