Mercurial > hg > xemacs-beta
annotate configure.ac @ 5921:68639fb08af8 cygwin
no obvious 64 vs. 32 pblms in compilation, but still crashing in event-msw
author | Henry Thompson <ht@markup.co.uk> |
---|---|
date | Wed, 23 Apr 2014 22:22:37 +0100 |
parents | 0f2338afbabf |
children | 4b055de36bb9 |
rev | line source |
---|---|
2651 | 1 dnl XEmacs config script for autoconf 2.5. |
2 dnl ------------------------------------------------------------------------- | |
3 dnl Overrides of standard autoconf macros. | |
4 | |
5 # AC_LANG(C) | |
6 # ---------- | |
7 # CFLAGS is not in ac_cpp because -g, -O, etc. are not valid cpp options. | |
8 m4_define([AC_LANG(C)], | |
9 [ac_ext=c | |
10 xe_cppflags='$CPPFLAGS $c_switch_site $c_switch_machine $c_switch_system $c_switch_x_site $X_CFLAGS' | |
11 xe_ldflags='$LDFLAGS $ld_switch_site $ld_switch_machine $ld_switch_system $ld_switch_x_site $ld_switch_run' | |
12 xe_libs='$ld_call_shared $xe_check_libs $X_EXTRA_LIBS $libs_x $libs_gtk $X_PRE_LIBS $LIBS $libs_machine $libs_system $libs_standard' | |
13 ac_cpp='$CPP '"$xe_cppflags" | |
2667 | 14 ac_compile='$CC -c $CFLAGS '"$xe_cppflags"' conftest.$ac_ext >&AS_MESSAGE_LOG_FD' |
2651 | 15 ac_link='$CC -o conftest$ac_exeext $CFLAGS '"$xe_cppflags $xe_ldflags"' conftest.$ac_ext '"$xe_libs"' >&AS_MESSAGE_LOG_FD' |
16 ac_compiler_gnu=$ac_cv_c_compiler_gnu | |
17 ]) | |
4991
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
18 # AC_LANG(C++) |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
19 # ---------- |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
20 # Similar to AC_LANG(C) but we use XEMACS_CC, which may be g++. |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
21 m4_define([AC_LANG(C++)], |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
22 [ac_ext=c |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
23 xe_cppflags='$CPPFLAGS $c_switch_site $c_switch_machine $c_switch_system $c_switch_x_site $X_CFLAGS' |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
24 xe_ldflags='$LDFLAGS $ld_switch_site $ld_switch_machine $ld_switch_system $ld_switch_x_site $ld_switch_run' |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
25 xe_libs='$ld_call_shared $xe_check_libs $X_EXTRA_LIBS $libs_x $libs_gtk $X_PRE_LIBS $LIBS $libs_machine $libs_system $libs_standard' |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
26 ac_cpp='$CPP '"$xe_cppflags" |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
27 ac_compile='$XEMACS_CC -c $CFLAGS '"$xe_cppflags"' conftest.$ac_ext >&AS_MESSAGE_LOG_FD' |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
28 ac_link='$XEMACS_CC -o conftest$ac_exeext $CFLAGS '"$xe_cppflags $xe_ldflags"' conftest.$ac_ext '"$xe_libs"' >&AS_MESSAGE_LOG_FD' |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
29 ac_compiler_gnu=$ac_cv_c_compiler_gnu |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
30 ]) |
3003 | 31 dnl |
2651 | 32 dnl ------------------------------------------------------------------------- |
33 dnl Autoconf startup. | |
3003 | 34 dnl |
35 dnl Due to a dependence on the implementation of certain internal autoconf | |
36 dnl macros, die if any version other than 2.59 is used. | |
2651 | 37 AC_PREREQ(2.59)dnl |
3050 | 38 AC_INIT([XEmacs],[21.5],[xemacs-beta@xemacs.org])dnl |
39 AC_CONFIG_SRCDIR(src/lisp.h)dnl | |
3003 | 40 dnl |
2651 | 41 dnl ------------------------------------------------------------------------- |
42 dnl Local copyright notices. | |
43 | |
44 AC_COPYRIGHT( | |
3073 | 45 [Configuration script for XEmacs. Largely divergent from FSF. |
46 Guess values for system-dependent variables and create Makefiles. | |
47 | |
3418 | 48 Copyright (C) 1992-1999, 2001-2006 Free Software Foundation, Inc. |
3073 | 49 Copyright (C) 1993, 1994, 1995 Board of Trustees, University of Illinois. |
50 Copyright (C) 1996, 1997 Sun Microsystems, Inc. | |
51 Copyright (C) 1995, 1996, 2002, 2003, 2004 Ben Wing. | |
52 Copyright (C) 2000, 2001 Martin Buchholz. | |
53 Copyright (C) 1998, 1999 J. Kean Johnston. | |
54 Copyright (C) 2005 Malcolm Purvis | |
55 | |
56 Don't edit this script! | |
57 This script was automatically generated by the `autoconf' program | |
58 from the file `./configure.ac'. To rebuild it, execute the command: | |
59 | |
60 autoconf | |
61 | |
62 in the this directory. You must have autoconf version 2.59. | |
63 | |
64 This file is part of XEmacs. | |
65 | |
5409
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
66 XEmacs is free software: you can redistribute it and/or modify it |
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
67 under the terms of the GNU General Public License as published by the |
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
68 Free Software Foundation, either version 3 of the License, or (at your |
3073 | 69 option) any later version. |
70 | |
5409
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
71 XEmacs is distributed in the hope that it will be useful, but WITHOUT |
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
72 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
73 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
74 for more details. |
3073 | 75 |
76 You should have received a copy of the GNU General Public License | |
5409
c36f065c3090
Convert part of root folder to GPLv3.
Mats Lidell <matsl@xemacs.org>
parents:
5228
diff
changeset
|
77 along with XEmacs. If not, see <http://www.gnu.org/licenses/>. |
3073 | 78 |
79 For usage, run `./configure --help' | |
80 For more detailed information on building and installing XEmacs, | |
81 read the file `INSTALL'. | |
82 | |
83 If configure succeeds, it leaves its status in config.status. | |
84 A log of configuration tests can be found in config.log. | |
85 If configure fails after disturbing the status quo, | |
86 config.status is removed. | |
2651 | 87 ]) |
88 | |
89 dnl ------------------------------------------------------------------------- | |
90 dnl Program name (sanitize $0) | |
91 dnl Remove any more than one leading "." element from the path name. | |
92 dnl config.status prepends another "./" at each use. This confuses | |
93 dnl move-if-change. | |
94 dnl | |
95 dnl Unfortunately, some seds (Ultrix's) don't allow you to apply * to a | |
96 dnl \( \) group. Bleah. Remove the level config.status adds, at least. | |
97 dnl | |
98 dnl If there's reason to prefer $0 over this, make sure you fix all the | |
99 dnl uses in this script!! | |
100 progname="`echo $0 | sed 's:^\./\./:\./:'`" | |
3003 | 101 dnl |
2651 | 102 dnl ------------------------------------------------------------------------- |
103 dnl Local macros | |
3003 | 104 dnl |
2651 | 105 define([USAGE_ERROR], |
106 [(echo "$progname: Usage error:" | |
107 echo " " $1 | |
3003 | 108 echo " Use \`$progname --help' to show usage.") >&2 && exit 1])dnl |
109 dnl | |
2651 | 110 dnl PRINT_VAR(var var ...) prints values of shell variables |
111 define([PRINT_VAR],[for var in patsubst([$1],[[ | |
3003 | 112 ]+],[ ]); do eval "echo \"$var = '\$$var'\""; done])dnl |
113 dnl | |
2651 | 114 dnl XE_ADD_OBJS(foo.o) |
115 define([XE_ADD_OBJS], | |
116 [extra_objs="$extra_objs [$1]" && dnl | |
117 if test "$verbose" = "yes"; then | |
118 echo " xemacs will be linked with \"[$1]\"" | |
119 fi])dnl XE_ADD_OBJS | |
3003 | 120 dnl |
2651 | 121 dnl XE_APPEND(value, varname) |
122 define([XE_APPEND], | |
123 [[$2]="$[$2] [$1]" && dnl | |
3003 | 124 if test "$verbose" = "yes"; then echo " Appending \"[$1]\" to \$[$2]"; fi])dnl |
125 dnl | |
2651 | 126 dnl XE_PREPEND(value, varname) |
127 define([XE_PREPEND], | |
128 [[$2]="[$1] $[$2]" && dnl | |
3003 | 129 if test "$verbose" = "yes"; then echo " Prepending \"[$1]\" to \$[$2]"; fi])dnl |
130 dnl | |
2651 | 131 dnl XE_DIE(message) |
3003 | 132 define([XE_DIE], [{ echo "Error:" $1 >&2; exit 1; }])dnl |
133 dnl | |
2651 | 134 dnl XE_CHECK_FEATURE_DEPENDENCY(feature1, feature2) |
135 define([XE_CHECK_FEATURE_DEPENDENCY], | |
136 [if test "$with_[$1] $with_[$2]" = "yes no"; then | |
137 USAGE_ERROR("--with-[$1] requires --with-[$2]") | |
138 elif test "$with_[$2]" = "no" ; then with_[$1]=no | |
139 elif test "$with_[$1]" = "yes"; then with_[$2]=yes | |
140 fi | |
3003 | 141 ])dnl |
142 dnl | |
2651 | 143 dnl XE_STRIP_4TH_COMPONENT(var) |
144 dnl Changes i986-pc-linux-gnu to i986-pc-linux, as God (not RMS) intended. | |
145 define([XE_STRIP_4TH_COMPONENT], | |
3003 | 146 [$1=`echo "$$1" | sed '[s/^\([^-][^-]*-[^-][^-]*-[^-][^-]*\)-.*$/\1/]'`])dnl |
147 dnl | |
2651 | 148 dnl Do our best to deal with automounter brokenness |
149 dnl CANONICALIZE_PATH(varname) | |
150 define([CANONICALIZE_PATH], | |
151 [if test -d "/net"; then | |
152 if test -d "/tmp_mnt/net"; then tdir="tmp_mnt/net"; else tdir="tmp_mnt"; fi | |
153 $1=`echo "[$]$1" | \ | |
154 sed -e "s|^${tdir}/|/net/|" -e "s|^/a/|/net/|" -e "s|^/amd/|/net/|"` | |
155 fi])dnl | |
3003 | 156 dnl |
2651 | 157 dnl XE_PROTECT_LINKER_FLAGS(shell_var) |
158 define([XE_PROTECT_LINKER_FLAGS], [ | |
159 if test "$GCC" = "yes"; then | |
160 set x $[$1]; shift; [$1]="" | |
161 while test -n "[$]1"; do | |
162 case [$]1 in | |
163 -L | -l | -u ) [$1]="$[$1] [$]1 [$]2"; shift ;; | |
164 -L* | -l* | -u* | -Wl* | -pg ) [$1]="$[$1] [$]1" ;; | |
165 -Xlinker* ) ;; | |
166 * ) [$1]="$[$1] -Xlinker [$]1" ;; | |
167 esac | |
168 shift | |
169 done | |
170 fi])dnl | |
3003 | 171 dnl |
2651 | 172 dnl Allow use of either ":" or spaces for lists of directories |
173 define(COLON_TO_SPACE, | |
174 [case "$[$1]" in *:* [)] [$1]="`echo '' $[$1] | sed -e 's/^ //' -e 's/:/ /g'`";; esac])dnl | |
3003 | 175 dnl |
2651 | 176 dnl XE_ADD_RUNPATH_DIR(directory) |
177 define([XE_ADD_RUNPATH_DIR],[{ | |
178 xe_runpath_dir=$1 | |
179 dnl PRINT_VAR(ld_switch_site ld_switch_x_site runpath xe_runpath_dir LD_RUN_PATH xe_ldflags) | |
180 test "$xe_runpath_dir" != "/lib" -a \ | |
181 "$xe_runpath_dir" != "/usr/lib" -a \ | |
182 -n "`ls ${xe_runpath_dir}/*.s[[ol]] 2>/dev/null`" && \ | |
183 eval "$xe_add_unique_runpath_dir" | |
184 }])dnl | |
3003 | 185 dnl |
2651 | 186 dnl XE_COMPUTE_RUNPATH() |
187 define([XE_COMPUTE_RUNPATH],[ | |
188 if test "$add_runtime_path" = "yes" -a -n "$dash_r"; then | |
189 dnl Remove runtime paths from current ld switches | |
190 ld_switch_site=`echo '' $ld_switch_site | sed -e 's:^ ::' -e "s/$dash_r[[^ ]]*//g"` | |
191 ld_switch_x_site=`echo '' $ld_switch_x_site | sed -e 's:^ ::' -e "s/$dash_r[[^ ]]*//g"` | |
192 dnl PRINT_VAR(ld_switch_site ld_switch_x_site) | |
193 | |
194 dnl Fix up Runtime path | |
195 dnl If LD_RUN_PATH is set in environment, use that. | |
196 dnl In this case, assume user has set the right value. | |
197 runpath="" runpath_dirs="" | |
198 if test -n "$LD_RUN_PATH"; then | |
199 runpath="$LD_RUN_PATH" | |
200 elif test "$GCC" = "yes"; then | |
201 dnl Compute runpath from gcc's -v output | |
202 ld_switch_run_save="$ld_switch_run"; ld_switch_run="" | |
4588
6a6689b96f00
Adopt Martin's suggestion of "char **argv" throughout configure.ac.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4543
diff
changeset
|
203 echo "int main(int argc, char **argv) {return 0;}" > conftest.c |
2651 | 204 xe_runpath_link='${CC-cc} -o conftest -v $CFLAGS '"$xe_ldflags"' conftest.$ac_ext 2>&1 1>/dev/null' |
205 for arg in `eval "$xe_runpath_link" | grep ' -L'`; do | |
206 case "$arg" in P,* | -L* | -R* ) | |
207 for dir in `echo '' "$arg" | sed -e 's:^ ::' -e 's/^..//' -e 'y/:/ /'`; do | |
208 XE_ADD_RUNPATH_DIR("$dir") | |
209 done ;; | |
210 esac | |
211 done | |
212 ld_switch_run="$ld_switch_run_save" | |
213 rm -f conftest* | |
214 else | |
215 dnl Add all directories with .so files to runpath | |
216 for arg in $ld_switch_site $ld_switch_x_site; do | |
217 case "$arg" in -L*) XE_ADD_RUNPATH_DIR(`echo '' "$arg" | sed -e 's:^ ::' -e 's/^-L//'`);; esac | |
218 done | |
219 dnl Sometimes /opt/SUNWdt/lib is the only installed Motif available | |
3019 | 220 dnl #### this test always fails here as need_motif is null |
2651 | 221 if test "$opsys $need_motif" = "sol2 yes"; then |
222 xe_runpath_dir="/opt/SUNWdt/lib"; | |
223 eval "$xe_add_unique_runpath_dir"; | |
224 fi | |
225 fi dnl Compute $runpath | |
226 | |
227 if test -n "$runpath"; then | |
228 ld_switch_run="${dash_r}${runpath}" | |
229 XE_PROTECT_LINKER_FLAGS(ld_switch_run) | |
230 test "$verbose" = "yes" && echo "Setting runpath to $runpath" | |
231 fi | |
232 fi | |
233 ])dnl | |
3003 | 234 dnl |
2651 | 235 dnl The construct foo=`echo $w1 $w2 $w3` fails on some systems if $w1 = -e or -n |
236 dnl So we use the following instead. | |
237 dnl XE_SPACE(var, words) | |
238 define([XE_SPACE],[ | |
239 T="" | |
240 for W in $2; do if test -z "$T"; then T="$W"; else T="$T $W"; fi; done | |
241 $1="$T" | |
242 ])dnl XE_SPACE | |
3683 | 243 dnl Autoconf 2.59 and 2.60 have slightly different versions of m4_cdr that |
244 dnl return different values for an empty list. XE_CDR is a copy of the 2.60 | |
245 dnl version which will be used with both versions. | |
246 define([XE_CDR], | |
247 [m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], | |
248 [$#], 1, [], | |
249 [m4_dquote(m4_shift($@))])])dnl | |
3003 | 250 dnl |
251 dnl XE_MERGED_ARG(FEATURE, HELP-STRING, [ACTION-IF-TRUE], [ACTION-IF-FALSE]) | |
252 dnl ------------------------------------------------------------------------ | |
253 dnl | |
254 dnl Arguments that can be specified with either --enable or --with. The | |
255 dnl majority of XEmacs arguments do not fit neatly into the division between | |
256 dnl --enable and --with, so allow those to be specified by either argument. | |
257 dnl The value is stored in both enable_FEATURE and with_FEATURE. | |
258 AC_DEFUN([XE_MERGED_ARG], | |
259 [m4_divert_once([HELP_ENABLE], [[ | |
260 Optional Features: | |
261 --with-FEATURE[=ARG] include FEATURE [ARG=yes] | |
262 --enable-FEATURE[=ARG] alias for --with-FEATURE | |
263 --without-FEATURE do not use FEATURE (same as --with-FEATURE=no) | |
264 --disable-FEATURE alias for --without-FEATURE]])dnl | |
265 m4_divert_once([HELP_ENABLE], m4_bpatsubst([[$2]],[--enable\([^ ]+\) ],[--with\1 ]))dnl | |
3764 | 266 dnl Register both forms with the option checking list. |
267 dnl Options are only checked with autoconf > 2.61. | |
4656
79d1a0524b5f
Use correct separator when registering options to _AC_USER_OPTS.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4588
diff
changeset
|
268 m4_append_uniq([_AC_USER_OPTS], [enable_]m4_bpatsubst([$1], -, _), [ |
79d1a0524b5f
Use correct separator when registering options to _AC_USER_OPTS.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4588
diff
changeset
|
269 ])dnl |
79d1a0524b5f
Use correct separator when registering options to _AC_USER_OPTS.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4588
diff
changeset
|
270 m4_append_uniq([_AC_USER_OPTS], [with_]m4_bpatsubst([$1], -, _), [ |
79d1a0524b5f
Use correct separator when registering options to _AC_USER_OPTS.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4588
diff
changeset
|
271 ])dnl |
3003 | 272 # If --with-$1 or --without-$1 were given then copy the value to the |
273 # equivalent enable_$1 variable. | |
274 if test "[${with_]m4_bpatsubst([$1], -, _)+set}" = set; then | |
275 [enable_]m4_bpatsubst([$1], -, _)="[$with_]m4_bpatsubst([$1], -, _)" | |
276 fi; | |
277 # If -enable-$1 or --disable-$1 were given then copy the value to the | |
278 # equivalent with_$1 variable. | |
279 if test "[${enable_]m4_bpatsubst([$1], -, _)+set}" = set; then | |
280 [with_]m4_bpatsubst([$1], -, _)="[$enable_]m4_bpatsubst([$1], -, _)" | |
281 fi; | |
282 # Check whether --with-$1 or --without-$1 was given. | |
283 if test "[${with_]m4_bpatsubst([$1], -, _)+set}" = set; then | |
284 enableval="[$with_]m4_bpatsubst([$1], -, _)" | |
285 withval="[$with_]m4_bpatsubst([$1], -, _)" | |
286 $3 | |
287 m4_ifvaln([$4], [else | |
288 $4])dnl | |
289 fi; dnl | |
290 ])dnl XE_MERGED_ARG | |
291 dnl | |
3073 | 292 dnl XE_HELP_SUBSECTION(HEADING) |
293 dnl -------------------------- | |
294 dnl | |
295 dnl Add subsection headings to the help text for XE_MERGED_ARG options. | |
296 dnl | |
297 AC_DEFUN([XE_HELP_SUBSECTION], | |
298 [m4_divert_once([HELP_ENABLE], [[ | |
299 Optional Features: | |
300 --with-FEATURE[=ARG] include FEATURE [ARG=yes] | |
301 --enable-FEATURE[=ARG] alias for --with-FEATURE | |
302 --without-FEATURE do not use FEATURE (same as --with-FEATURE=no) | |
303 --disable-FEATURE alias for --without-FEATURE]])dnl | |
304 dnl NOTE: The next eol adds a blank line before the heading. | |
305 m4_divert_once([HELP_ENABLE], [[ | |
306 $1]])dnl | |
3161 | 307 dnl Add an underscore |
3073 | 308 dnl NOTE: The next eol adds a blank line after the underscore. |
309 m4_divert_text([HELP_ENABLE], patsubst([$1], [.], [-]) | |
310 )])dnl | |
311 dnl | |
2651 | 312 dnl XEmacs keyword option support |
313 dnl ============================= | |
314 dnl | |
315 dnl A "keyword" option is one that accepts one of a number of pre-defined | |
316 dnl values. For example --with-mail-locking=flock. | |
317 dnl The descriptions below provide prototypes and little more. | |
318 dnl | |
319 dnl For more information, | |
320 dnl (Info-goto-node "(internals)The configure Script") | |
321 dnl To edit the documentation, | |
322 dnl (progn (find-file "man/internals/internals.texi")) | |
323 dnl and search for "@node The configure Script". | |
324 dnl | |
325 dnl XE_PARSE_KEYWORD_OPTION(prefix, cmdline-flag) | |
326 dnl --------------------------------------------- | |
327 dnl | |
328 dnl Internal macro to parse the option values. If an undeclared option is | |
329 dnl found then an error is generated. | |
330 dnl | |
331 define([XE_PARSE_KEYWORD_OPTION], | |
332 [_[$1]_bogus=yes | |
333 for x in XE_KEYWORD_LIST ; do | |
3003 | 334 if test $x = $with_[$1] ; then |
2651 | 335 _[$1]_bogus=no |
336 fi | |
337 done | |
338 if test "$_[$1]_bogus" = "yes" ; then | |
339 USAGE_ERROR(["The [$2] option must have one of these values: m4_translit(XE_KEYWORD_VALUES,[:],[,])."]) | |
340 fi | |
341 unset _[$1]_bogus | |
342 undefine([XE_KEYWORD_LIST])dnl | |
3003 | 343 undefine([XE_KEYWORD_VALUES])])dnl |
2651 | 344 dnl |
345 dnl XE_KEYWORD(keyword) | |
346 dnl -------------------------------- | |
347 dnl | |
348 dnl | |
349 define([XE_KEYWORD], | |
350 [m4_append([XE_KEYWORD_LIST],[$1],[ ])dnl | |
351 dnl Separate with a ':' instead of a ',' (see the parsing code above) to avoid | |
3161 | 352 dnl confusion with macro parameter lists. |
2651 | 353 m4_append([XE_KEYWORD_VALUES],[\`$1'],[:])dnl |
3003 | 354 ])dnl |
2651 | 355 dnl |
3003 | 356 dnl XE_KEYWORD_ARG(PACKAGE, HELP-STRING, ACTION-IF-TRUE, ACTION-IF-FALSE, |
2651 | 357 dnl [XE_KEYWORD(keyword), ....]) |
358 dnl -------------------------------------------------------------------------- | |
359 dnl | |
3003 | 360 dnl Expanded version of XE_MERGED_ARG for keyword options. All the parameters |
2651 | 361 dnl are required. |
362 dnl | |
3003 | 363 define([XE_KEYWORD_ARG], |
2651 | 364 [m4_map([XE_KEYWORD],m4_shiftn(4, $@)) |
3003 | 365 XE_MERGED_ARG([$1],[$2], |
366 [XE_PARSE_KEYWORD_OPTION(patsubst([$1], -, _), [--with-$1]) | |
2651 | 367 $3 |
3003 | 368 ],[$4])])dnl |
2651 | 369 dnl |
370 dnl XEmacs complex option support | |
371 dnl ============================= | |
372 dnl | |
373 dnl A "complex option" is one that takes a number of related values. | |
374 dnl For example, we might use "--with-xft=all,nomenubars" for compatibility | |
375 dnl with XFontSet i18n of menubars. (Silly, Xft looks much better than XFS.) | |
376 dnl | |
377 dnl The descriptions below provide prototypes and little more. | |
378 dnl For more information, | |
379 dnl (Info-goto-node "(internals)The configure Script") | |
380 dnl To edit the documentation, | |
381 dnl (progn (find-file "man/internals/internals.texi")) | |
382 dnl and search for "@node The configure Script". | |
383 dnl | |
384 dnl XE_EXPAND_COMPLEX_OPTION(prefix, component, yesno) | |
385 dnl --------------------------------------------------- | |
386 dnl | |
387 dnl Internal macro create the option's shell variable containing the default | |
388 dnl value and to note the values in an option list. | |
389 dnl | |
390 define([XE_EXPAND_COMPLEX_OPTION], | |
3147 | 391 [_[$1]_[$2]_default=[$3] |
2651 | 392 m4_append([XE_COMPONENT_LIST],[$2],[ ])dnl |
393 dnl Separate with a ':' instead of a ',' (see <prefix>_default below) to avoid | |
3161 | 394 dnl confusion with macro parameter lists. |
2651 | 395 m4_append([XE_COMPONENT_DEFAULT],[m4_if([$3],no,no)[$2]],[:])dnl |
396 ])dnl | |
397 dnl | |
398 dnl XE_EXPAND_COMPLEX_OPTIONS(prefix, option_list) | |
399 dnl ---------------------------------------------- | |
400 dnl | |
401 dnl Internal macro to recursively expand all the options in the option list. | |
402 dnl | |
4475
86283c809984
autoconf 2.62 compatibility, #370
"Ville Skyttä <scop@xemacs.org>"
parents:
4455
diff
changeset
|
403 dnl m4_fst disappeared without a trace in autoconf 2.62 |
86283c809984
autoconf 2.62 compatibility, #370
"Ville Skyttä <scop@xemacs.org>"
parents:
4455
diff
changeset
|
404 m4_define([xe_fst], [$1])dnl |
2651 | 405 define([XE_EXPAND_COMPLEX_OPTIONS], |
3683 | 406 [m4_if([$2], [], [], |
4475
86283c809984
autoconf 2.62 compatibility, #370
"Ville Skyttä <scop@xemacs.org>"
parents:
4455
diff
changeset
|
407 [XE_EXPAND_COMPLEX_OPTION([$1], xe_fst($2))[]dnl |
3683 | 408 XE_EXPAND_COMPLEX_OPTIONS([$1], XE_CDR($2))])])dnl |
2651 | 409 dnl |
410 dnl XE_INIT_COMPLEX_OPTION(prefix, option_list) | |
411 dnl ------------------------------------------- | |
412 dnl | |
413 dnl Internal macro to initialise the complex option shell variables. | |
414 dnl Variables of the form <prefix>_<option> contain the default value for that | |
415 dnl option. <prefix>_types contains a space-separated list of all the options | |
416 dnl and <prefix>_default contains a comma-separated list of all the default | |
417 dnl values. | |
418 dnl | |
419 define([XE_INIT_COMPLEX_OPTION], | |
3003 | 420 [_[$1]_notfirst="" |
2651 | 421 dnl |
3147 | 422 XE_EXPAND_COMPLEX_OPTIONS($@)dnl |
2651 | 423 _[$1]_types="XE_COMPONENT_LIST" |
424 _[$1]_default="m4_translit(XE_COMPONENT_DEFAULT,[:],[,])" | |
425 dnl Undefine these macros so that they can be reused by later complex | |
426 dnl options. | |
3147 | 427 undefine([XE_COMPONENT_LIST])dnl |
428 undefine([XE_COMPONENT_DEFAULT])dnl | |
3003 | 429 ])dnl |
430 dnl | |
2651 | 431 dnl XE_PARSE_COMPLEX_OPTION(prefix, cmdline-flag) |
432 dnl --------------------------------------------- | |
433 dnl | |
434 dnl Internal macro to parse the option values. If an undeclared option is | |
3073 | 435 dnl found then an error is generated. Because something has been supplied on |
436 dnl the command line initialise all the complex options to 'no' rather than | |
3147 | 437 dnl the default. In this way --enable-complex=foo will give the expected |
3073 | 438 dnl value (no) for bar. |
2651 | 439 dnl |
3147 | 440 dnl #### I think we should add a couple more features. |
441 dnl First, at the end of XE_PARSE_COMPLEX_OPTION check for contradictory args, | |
442 dnl specifically if `all' is specified but the options are all individually | |
443 dnl disabled, or if `none' is specified but the options are all individually | |
444 dnl enabled, we should _warn_ about this situation. | |
445 dnl Second, we should provide an XE_VALIDATE_COMPLEX_OPTION macro to be used | |
446 dnl at the end of detection. If any feature is `yes' but we don't have it, | |
447 dnl then we should XE_DIE. | |
448 dnl | |
2651 | 449 define([XE_PARSE_COMPLEX_OPTION], |
3147 | 450 [dnl Initialize variables for COMPLEX_OPTION [$1]. Leading underscore or |
451 dnl single letter variables are internal to the XE_PARSE_COMPLEX_OPTION macro. | |
452 _[$1]_all_default="" | |
453 _require_[$1]="" | |
454 dnl check first arg for default spec | |
455 case "$with_[$1]" in | |
456 n | no | non | none ) _[$1]_all_default=no ;; | |
457 n,* | no,* | non,* | none,* ) _[$1]_all_default=no ;; | |
458 a | al | all | both ) _[$1]_all_default=yes ;; | |
459 a,* | al,* | all,* | both,* ) _[$1]_all_default=yes ;; | |
460 y | yes ) _require_[$1]=yes ;; | |
461 esac | |
462 dnl if first arg was a default spec, trim it | |
463 if test -n "$_[$1]_all_default$_require_[$1]"; then | |
464 _with_[$1]_args=`echo $with_[$1] | sed -e 's/^[[a-z]]*\(,\(.*\)\)\{0,1\}$/\2/'` | |
465 else | |
466 _with_[$1]_args=$with_[$1] | |
467 fi | |
468 dnl set default for each type | |
469 for y in $_[$1]_types; do | |
470 if test -n "$_[$1]_all_default" ; then | |
471 eval "with_[$1]_${y}=$_[$1]_all_default" | |
472 else | |
473 eval "with_[$1]_$y=\$_[$1]_${y}_default" | |
474 fi | |
3073 | 475 done |
3147 | 476 dnl parse the command line arg and set types found appropriately |
477 for x in `echo "$_with_[$1]_args" | sed -e 's/,/ /g'` ; do | |
2651 | 478 _[$1]_found="" |
3147 | 479 for y in $_[$1]_types; do |
480 if test "$x" = "$y"; then | |
481 _[$1]_found=yes | |
482 eval "with_[$1]_$y=yes" | |
483 elif test "$x" = "no$y"; then | |
484 _[$1]_found=yes | |
485 eval "with_[$1]_$y=no" | |
486 fi | |
487 done | |
488 test -z "$_[$1]_found" && \ | |
489 USAGE_ERROR(["\ | |
490 Invalid type list supplied. Valid types for the [$2] option are: | |
491 $_[$1]_types. | |
492 A prefix of \"no\" (eg, \"notype\" for \"type\") turns a type off. | |
493 Types not explicitly specified or negated take their defaults. | |
494 The list of defaults is \"$_[$1]_default\". Prefixing \`all' or | |
495 \`none' to the list sets all defaults to on and off respectively. | |
496 \`yes' as the sole argument is equivalent to omitting the argument."]) | |
2651 | 497 done |
3147 | 498 dnl copy values to enable_FEATURE_TYPE. Cleanup default vars. |
499 for y in $_[$1]_types; do | |
500 eval "enable_[$1]_$y=\$with_[$1]_$y" | |
501 unset _[$1]_${y}_default | |
502 done | |
503 dnl clean up | |
504 unset _[$1]_types _[$1]_default _[$1]_all_default _[$1]_use_defaults | |
505 unset _with_[$1]_args _[$1]_found x y _require_[$1] | |
3003 | 506 ])dnl |
507 dnl | |
2651 | 508 dnl XE_COMPLEX_OPTION(option, yesno) |
509 dnl -------------------------------- | |
510 dnl | |
511 dnl Declare a complex option and its default value. The value MUST be either | |
512 dnl yes or no or "" (which means maybe). | |
513 dnl | |
514 define([XE_COMPLEX_OPTION],[[$1,$2]]) | |
515 dnl | |
516 dnl XE_COMPLEX_OPTION_HELP_STRING(flag, long, short, components, libraries) | |
517 dnl ----------------------------------------------------------------------- | |
518 dnl Boilerplate help string for complex options. | |
519 dnl #### This doesn't read so well for alternative libraries like sound. | |
520 dnl | |
521 define([XE_COMPLEX_OPTION_HELP_STRING], | |
3312 | 522 [AS_HELP_STRING([$1],[Compile with support for $2. Components that can use |
2651 | 523 $3 are $4. Prefix component with `no' to disable its use of $3. Requires |
3003 | 524 $5 support. Default is $6.])])dnl |
2651 | 525 dnl |
3003 | 526 dnl XE_COMPLEX_ARG(PACKAGE, HELP-STRING, ACTION-IF-TRUE, ACTION-IF-FALSE, |
2651 | 527 dnl [XE_COMPLEX_OPTION(a,yes), ....]) |
528 dnl -------------------------------------------------------------------------- | |
529 dnl | |
3003 | 530 dnl Expanded version of XE_MERGED_ARG for complex options. All the parameters |
2651 | 531 dnl are required. |
532 dnl | |
3003 | 533 define([XE_COMPLEX_ARG], |
534 [XE_INIT_COMPLEX_OPTION(patsubst([$1], -, _), m4_shiftn(4, $@)) | |
535 XE_MERGED_ARG([$1],[$2], | |
536 [XE_PARSE_COMPLEX_OPTION(patsubst([$1], -, _), [--with-$1]) | |
2651 | 537 $3 |
3147 | 538 ],[ |
539 # set default for each type | |
3149 | 540 for y in [$_]patsubst([$1], -, _)[_types]; do |
541 eval "[with_]patsubst([$1], -, _)[_$y]=[\$_]patsubst([$1], -, _)[_${y}_default]" | |
542 eval "[enable_]patsubst([$1], -, _)[_$y]=[\$_]patsubst([$1], -, _)[_${y}_default]" | |
543 unset [_]patsubst([$1], -, _)[_${y}_default] | |
3147 | 544 done |
545 $4])])dnl | |
2651 | 546 dnl |
547 dnl ------------------------------------------------------------------------- | |
548 XE_APPEND(lib-src, MAKE_SUBDIR) | |
549 XE_APPEND(lib-src, INSTALL_ARCH_DEP_SUBDIR) | |
550 with_dragndrop_default="no" | |
551 dnl ------------------------------------------------------------------------- | |
552 dnl Command line argument processing. | |
3312 | 553 dnl Note that AS_HELP_STRING compresses whitespace, wraps, and indents the |
2651 | 554 dnl string to fit the --help display; there's no need to preformat. |
555 dnl | |
556 dnl I think these will be caught by autoconf internal checks, | |
557 dnl only --with-* are unchecked | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
558 dnl --external-widget --with-external-widget |
2651 | 559 dnl --native-sound-lib=LIB --with-native-sound-lib |
560 dnl --mail-locking=TYPE --with-mail-locking | |
561 dnl --rel-alloc --with-rel-alloc | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
562 dnl --use-number-lib --with-bignum |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
563 dnl --debug --with-debug |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
564 dnl --error-checking --with-error-checking |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
565 dnl --memory-usage-stats --with-memory-usage-stats |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
566 dnl --quick-build --with-quick-build |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
567 dnl --use-union-type --with-union-type |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
568 dnl --pdump --with-pdump |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
569 dnl --use-kkcc --with-kkcc |
3003 | 570 dnl |
2651 | 571 dnl parse flags |
3073 | 572 XE_HELP_SUBSECTION([Compilation options]) |
573 XE_MERGED_ARG([compiler], | |
3312 | 574 AS_HELP_STRING([--with-compiler],[C compiler to use]), |
3073 | 575 [], []) |
576 XE_MERGED_ARG([xemacs-compiler], | |
3312 | 577 AS_HELP_STRING([--with-xemacs-compiler], |
3073 | 578 [compiler to use to compile just the xemacs executable and C modules. |
579 If you want to compile XEmacs as C++, use e.g. | |
580 `--with-xemacs-compiler=g++'. This turns on a lot of | |
581 additional error-checking.]), | |
582 [], []) | |
583 XE_MERGED_ARG([gcc], | |
3312 | 584 AS_HELP_STRING([--with-gcc],[Use GCC to compile XEmacs.]), |
3073 | 585 [], []) |
586 XE_MERGED_ARG([cflags], | |
3312 | 587 AS_HELP_STRING([--with-cflags=FLAGS], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
588 [Compiler flags. These flags will be placed after any flags inserted for warnings, debugging or optimization; setting this does not disable the insertion of those flags. Use configure settings such as `--with-optimization=no' or `with-debug=no' to turn them off, or override them with `--with-cflags-optimization', `--with-cflags-debugging', or `with-cflags-warning'.]), |
3073 | 589 [], []) |
590 XE_MERGED_ARG([cflags-warning], | |
3312 | 591 AS_HELP_STRING([--with-cflags-warning=FLAGS],[Override compiler flags used to control warnings. |
3073 | 592 Normally, don't set this, as XEmacs already turns on |
593 the maximum safe warning level.]), | |
594 [], []) | |
595 XE_MERGED_ARG([optimization], | |
3312 | 596 AS_HELP_STRING([--with-optimization],[Control whether compilation is optimized. By default, optimization is on in release versions and off in beta versions, since it can interfere with proper stack backtraces.]), |
3073 | 597 [], []) |
598 XE_MERGED_ARG([cflags-optimization], | |
3312 | 599 AS_HELP_STRING([--with-cflags-optimization=FLAGS], |
3073 | 600 [Override compiler flags used to control optimization. If blank, forces no optimization; if non-blank, forces optimization. Normally, don't set this; XEmacs automatically sets the maximum safe optimization flags appropriate for the compiler being invoked. If you just want to turn optimization on or off, use `with-optimization' instead.]), |
601 [], []) | |
602 XE_MERGED_ARG([cflags-debugging], | |
3312 | 603 AS_HELP_STRING([--with-cflags-debugging=FLAGS], |
3073 | 604 [Override compiler flags used to add debugging information to the executable. Normally, debugging information is added whenever possible (i.e. unless optimization is turned on and the compiler does not permit debugging and optimization simultaneously).]), |
605 [], []) | |
606 XE_MERGED_ARG([cpp], | |
3312 | 607 AS_HELP_STRING([--with-cpp],[C preprocessor to use (e.g. /usr/ccs/lib/cpp or cc -E)]), |
3073 | 608 [CPP="$with_cpp"], []) |
609 XE_MERGED_ARG([cppflags], | |
3312 | 610 AS_HELP_STRING([--with-cppflags],[C preprocessor flags (e.g. -I/foo or -Dfoo=bar)]), |
3073 | 611 [CPPFLAGS="$with_cppflags"], []) |
612 XE_MERGED_ARG([libs=LIBS], | |
3312 | 613 AS_HELP_STRING([--with-libs],[Additional libraries (e.g. -lfoo)]), |
3073 | 614 [LIBS="$with_libs"], []) |
615 XE_MERGED_ARG([ldflags=FLAGS], | |
3312 | 616 AS_HELP_STRING([--with-ldflags],[Additional linker flags (e.g. -L/foo)]), |
3073 | 617 [LDFLAGS="$with_ldflags"], []) |
618 XE_MERGED_ARG([site-includes], | |
3312 | 619 AS_HELP_STRING([--with-site-includes=PATHS],[Prepend to include search path.]), |
3073 | 620 [], []) |
621 XE_MERGED_ARG([site-libraries], | |
3312 | 622 AS_HELP_STRING([--with-site-libraries=PATHS],[Prepend to library search path.]), |
3073 | 623 [], []) |
624 XE_MERGED_ARG([site-prefixes], | |
3312 | 625 AS_HELP_STRING([--with-site-prefixes=PATHS],[Prepend to include and library search paths, with /include and /lib added. Comes after site-includes and site-libraries, if any.]), |
3073 | 626 [], []) |
627 XE_MERGED_ARG([site-runtime-libraries], | |
3312 | 628 AS_HELP_STRING([--with-site-runtime-libraries=PATHS],[Prepend to the runtime library search path]), |
3073 | 629 [], []) |
630 XE_MERGED_ARG([dynamic], | |
3312 | 631 AS_HELP_STRING([--with-dynamic],[Link dynamically if supported by system. 'No' forces static linking.]), |
3073 | 632 [], []) |
633 dnl | |
634 XE_HELP_SUBSECTION([Installation options]) | |
3003 | 635 XE_MERGED_ARG([prefix], |
3312 | 636 AS_HELP_STRING([--with-prefix=no],[Don't compile the value for `prefix' into the executable.]), |
2651 | 637 [true], [with_prefix=yes]) |
3073 | 638 XE_MERGED_ARG([netinstall], |
3312 | 639 AS_HELP_STRING([--with-netinstall],[Support for installation over the internet. |
3073 | 640 Only functional on the MS Windows platforms.]), |
641 [], [with_netinstall="no"]) | |
642 XE_MERGED_ARG([statedir], | |
3312 | 643 AS_HELP_STRING([--with-statedir=DIR],[]), |
3073 | 644 [], [with_statedir='${prefix}/lib']) |
645 XE_MERGED_ARG([lispdir], | |
3312 | 646 AS_HELP_STRING([--with-lispdir=DIR],[]), |
3073 | 647 [AC_DEFINE(LISPDIR_USER_DEFINED)], [with_lispdir='${datadir}/${instvardir}/lisp']) |
648 XE_MERGED_ARG([archlibdir], | |
3312 | 649 AS_HELP_STRING([--with-archlibdir=DIR],[]), |
3073 | 650 [AC_DEFINE(ARCHLIBDIR_USER_DEFINED)], [with_archlibdir='${libdir}/${instvardir}/${configuration}']) |
651 XE_MERGED_ARG([moduledir], | |
3312 | 652 AS_HELP_STRING([--with-moduledir=DIR],[]), |
3073 | 653 [AC_DEFINE(MODULEDIR_USER_DEFINED)], [with_moduledir='${libdir}/${instvardir}/${configuration}/modules']) |
654 XE_MERGED_ARG([etcdir], | |
3312 | 655 AS_HELP_STRING([--with-etcdir=DIR],[]), |
3073 | 656 [AC_DEFINE(ETCDIR_USER_DEFINED)], [with_etcdir='${datadir}/${instvardir}/etc']) |
657 XE_MERGED_ARG([docdir], | |
3312 | 658 AS_HELP_STRING([--with-docdir=DIR],[]), |
3073 | 659 [AC_DEFINE(DOCDIR_USER_DEFINED)], [with_docdir='${archlibdir}']) |
660 dnl | |
661 XE_HELP_SUBSECTION([Run-time path-searching options]) | |
3003 | 662 XE_MERGED_ARG([site-lisp], |
3312 | 663 AS_HELP_STRING([--with-site-lisp=no],[Allow for a site-lisp directory in the XEmacs hierarchy searched before the installation packages.]), |
2651 | 664 [true], [with_site_lisp=no]) |
3003 | 665 XE_MERGED_ARG([site-modules], |
3312 | 666 AS_HELP_STRING([--with-site-modules=no],[Disable site-modules directory in the XEmacs hierarchy, which is searched before the installation modules.]), |
2651 | 667 [], []) |
3179 | 668 XE_MERGED_ARG([early-packages], |
3312 | 669 AS_HELP_STRING([--with-early-packages=DIR],[Specify location of early/user packages (instead of ~/.xemacs; same as --with-user-packages).]), |
3179 | 670 [AC_DEFINE(EARLY_PACKAGE_DIRECTORIES_USER_DEFINED)], []) |
671 XE_MERGED_ARG([user-packages], | |
3312 | 672 AS_HELP_STRING([--with-user-packages=DIR],[Specify location of early/user packages (instead of ~/.xemacs; same as --with-early-packages).]), |
3179 | 673 [AC_DEFINE(EARLY_PACKAGE_DIRECTORIES_USER_DEFINED)], []) |
674 XE_MERGED_ARG([late-packages], | |
3312 | 675 AS_HELP_STRING([--with-late-packages=DIR],[Specify location of late/system packages (instead of default location; same as --with-system-packages).]), |
3179 | 676 [AC_DEFINE(LATE_PACKAGE_DIRECTORIES_USER_DEFINED)], []) |
677 XE_MERGED_ARG([system-packages], | |
3518 | 678 AS_HELP_STRING([--with-system-packages=DIR],[Specify location of late/system packages (instead of default location; same as --with-late-packages).]), |
3179 | 679 [AC_DEFINE(LATE_PACKAGE_DIRECTORIES_USER_DEFINED)], []) |
680 XE_MERGED_ARG([last-packages], | |
3312 | 681 AS_HELP_STRING([--with-last-packages=DIR],[Specify location of last/legacy packages (instead of default location; same as --with-legacy-packages).]), |
3179 | 682 [AC_DEFINE(LAST_PACKAGE_DIRECTORIES_USER_DEFINED)], []) |
683 XE_MERGED_ARG([legacy-packages], | |
4350
50889296c05c
Fix typo of "late packages" for "last packages".
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4328
diff
changeset
|
684 AS_HELP_STRING([--with-legacy-packages=DIR],[Specify location of last/legacy packages (instead of default location; same as --with-last-packages).]), |
50889296c05c
Fix typo of "late packages" for "last packages".
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4328
diff
changeset
|
685 [AC_DEFINE(LAST_PACKAGE_DIRECTORIES_USER_DEFINED)], []) |
3073 | 686 XE_MERGED_ARG([package-path], |
3312 | 687 AS_HELP_STRING([--with-package-path=PATH],[Search path for package directories.]), |
3073 | 688 [AC_DEFINE(PACKAGE_PATH_USER_DEFINED)], []) |
689 XE_MERGED_ARG([infopath], | |
3312 | 690 AS_HELP_STRING([--with-infopath=PATH],[Location of info directories]), |
3073 | 691 [AC_DEFINE(INFOPATH_USER_DEFINED)], []) |
692 dnl | |
693 XE_HELP_SUBSECTION([Window-system options]) | |
3354 | 694 dnl Enable when fontconfig support is factored out of Xft. |
695 dnl XE_MERGED_ARG([fontconfig], | |
696 dnl AS_HELP_STRING([--with-fontconfig], | |
697 dnl [Use fontconfig library to configure fonts.], | |
698 dnl [],[]) | |
3094 | 699 dnl if you change defaults, make sure to fix arg 6 of the OPTION_HELP macro. |
700 XE_COMPLEX_ARG([xft], | |
701 [XE_COMPLEX_OPTION_HELP_STRING([--with-xft], | |
702 [Xft client-side font rendering and anti-aliasing], | |
703 [Xft], | |
704 [`emacs' (buffers), `menubars', `tabs', and `gauges'], | |
705 [X11, Xft, Xrender, freetype, and fontconfig], | |
4496
772c80e0e180
with-xft defaults to xft being used with a default setting.
Mats Lidell <matsl@xemacs.org>
parents:
4475
diff
changeset
|
706 [`noemacs, nomenubars, notabs, nogauges'. |
772c80e0e180
with-xft defaults to xft being used with a default setting.
Mats Lidell <matsl@xemacs.org>
parents:
4475
diff
changeset
|
707 The default when selected is `emacs, nomenubars, notabs, nogauges'])], |
772c80e0e180
with-xft defaults to xft being used with a default setting.
Mats Lidell <matsl@xemacs.org>
parents:
4475
diff
changeset
|
708 [],[with_xft_emacs=no], |
772c80e0e180
with-xft defaults to xft being used with a default setting.
Mats Lidell <matsl@xemacs.org>
parents:
4475
diff
changeset
|
709 [XE_COMPLEX_OPTION([emacs],[yes]), |
3098 | 710 XE_COMPLEX_OPTION([menubars],[no]), |
711 XE_COMPLEX_OPTION([tabs],[no]), | |
712 XE_COMPLEX_OPTION([gauges],[no])]) | |
3003 | 713 XE_MERGED_ARG([gtk], |
3312 | 714 AS_HELP_STRING([--with-gtk],[Support GTK on the X Window System. (EXPERIMENTAL)]), |
2651 | 715 [true], [with_gtk=no]) |
3003 | 716 XE_MERGED_ARG([gnome], |
3312 | 717 AS_HELP_STRING([--with-gnome],[Support GNOME on the X Window System. (EXPERIMENTAL)]), |
2651 | 718 [true], [with_gnome=no]) |
3003 | 719 XE_MERGED_ARG([msw], |
3312 | 720 AS_HELP_STRING([--with-msw],[Support MS Windows as a window system (only under Cygwin and MinGW). `--with-msw=no' may be needed on *nix systems with Wine installed.]), |
2651 | 721 [], []) |
3073 | 722 XE_MERGED_ARG([toolbars], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
723 AS_HELP_STRING([--with-toolbars],[Enable toolbar support. Default: yes.]), |
2651 | 724 [], []) |
3073 | 725 XE_MERGED_ARG([wmcommand], |
3312 | 726 AS_HELP_STRING([--with-wmcommand],[Compile without realized leader window which will |
3073 | 727 keep the WM_COMMAND property.]), |
2651 | 728 [], []) |
3073 | 729 XE_KEYWORD_ARG([athena], |
3312 | 730 AS_HELP_STRING([--with-athena=TYPE],[Use TYPE Athena widgets (`xaw', `3d', `next', `95', or `xpm').]), |
3073 | 731 [],[],[xaw,3d,next,95,xpm])dnl |
732 XE_KEYWORD_ARG([menubars], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
733 AS_HELP_STRING([--with-menubars=TYPE],[Use TYPE menubars ('yes', '`no', `lucid', `motif', `athena', `gtk', or `msw'). The Lucid |
3073 | 734 widgets emulate Motif (mostly) but are faster. |
735 *WARNING* The Motif menubar is currently broken. | |
736 Lucid menubars are the default.]), | |
737 [], [],[yes,no,lucid,motif,athena,gtk,msw]) | |
738 XE_KEYWORD_ARG([scrollbars], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
739 AS_HELP_STRING([--with-scrollbars=TYPE],[Use TYPE scrollbars 'yes', '`no', `lucid', `motif', `athena', `gtk', or `msw'). |
3073 | 740 Lucid scrollbars are the default.]), |
741 [], [],[yes,no,lucid,motif,athena,gtk,msw]) | |
742 XE_KEYWORD_ARG([dialogs], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
743 AS_HELP_STRING([--with-dialogs=TYPE],[Use TYPE dialog boxes 'yes', '`no', `lucid', `motif', `athena', `gtk', or `msw'). |
3073 | 744 There are no true Lucid dialogs; Motif dialogs will be |
745 used if Motif can be found, else Athena is used.]), | |
746 [], [],[yes,no,lucid,motif,athena,gtk,msw]) | |
747 XE_KEYWORD_ARG([widgets], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
748 AS_HELP_STRING([--with-widgets=TYPE],[Use TYPE native widgets ('yes', '`no', `lucid', `motif', `athena', `gtk', or `msw'). |
3073 | 749 Other widget types are currently unsupported. |
750 There are no true Lucid widgets; Motif widgets will be | |
751 used if Motif can be found, else Athena is used.]), | |
752 [], [],[yes,no,lucid,motif,athena,gtk,msw]) | |
3003 | 753 XE_MERGED_ARG([dragndrop], |
3312 | 754 AS_HELP_STRING([--with-dragndrop],[Compile in the generic drag and drop API. This is automatically added if one of the drag and drop |
4790
bc4f2511bbea
Remove support for the OffiX drag-and-drop protocol. See xemacs-patches
Jerry James <james@xemacs.org>
parents:
4769
diff
changeset
|
755 protocols is found (currently CDE, MSWindows, and GTK). |
2651 | 756 *WARNING* The Drag'n'drop support is under development |
757 and is considered experimental.]), | |
758 [], []) | |
3003 | 759 XE_MERGED_ARG([cde], |
3312 | 760 AS_HELP_STRING([--with-cde],[Compile in support for CDE drag and drop.]), |
2651 | 761 [], []) |
3073 | 762 XE_MERGED_ARG([external-widget], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
763 AS_HELP_STRING([--with-external-widget],[Support XEmacs server for text widgets in other applications.]), |
3073 | 764 [], []) |
765 dnl | |
766 XE_HELP_SUBSECTION([TTY (character terminal) options]) | |
767 XE_MERGED_ARG([tty], | |
3312 | 768 AS_HELP_STRING([--with-tty],[Enable TTY support. Default: yes.]), |
3073 | 769 [], []) |
770 XE_MERGED_ARG([ncurses], | |
3312 | 771 AS_HELP_STRING([--with-ncurses],[Use the ncurses library for tty support.]), |
3073 | 772 [], []) |
3003 | 773 XE_MERGED_ARG([gpm], |
3312 | 774 AS_HELP_STRING([--with-gpm],[Compile in GPM mouse support for ttys.]), |
2651 | 775 [], []) |
3073 | 776 dnl |
777 XE_HELP_SUBSECTION([Image options]) | |
3003 | 778 XE_MERGED_ARG([xpm], |
3312 | 779 AS_HELP_STRING([--with-xpm],[Compile with support for XPM images. PRACTICALLY |
2651 | 780 REQUIRED. Although this library is nonstandard and |
781 a real hassle to build, many basic things (e.g. | |
782 toolbars) depend on it, and you will run into | |
783 many problems without it.]), | |
784 [], []) | |
3073 | 785 XE_MERGED_ARG([png], |
3312 | 786 AS_HELP_STRING([--with-png],[Compile with support for PNG images. Recommended |
3073 | 787 because the images on the About page are not viewable |
788 without it.]), | |
789 [], []) | |
790 XE_MERGED_ARG([jpeg], | |
3312 | 791 AS_HELP_STRING([--with-jpeg],[Compile with support for JPEG images. Useful if |
3073 | 792 you are using a mail, news reader, or web browser |
793 in XEmacs, so that JPEG images can be displayed.]), | |
794 [], []) | |
795 XE_MERGED_ARG([tiff], | |
3312 | 796 AS_HELP_STRING([--with-tiff],[Compile with support for TIFF images. Possibly |
3073 | 797 useful, for the same reason as JPEG images.]), |
798 [], []) | |
3003 | 799 XE_MERGED_ARG([xface], |
3312 | 800 AS_HELP_STRING([--with-xface],[Compile with support for X-Face mail headers. |
2651 | 801 Requires the compface package.]), |
802 [], []) | |
3003 | 803 XE_MERGED_ARG([gif], |
4708
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
804 AS_HELP_STRING([--with-gif],[Compile with support for GIF images.]), |
2651 | 805 [], []) |
3073 | 806 dnl |
807 XE_HELP_SUBSECTION([Sound options]) | |
808 XE_COMPLEX_ARG([sound], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
809 AS_HELP_STRING([--with-sound=TYPE],[Compile with sound support. |
3308 | 810 Valid types are `native', `alsa', `nas' and `esd'. |
3073 | 811 Prefix a type with 'no' to disable. |
812 The first type can be `none' or `all'. `none' means | |
3308 | 813 `nonative,noalsa,nonas,noesd'. `all' means |
814 `native,alsa,nas,esd'. Later options override earlier | |
815 ones for the same TYPE. The default is to autodetect | |
816 all sound support except for ESD which defaults to | |
817 off.]), | |
3073 | 818 [], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
819 [with_sound_nas=""], |
3073 | 820 [XE_COMPLEX_OPTION([native],[""]), |
3308 | 821 XE_COMPLEX_OPTION([alsa],[""]), |
3073 | 822 XE_COMPLEX_OPTION([nas],[""]), |
823 XE_COMPLEX_OPTION([esd],[no])]) | |
824 XE_MERGED_ARG([native-sound-lib], | |
3312 | 825 AS_HELP_STRING([--with-native-sound-lib],[Path to sound library (for systems with name conflicts).]), |
2651 | 826 [], []) |
3073 | 827 dnl |
828 XE_HELP_SUBSECTION([Internationalization options]) | |
3003 | 829 XE_MERGED_ARG([mule], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
830 AS_HELP_STRING([--with-mule],[Compile with Mule (Multi-Lingual Emacs) support, |
2651 | 831 needed to support non-Latin-1 (including Asian) |
832 languages.]), | |
833 [], []) | |
3073 | 834 XE_KEYWORD_ARG([xim], |
3312 | 835 AS_HELP_STRING([--with-xim==TYPE],[Enable XIM support. TYPE is `yes', `no', `xlib', or `motif']), |
3073 | 836 [],[],[yes,no,xlib,motif])dnl |
3003 | 837 XE_MERGED_ARG([canna], |
3312 | 838 AS_HELP_STRING([--with-canna],[Support the Canna Japanese input method. Requires Mule.]), |
2651 | 839 [], []) |
3003 | 840 XE_MERGED_ARG([wnn], |
3312 | 841 AS_HELP_STRING([--with-wnn],[Support the Wnn Asian language input |
2651 | 842 method. Requires Mule.]), |
843 [], []) | |
3003 | 844 XE_MERGED_ARG([wnn6], |
3312 | 845 AS_HELP_STRING([--with-wnn6],[Support the Wnn6 Asian language input |
2651 | 846 method (proprietary). Requires Mule.]), |
847 [], []) | |
3073 | 848 XE_MERGED_ARG([xfs], |
3312 | 849 AS_HELP_STRING([--with-xfs],[Enable XFontSet support for internationalized |
3094 | 850 menubar. Incompatible with `--with-xim=motif' and `--with-xft'. |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
851 `--with-menubars=lucid' (the default) is desirable.]), |
3073 | 852 [], []) |
853 dnl | |
854 XE_HELP_SUBSECTION([File-related options]) | |
855 XE_MERGED_ARG([default-eol-detection], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
856 AS_HELP_STRING([--with-default-eol-detection],[Turns on by default auto-detection of end-of-line type |
3073 | 857 when reading a file. Applies to those platforms where |
858 auto-detection is off by default (non-Mule Unix). Has | |
859 no effect otherwise.]), | |
860 [], []) | |
861 XE_MERGED_ARG([clash-detection], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
862 AS_HELP_STRING([--with-clash-detection],[Disable use of lock files to detect multiple edits |
3073 | 863 of the same file.]), |
2651 | 864 [], []) |
3073 | 865 XE_MERGED_ARG([zlib], |
3312 | 866 AS_HELP_STRING([--with-zlib],[Support inflate (de)compression internally.]), |
2651 | 867 [], []) |
3073 | 868 dnl |
869 XE_HELP_SUBSECTION([Database options]) | |
870 XE_COMPLEX_ARG([database], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
871 AS_HELP_STRING([--with-database=TYPE],[Compile with database support. Valid types are |
3073 | 872 `no' or a comma-separated list of one or more |
4412
2f000e022a8b
Fix misspelling of option 'gdbm'.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4401
diff
changeset
|
873 of `berkdb' and either `dbm' or `gdbm'.]), |
3073 | 874 [ |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
875 if test "$with_database_dbm" = "yes" -a "$with_database_gdbm" = "yes"; then |
4412
2f000e022a8b
Fix misspelling of option 'gdbm'.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4401
diff
changeset
|
876 USAGE_ERROR("Only one of \`dbm' and \`gdbm' may be specified |
3073 | 877 with the \`--with-database' option.") |
878 fi | |
879 ], | |
880 [], | |
881 [XE_COMPLEX_OPTION([berkdb],[""]), | |
882 XE_COMPLEX_OPTION([dbm],[""]), | |
883 XE_COMPLEX_OPTION([gdbm],[""])]) | |
3003 | 884 XE_MERGED_ARG([ldap], |
3312 | 885 AS_HELP_STRING([--with-ldap],[Support the LDAP protocol.]), |
2651 | 886 [], []) |
3003 | 887 XE_MERGED_ARG([postgresql], |
3312 | 888 AS_HELP_STRING([--with-postgresql],[Support the PostgreSQL RDBMS.]), |
2651 | 889 [], []) |
3073 | 890 dnl |
891 XE_HELP_SUBSECTION([Mail options]) | |
892 XE_KEYWORD_ARG([mail-locking], | |
3312 | 893 AS_HELP_STRING([--with-mail-locking=TYPE],[Specify the locking to be used by movemail to prevent |
3073 | 894 concurrent updates of mail spool files. Valid types |
895 are `lockf', `flock', `file', `locking', `mmdf' or `pop'.]), | |
896 [],[],[lockf,flock,file,locking,mmdf,pop])dnl | |
3003 | 897 XE_MERGED_ARG([pop], |
3312 | 898 AS_HELP_STRING([--with-pop],[Support POP for mail retrieval.]), |
2651 | 899 [], []) |
3003 | 900 XE_MERGED_ARG([kerberos], |
3312 | 901 AS_HELP_STRING([--with-kerberos],[Support Kerberos-authenticated POP.]), |
2651 | 902 [], []) |
3003 | 903 XE_MERGED_ARG([hesiod], |
3312 | 904 AS_HELP_STRING([--with-hesiod],[Support Hesiod to get the POP server host.]), |
2651 | 905 [], []) |
3073 | 906 dnl |
907 XE_HELP_SUBSECTION([Networking options]) | |
908 XE_MERGED_ARG([tooltalk], | |
3312 | 909 AS_HELP_STRING([--with-tooltalk],[Support the ToolTalk IPC protocol.]), |
2651 | 910 [], []) |
3073 | 911 XE_MERGED_ARG([socks], |
3312 | 912 AS_HELP_STRING([--with-socks],[Compile with support for SOCKS (an Internet proxy).]), |
3073 | 913 [], []) |
914 XE_MERGED_ARG([dnet], | |
3312 | 915 AS_HELP_STRING([--with-dnet],[Compile with support for DECnet.]), |
2651 | 916 [], []) |
3003 | 917 XE_MERGED_ARG([ipv6-cname], |
3312 | 918 AS_HELP_STRING([--with-ipv6-cname],[Try IPv6 information first when canonicalizing host names. This option has no effect unless system supports getaddrinfo(3) and getnameinfo(3).]), |
2651 | 919 [], [with_ipv6_cname="no"]) |
3073 | 920 dnl |
921 XE_HELP_SUBSECTION([Memory allocation options]) | |
922 XE_MERGED_ARG([rel-alloc], | |
3312 | 923 AS_HELP_STRING([--with-rel-alloc],[Enable the relocating allocator.]), |
3073 | 924 [], [with_rel_alloc='default']) |
925 XE_MERGED_ARG([dlmalloc], | |
3312 | 926 AS_HELP_STRING([--with-dlmalloc],[Use Doug Lea's malloc implementation.]), |
3073 | 927 [], [with_dlmalloc='default']) |
928 XE_MERGED_ARG([system-malloc], | |
3312 | 929 AS_HELP_STRING([--with-system-malloc],[Use the system malloc, not the one distributed with XEmacs.]), |
3073 | 930 [], [with_system_malloc='default']) |
931 XE_MERGED_ARG([debug-malloc], | |
3312 | 932 AS_HELP_STRING([--with-debug-malloc],[Use a debugging malloc.]), |
2651 | 933 [], []) |
3003 | 934 XE_MERGED_ARG([pdump], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
935 AS_HELP_STRING([--with-pdump],[Enable portable LISP preloader.]), |
2651 | 936 [], []) |
3003 | 937 XE_MERGED_ARG([dump-in-exec], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
938 AS_HELP_STRING([--with-dump-in-exec],[Enable dumping into executable (enabled by default |
2720 | 939 for `pdump', not enabled by default in combination |
3263 | 940 with `newgc').]), |
2720 | 941 [], []) |
3073 | 942 XE_MERGED_ARG([kkcc], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
943 AS_HELP_STRING([--with-kkcc],[Enable experimental new GC mark algorithms.]), |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
944 [], [with_kkcc=yes]) |
3263 | 945 |
3092 | 946 XE_MERGED_ARG([newgc], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
947 AS_HELP_STRING([--with-newgc],[Enable new incremental garbage collector and new allocator.]), |
3092 | 948 [], []) |
949 XE_COMPLEX_ARG([vdb], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
950 AS_HELP_STRING([--with-vdb=TYPE],[Override auto-detection of |
3092 | 951 virtual-dirty-bit write-barrier implementation for the |
952 new garbage collector. TYPE must be one of "auto" (for | |
953 auto-detection), "posix", "win32", "mach", or "fake" | |
954 (uses the new garbage collector but disables | |
955 incremental collections). The default is to | |
956 use auto-detection.]), | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
957 [], [with_vdb="auto"],[auto,posix,win32,mach,fake,no]) |
3073 | 958 dnl |
959 XE_HELP_SUBSECTION([Emacs Lisp options]) | |
960 XE_MERGED_ARG([modules], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
961 AS_HELP_STRING([--with-modules],[Compile in experimental support for dynamically |
3073 | 962 loaded libraries (Dynamic Shared Objects).]), |
963 [], []) | |
964 XE_KEYWORD_ARG([bignum], | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
965 AS_HELP_STRING([--with-bignum=TYPE],[Compile in support for bignums, ratios, or bigfloats |
3073 | 966 using library support. TYPE must be one of "gmp" |
5739
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
967 (for GNU MP), "mpir" (for MPIR), "mp" (for BSD MP), |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
968 or "no" (disabled).]), |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
969 [], [with_bignum="no"],[no,gmp,mpir,mp]) |
3073 | 970 dnl |
971 XE_HELP_SUBSECTION([Platform Specific options]) | |
972 XE_MERGED_ARG([workshop], | |
3312 | 973 AS_HELP_STRING([--with-workshop],[Support the Sun WorkShop (formerly Sparcworks) |
3073 | 974 development environment.]), |
975 [], []) | |
976 XE_MERGED_ARG([sparcworks], | |
3312 | 977 AS_HELP_STRING([--with-sparcworks],[Alias for --with-workshop]), |
3073 | 978 [], []) |
979 dnl | |
980 XE_HELP_SUBSECTION([Debugging options]) | |
3003 | 981 XE_MERGED_ARG([debug], |
4944
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
982 AS_HELP_STRING([--with-debug],[Enable additional debugging information. No noticeable time cost (unlike |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
983 `--with-error-checking'). This turns adds `-g' to the compiler options so that |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
984 debug information is compiled into the XEmacs executable. It also turns on |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
985 assert checks in the source code (i.e. same as `--with-assertions'); enables |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
986 Lisp commands for determining detailed memory usage statistics (same as |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
987 `--with-memory-usage-stats'); adds various Lisp variables and functions |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
988 that allow one to display internal structures, show the internal workings |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
989 of certain subsystems, and exit to the debugger; causes Lisp errors during |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
990 building to exit to the debugger or dump core; and adds debugging-related |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
991 C functions meant to be called from a debugger.]), |
2651 | 992 [], []) |
4944
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
993 dnl If just --with-error-checking or --with-error-checking=yes is given, |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
994 dnl it should be the same as --with-error-checking=all. Currently it's |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
995 dnl the same as saying nothing at all. |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
996 if test "$with_error_checking" = "yes"; then |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
997 with_error_checking=all |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
998 fi |
3073 | 999 XE_COMPLEX_ARG([error-checking], |
4944
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1000 AS_HELP_STRING([--with-error-checking[=CLASS|all|none]],[Compile with internal error-checking added. |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1001 Causes noticeable loss of speed. Valid classes are `byte_code', `display' |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1002 (redisplay), `extents', `gc' (garbage collection), `glyphs', `malloc' |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1003 (memory allocation), `structures' (C structures), `text' (text handling and |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1004 conversion), `types' (correct Lisp-object type for type-specific |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1005 operations). `all' or `none' can be given to set all or no classes, |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1006 respectively. Any of the classes can be prefixed with `no' to turn the |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1007 class off. A comma-separated list of classes can also be given. For |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1008 example, `all,nogc' turns on all but garbage-collection-related checking. |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1009 Omitting any argument or specifying just `yes' is the same as `all'.]), |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1010 [], [], |
6af9b2e79451
Fixes to configure so --with-error-checking=yes works
Ben Wing <ben@xemacs.org>
parents:
4939
diff
changeset
|
1011 dnl Keep TESTS sorted to help with syncing doc to reality. |
3959 | 1012 [XE_COMPLEX_OPTION([byte_code],[""]), |
1013 XE_COMPLEX_OPTION([display],[""]), | |
1014 XE_COMPLEX_OPTION([extents],[""]), | |
3073 | 1015 XE_COMPLEX_OPTION([gc],[""]), |
3959 | 1016 XE_COMPLEX_OPTION([glyphs],[""]), |
3073 | 1017 XE_COMPLEX_OPTION([malloc],[""]), |
3961 | 1018 XE_COMPLEX_OPTION([structures],[""]), |
3959 | 1019 XE_COMPLEX_OPTION([text],[""]), |
3961 | 1020 XE_COMPLEX_OPTION([types],[""])]) |
3003 | 1021 XE_MERGED_ARG([assertions], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1022 AS_HELP_STRING([--with-assertions],[Compile in runtime assertions.]), |
2651 | 1023 [], []) |
3003 | 1024 XE_MERGED_ARG([memory-usage-stats], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1025 AS_HELP_STRING([--with-memory-usage-stats],[Enable LISP memory usage API.]), |
2651 | 1026 [], []) |
3003 | 1027 XE_MERGED_ARG([quick-build], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1028 AS_HELP_STRING([--with-quick-build],[Speed up the build cycle by leaving out steps where |
2651 | 1029 XEmacs will still work (more or less) without them. |
1030 Potentially dangerous if you don't know what you're | |
5050
6f2158fa75ed
Fix quick-build, use asserts() in place of ABORT()
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1031 doing. This (1) Doesn't garbage-collect after loading |
6f2158fa75ed
Fix quick-build, use asserts() in place of ABORT()
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1032 each file during dumping, (2) Doesn't |
2651 | 1033 automatically rebuild the DOC file (remove it by hand |
1034 to get it rebuilt), (3) Removes config.h, lisp.h and | |
1035 associated files from the dependency lists, so changes | |
1036 to these files don't automatically cause all .c files | |
5050
6f2158fa75ed
Fix quick-build, use asserts() in place of ABORT()
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1037 to be rebuilt, (4) Doesn't check for Lisp shadows.]), |
2651 | 1038 [], []) |
3073 | 1039 XE_MERGED_ARG([union-type], |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1040 AS_HELP_STRING([--with-union-type],[Use union definition of Lisp_Object type. Known to trigger bugs in some compilers.]), |
2651 | 1041 [], []) |
3073 | 1042 XE_MERGED_ARG([quantify], |
3312 | 1043 AS_HELP_STRING([--with-quantify],[Support performance debugging using Quantify.]), |
3073 | 1044 [], []) |
1045 XE_MERGED_ARG([purify], | |
3312 | 1046 AS_HELP_STRING([--with-purify],[Support memory debugging using Purify.]), |
3073 | 1047 [], []) |
4803
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
1048 XE_MERGED_ARG([valgrind], |
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
1049 AS_HELP_STRING([--with-valgrind],[Support memory debugging using Valgrind.]), |
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
1050 [], []) |
2651 | 1051 dnl ------------------------------------------------------------------------- |
1052 dnl Final command line argument checks. | |
1053 | |
1054 dnl --with-quantify or --with-purify imply --with-system-malloc | |
1055 if test "$with_purify" = "yes" -o "$with_quantify" = "yes"; then | |
1056 test "$with_system_malloc" = "default" && with_system_malloc=yes | |
1057 fi | |
1058 | |
1059 dnl CDE requires tooltalk | |
1060 XE_CHECK_FEATURE_DEPENDENCY(cde, tooltalk) | |
1061 | |
3094 | 1062 dnl Xft sanity checking |
1063 dnl #### Maybe we should XE_DIE here instead? Or fix the UI so that | |
1064 dnl emacs is always implicit? (I worry that --without-xft would be weird.) | |
1065 if test \( "$with_xft_menubars" = "yes" -o "$with_xft_tabs" = "yes" \ | |
1066 -o "$with_xft_gauges" = "yes" \) -a "$with_xft_emacs" = "no"; then | |
1067 AC_MSG_WARN([Forcing --with-xft=emacs because Xft is enabled]) | |
1068 with_xft_emacs=yes | |
1069 fi | |
1070 | |
1071 dnl XFS and Xft in menubars conflict | |
1072 if test "$with_xfs" = "yes" -a "$with_xft_menubars" = "yes"; then | |
1073 USAGE_ERROR("XFS and Xft in the menubars are incompatible!") | |
1074 fi | |
1075 | |
2651 | 1076 dnl ------------------------------------------------------------------------- |
1077 dnl Local paths | |
1078 test "x$prefix" = xNONE && prefix=$ac_default_prefix | |
1079 # Let make expand exec_prefix. | |
1080 if test "x$exec_prefix" = xNONE | |
1081 then | |
1082 exec_prefix='${prefix}' | |
1083 else | |
1084 AC_DEFINE(EXEC_PREFIX_USER_DEFINED) | |
1085 fi | |
3729 | 1086 |
1087 define([XE_EXPAND_VARIABLE], | |
1088 [$2=[$]$1 | |
1089 while true; do | |
1090 case "[$]$2" in | |
1091 *\[$]* ) eval "$2=[$]$2" ;; | |
1092 *) break ;; | |
1093 esac | |
1094 done])dnl XE_EXPAND_VARIABLE | |
1095 | |
1096 XE_EXPAND_VARIABLE(prefix,prefix_expanded) | |
1097 XE_EXPAND_VARIABLE(datadir,datadir_expanded) | |
4455
49f8ed034500
Fix path-configuration glitches:
Mike Sperber <sperber@deinprogramm.de>
parents:
4450
diff
changeset
|
1098 XE_EXPAND_VARIABLE(exec_prefix,exec_prefix_expanded) |
49f8ed034500
Fix path-configuration glitches:
Mike Sperber <sperber@deinprogramm.de>
parents:
4450
diff
changeset
|
1099 XE_EXPAND_VARIABLE(libdir,libdir_expanded) |
49f8ed034500
Fix path-configuration glitches:
Mike Sperber <sperber@deinprogramm.de>
parents:
4450
diff
changeset
|
1100 XE_EXPAND_VARIABLE(infodir,infodir_expanded) |
3729 | 1101 |
4660
32be564c53dd
More accurate tests for explicitly-set paths.
Mike Sperber <sperber@deinprogramm.de>
parents:
4656
diff
changeset
|
1102 if test "x$datadir" != "x\${datarootdir}" |
2651 | 1103 then |
1104 AC_DEFINE(INFODIR_USER_DEFINED) | |
1105 AC_DEFINE(LISPDIR_USER_DEFINED) | |
1106 AC_DEFINE(ETCDIR_USER_DEFINED) | |
5149
b72f27a08ed5
Reflect --with-datadir setting in late-package directories.
Mike Sperber <sperber@deinprogramm.de>
parents:
5050
diff
changeset
|
1107 AC_DEFINE(LATE_PACKAGE_DIRECTORIES_USER_DEFINED) |
4092 | 1108 fi |
1109 | |
4660
32be564c53dd
More accurate tests for explicitly-set paths.
Mike Sperber <sperber@deinprogramm.de>
parents:
4656
diff
changeset
|
1110 if test "x$libdir" != "x\${exec_prefix}/lib" |
2651 | 1111 then |
1112 AC_DEFINE(MODULEDIR_USER_DEFINED) | |
1113 AC_DEFINE(ARCHLIBDIR_USER_DEFINED) | |
1114 AC_DEFINE(DOCDIR_USER_DEFINED) | |
1115 fi | |
3729 | 1116 |
4660
32be564c53dd
More accurate tests for explicitly-set paths.
Mike Sperber <sperber@deinprogramm.de>
parents:
4656
diff
changeset
|
1117 if test "x$infodir" != "x\${datarootdir}/info" |
2651 | 1118 then |
1119 AC_DEFINE(INFODIR_USER_DEFINED) | |
1120 else | |
4118 | 1121 infodir='${datarootdir}/${instvardir}/info' |
2651 | 1122 fi |
1123 | |
1124 with_sitelispdir='${datadir}/${inststaticdir}/site-lisp' | |
1125 inststaticdir='${PROGNAME}' | |
1126 instvardir='${PROGNAME}-${version}' | |
1127 sitemoduledir='${libdir}/${inststaticdir}/site-modules' | |
5149
b72f27a08ed5
Reflect --with-datadir setting in late-package directories.
Mike Sperber <sperber@deinprogramm.de>
parents:
5050
diff
changeset
|
1128 with_late_packages='${datadir}/${PROGNAME}' |
2651 | 1129 |
1130 AC_SUBST(inststaticdir) | |
1131 AC_SUBST(statedir,$with_statedir) | |
1132 | |
1133 dnl ------------------------------------------------------------------------- | |
1134 | |
1135 AC_PROG_LN_S | |
1136 | |
1137 dnl Make symlinks for etc, lisp, and info directories while the path | |
1138 dnl is still relative. We do not symlink lock because someone may | |
1139 dnl have stuck the source on a read-only partition. Instead we | |
1140 dnl create it as an actual directory later on if it does not already | |
1141 dnl exist. | |
1142 for dir in lisp etc man info tests; do | |
1143 if test ! -d "$dir" ; then | |
1144 echo Making symbolic link to "$srcdir/$dir" | |
1145 ${LN_S} "$srcdir/$dir" "$dir" | |
1146 fi | |
1147 done | |
1148 | |
1149 dnl Calculate canonical name for blddir (i.e. current directory). | |
1150 dnl PWD may already be the preferable absolute name for ".", | |
1151 dnl but we can't trust it - it is sometimes inaccurate. | |
1152 absolute_pwd="`pwd`"; | |
1153 if test -n "$PWD" -a "`cd $PWD && pwd`" = "$absolute_pwd" | |
1154 then blddir="$PWD" | |
1155 else blddir="$absolute_pwd"; CANONICALIZE_PATH(blddir) | |
1156 fi | |
1157 AC_SUBST(blddir) | |
1158 | |
1159 dnl Make srcdir absolute, if not already. It is important to | |
1160 dnl avoid running the path through pwd unnecessary, since pwd can | |
1161 dnl give you automounter prefixes, which can go away. | |
1162 case "$srcdir" in | |
1163 /* ) ;; | |
1164 . ) srcdir="$blddir" ;; | |
1165 * ) srcdir="`cd $srcdir && pwd`"; CANONICALIZE_PATH(srcdir) ;; | |
1166 esac | |
1167 | |
1168 dnl Check if the source directory already has a configured system in it. | |
1169 if test `pwd` != `sh -c cd $srcdir && pwd` \ | |
1170 && test -f "$srcdir/src/config.h"; then | |
1171 (echo "$progname: WARNING: The directory tree \`$srcdir' is being used" | |
1172 echo " as a build directory right now; it has been configured in its own" | |
1173 echo " right. To configure in another directory as well, you MUST" | |
1174 echo " use GNU make. If you do not have GNU make, then you must" | |
1175 echo " now do \`make distclean' in $srcdir," | |
1176 echo " and then run $progname again.") >&2 | |
1177 extrasub='/^VPATH[[ ]]*=/c\ | |
1178 vpath %.c $(srcdir)\ | |
1179 vpath %.h $(srcdir)\ | |
1180 vpath %.y $(srcdir)\ | |
1181 vpath %.l $(srcdir)\ | |
1182 vpath %.s $(srcdir)\ | |
1183 vpath %.in $(srcdir)' | |
1184 fi | |
1185 | |
2741 | 1186 dnl ------------------------------------------------------------------------- |
1187 AC_CONFIG_AUX_DIR_DEFAULT | |
1188 AC_CANONICAL_BUILD | |
1189 dnl ------------------------------------------------------------------------- | |
1190 | |
2651 | 1191 dnl ---------------------------------------- |
1192 dnl Find out which version of XEmacs this is | |
1193 dnl ---------------------------------------- | |
4419
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4412
diff
changeset
|
1194 dnl This should be the same code as in Makefile.in.in |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4412
diff
changeset
|
1195 cp "$srcdir/version.sh.in" "$srcdir/version.sh" |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4412
diff
changeset
|
1196 if test -d "$srcdir/.hg"; then |
eb82fbb675ea
Use Mercurial changeset hash to identify build version.
Mike Sperber <sperber@deinprogramm.de>
parents:
4412
diff
changeset
|
1197 (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:
4412
diff
changeset
|
1198 fi |
2651 | 1199 . "$srcdir/version.sh" || exit 1; |
1200 dnl Must do the following first to determine verbosity for AC_DEFINE | |
1201 if test -n "$emacs_is_beta"; then beta=yes; else beta=no; fi | |
1202 : "${verbose=$beta}" | |
1203 version="${emacs_major_version}.${emacs_minor_version}" | |
1204 AC_DEFINE_UNQUOTED(EMACS_MAJOR_VERSION, $emacs_major_version) | |
1205 AC_DEFINE_UNQUOTED(EMACS_MINOR_VERSION, $emacs_minor_version) | |
1206 if test -n "$emacs_beta_version" ; then | |
1207 if test "$beta" = "yes"; then | |
1208 version="${version}-b${emacs_beta_version}" | |
1209 AC_DEFINE_UNQUOTED(EMACS_BETA_VERSION, $emacs_beta_version) | |
1210 else | |
1211 version="${version}.${emacs_beta_version}" | |
1212 AC_DEFINE_UNQUOTED(EMACS_PATCH_LEVEL, $emacs_beta_version) | |
1213 fi | |
1214 fi | |
1215 AC_DEFINE_UNQUOTED(XEMACS_CODENAME, "$xemacs_codename") | |
3972 | 1216 dnl for etags |
1217 verbose_version=$version | |
2651 | 1218 if test "$xemacs_extra_name" != ""; then |
1219 AC_DEFINE_UNQUOTED(XEMACS_EXTRA_NAME, "$xemacs_extra_name") | |
3972 | 1220 verbose_version="$verbose_version $xemacs_extra_name" |
2651 | 1221 fi |
1222 if test "$xemacs_release_date" != ""; then | |
1223 AC_DEFINE_UNQUOTED(XEMACS_RELEASE_DATE, "$xemacs_release_date") | |
1224 fi | |
1225 AC_DEFINE_UNQUOTED(EMACS_VERSION, "$version") | |
1226 | |
5228
5efbd1253905
Remove all support for InfoDock.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5149
diff
changeset
|
1227 PROGNAME=xemacs |
5efbd1253905
Remove all support for InfoDock.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5149
diff
changeset
|
1228 SHEBANG_PROGNAME=xemacs-script |
2651 | 1229 |
4449
13ce402e1736
Call AC_SUBST on SHEBANG_PATHNAME, for #! support.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4448
diff
changeset
|
1230 AC_SUBST(SHEBANG_PROGNAME) |
2651 | 1231 |
1232 AC_DEFINE_UNQUOTED(EMACS_PROGNAME, "$PROGNAME") | |
1233 | |
4448
fd8a9a4d81d9
Support #!, to allow XEmacs to be called as a script interpreter.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4401
diff
changeset
|
1234 AC_DEFINE_UNQUOTED(SHEBANG_PROGNAME, "${PROGNAME}-script") |
fd8a9a4d81d9
Support #!, to allow XEmacs to be called as a script interpreter.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4401
diff
changeset
|
1235 |
2651 | 1236 dnl ---------------------------------- |
1237 dnl Error checking and debugging flags | |
1238 dnl ---------------------------------- | |
1239 dnl Error checking default to "yes" in beta versions, to "no" in releases. | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1240 dnl Same goes for --with-debug and --extra-verbosity. |
2651 | 1241 if test -n "$emacs_is_beta"; then beta=yes; else beta=no; fi |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1242 test "${with_error_checking_extents:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_EXTENTS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1243 test "${with_error_checking_types:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_TYPES) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1244 test "${with_error_checking_text:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_TEXT) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1245 test "${with_error_checking_gc:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_GC) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1246 test "${with_error_checking_malloc:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_MALLOC) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1247 test "${with_error_checking_byte_code:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_BYTE_CODE) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1248 test "${with_error_checking_glyphs:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_GLYPHS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1249 test "${with_error_checking_display:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_DISPLAY) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1250 test "${with_error_checking_structures:=$beta}" = yes && AC_DEFINE(ERROR_CHECK_STRUCTURES) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1251 dnl with_debug=yes must be set when error checking is present. This should be |
2651 | 1252 dnl fixed up. |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1253 dnl with_debug implies other options |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1254 if test "${with_debug:=$beta}" = "yes"; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1255 with_assertions=yes |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1256 with_memory_usage_stats=yes |
2651 | 1257 AC_DEFINE(DEBUG_XEMACS) |
1258 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1259 test "$with_assertions" = "yes" && AC_DEFINE(USE_ASSERTIONS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1260 test "$with_memory_usage_stats" = "yes" && AC_DEFINE(MEMORY_USAGE_STATS) |
2651 | 1261 |
1262 dnl ------------------------------ | |
1263 dnl Determine the s&m files to use | |
1264 dnl ------------------------------ | |
1265 dnl Given the configuration name, set machfile and opsysfile to the | |
1266 dnl names of the m/*.h and s/*.h files we should use. | |
1267 | |
1268 dnl Canonicalize the configuration name. | |
1269 XE_STRIP_4TH_COMPONENT(ac_cv_build_alias) | |
1270 XE_STRIP_4TH_COMPONENT(ac_cv_build) | |
1271 AC_SUBST(configuration, $ac_cv_build) | |
1272 | |
1273 dnl If you add support for a new configuration, add code to this | |
1274 dnl switch statement to recognize your configuration name and select | |
1275 dnl the appropriate operating system and machine description files. | |
1276 | |
1277 dnl You would hope that you could choose an m/*.h file pretty much | |
1278 dnl based on the machine portion of the configuration name, and an s- | |
1279 dnl file based on the operating system portion. However, it turns out | |
1280 dnl that each m/*.h file is pretty manufacturer-specific - for | |
1281 dnl example, apollo.h, hp9000s300.h, mega68k, news.h, and tad68k are | |
1282 dnl all 68000 machines; mips.h, pmax.h, and news-risc are all MIPS | |
1283 dnl machines. So we basically have to have a special case for each | |
1284 dnl configuration name. | |
1285 | |
1286 dnl As far as handling version numbers on operating systems is | |
1287 dnl concerned, make sure things will fail in a fixable way. If | |
1288 dnl /etc/MACHINES says nothing about version numbers, be | |
1289 dnl prepared to handle anything reasonably. If version numbers | |
1290 dnl matter, be sure /etc/MACHINES says something about it. | |
1291 | |
1292 dnl Eric Raymond says we should accept strings like "sysvr4" to mean | |
1293 dnl "System V Release 4"; he writes, "The old convention encouraged" | |
1294 dnl "confusion between `system' and `release' levels'." | |
1295 | |
1296 machine='' opsys='' | |
1297 | |
1298 dnl Straightforward machine determination | |
1299 case "$ac_cv_build" in | |
1300 sparc-*-* ) machine=sparc ;; | |
1301 alpha*-*-* ) machine=alpha ;; | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1302 mips*-* ) machine=mips ;; |
2651 | 1303 rs6000-ibm-aix* ) machine=ibmrs6000 ;; |
1304 powerpc-ibm-aix* ) machine=ibmrs6000 ;; | |
1305 powerpc*-* ) machine=powerpc ;; | |
1306 hppa-*-* ) machine=hp800 ;; | |
1307 arm* ) machine=arm ;; | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1308 i[[3-9]]86-*-* ) machine=intel386 ;; |
5920
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1309 x86_64-*-* ) machine=x86_64 ;; |
2651 | 1310 esac |
1311 | |
1312 dnl Straightforward OS determination | |
1313 case "$ac_cv_build" in | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1314 *-*-linux* ) opsys=linux ;; |
2651 | 1315 *-*-netbsd* ) opsys=netbsd ;; |
1316 *-*-openbsd* ) opsys=openbsd ;; | |
1317 | |
1318 dnl AIX | |
1319 *-*-aix[[4-9]]* ) opsys=aix4-2 ;; | |
1320 | |
1321 dnl Other generic OSes | |
1322 *-gnu* ) opsys=gnu ;; | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1323 *-*-bsd4.3 ) opsys=bsd-common ;; |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1324 *-*-aos* ) opsys=bsd-common ;; |
2651 | 1325 *-*-sysv4.1* | *-*-sysvr4.1* )opsys=usg5-4 NON_GNU_CPP=/usr/lib/cpp ;; |
1326 *-*-sysv4.[[2-9]]* | *-sysvr4.[[2-9]]* ) | |
1327 if test -z "$NON_GNU_CPP" ; then | |
1328 for prog in "/usr/ccs/lib/cpp" "/lib/cpp"; do | |
1329 if test -f "$prog"; then NON_GNU_CPP="$prog"; break; fi | |
1330 done | |
1331 fi | |
1332 opsys=usg5-4-2 ;; | |
1333 *-sysv4* | *-sysvr4* ) opsys=usg5-4 ;; | |
1334 *-*-mach_bsd4.3* ) opsys=mach-bsd4-3 ;; | |
1335 esac | |
1336 | |
1337 case "$ac_cv_build" in | |
1338 | |
1339 dnl Darwin, a.k.a. MacOS X (based on Mach and Freebsd) | |
1340 *-*-darwin*) | |
1341 opsys=darwin | |
4738
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
1342 dnl Use this to set BSD correctly. |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
1343 AC_DEFINE(USE_PARAM_H) |
2651 | 1344 ;; |
1345 | |
1346 dnl HP-UX | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
1347 *-hp-hpux* ) machine=hp800 opsys=hpux11 |
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
1348 NON_GNU_CC="cc -Ae" NON_GNU_CPP="cc -Ae -E" |
2651 | 1349 |
1350 case "$ac_cv_build" in *-hp-hpux*shr* ) opsys="${opsys}-shr" ;; esac | |
1351 ;; | |
1352 | |
1353 dnl Workstations sold by MIPS | |
1354 dnl This is not necessarily all workstations using the MIPS processor - | |
1355 dnl Irises are produced by SGI, and DECstations by DEC. | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1356 mips-mips-bsd* ) opsys=bsd-common ;; |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1357 mips-mips-* ) opsys=usg5-4-2 ;; |
2651 | 1358 |
1359 dnl Silicon Graphics machines | |
1360 dnl Iris 4D | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1361 mips-sgi-irix6* ) opsys=irix6-5 ;; |
2651 | 1362 |
1363 dnl Suns | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
1364 *-*-solaris* | *-sun-mach* | *-sun-bsd* ) |
2651 | 1365 dnl Make $canonical even more so. |
1366 case "$ac_cv_build" in *-sunos5*) | |
1367 ac_cv_build=`echo $ac_cv_build | sed -e s/sunos5/solaris2/`;; | |
1368 esac | |
1369 | |
1370 case "$ac_cv_build" in | |
1371 *-solaris2* ) | |
1372 #test -f /usr/ccs/lib/cpp && NON_GNU_CPP=/usr/ccs/lib/cpp | |
1373 RANLIB=':' ;; | |
1374 esac | |
1375 | |
1376 case "$ac_cv_build" in | |
1377 *-solaris* ) | |
1378 opsys=sol2 | |
1379 os_release_major=`uname -r | sed -e 's/^\([[0-9]]\{1,\}\)\.\([[0-9]]\{1,\}\).*/\1/'` | |
1380 os_release_minor=`uname -r | sed -e 's/^\([[0-9]]\{1,\}\)\.\([[0-9]]\{1,\}\).*/\2/'` | |
1381 case "$os_release_minor" in [[0-9]]) | |
1382 os_release_minor="0${os_release_minor}";; | |
1383 esac | |
1384 os_release="${os_release_major}${os_release_minor}" | |
1385 AC_DEFINE_UNQUOTED(OS_RELEASE, $os_release) ;; | |
1386 | |
1387 *-mach* ) opsys=mach-bsd4-3 ;; | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1388 * ) opsys=bsd-common ;; |
2651 | 1389 esac |
1390 | |
1391 dnl Watch out for a compiler guaranteed not to work. | |
1392 test "$opsys $CC" = "sol2 /usr/ucb/cc" && CC="" | |
1393 ;; | |
1394 | |
5920
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1395 dnl 64-bit machines where we do not care about the manufacturer |
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1396 x86_64-*-* ) |
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1397 case "$ac_cv_build" in |
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1398 *-cygwin* ) opsys=cygwin64 ;; |
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1399 dnl Otherwise, we fall through to the generic opsys code at the bottom. |
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1400 esac |
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1401 ;; |
0f2338afbabf
Minimum necessary to get started:
Henry Thompson <ht@markup.co.uk>
parents:
5767
diff
changeset
|
1402 |
2651 | 1403 dnl Intel 386 machines where we do not care about the manufacturer |
1404 i[[3-9]]86-*-* ) | |
1405 case "$ac_cv_build" in | |
1406 *-mach* ) opsys=mach-bsd4-3 ;; | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1407 *-sysv5* ) opsys=usg5-4-2 ;; |
2651 | 1408 *-freebsd* ) opsys=freebsd ;; |
1409 *-pc-cygwin* ) opsys=cygwin32 ;; | |
1410 *-pc-mingw* ) opsys=mingw32 ; | |
1411 test -z "$with_tty" && with_tty="no";; | |
1412 dnl Otherwise, we fall through to the generic opsys code at the bottom. | |
1413 esac | |
1414 ;; | |
1415 | |
1416 esac | |
1417 | |
1418 dnl Initialize machine from $canonical if not in our database above. | |
1419 test -z "$machine" && machine=`echo $ac_cv_build | sed 's/-.*$//'` | |
1420 | |
1421 dnl Initialize opsys from `uname -s` if not in our database above. | |
1422 test -z "$opsys" && opsys=`uname -s | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz` | |
1423 | |
1424 dnl Use configure-time autodetection if s&m not available | |
1425 if test -r "${srcdir}/src/m/${machine}.h"; then | |
1426 machfile="m/${machine}.h" | |
1427 AC_DEFINE_UNQUOTED(config_machfile, "$machfile") | |
1428 else | |
1429 echo "XEmacs has no builtin knowledge of \`$machine' machines." | |
1430 echo "Using configure-time autodetection only." | |
1431 fi | |
1432 | |
1433 if test -r "${srcdir}/src/s/${opsys}.h"; then | |
1434 opsysfile="s/${opsys}.h" | |
1435 AC_DEFINE_UNQUOTED(config_opsysfile, "$opsysfile") | |
1436 else | |
1437 echo "XEmacs has no builtin knowledge of \`$opsys' operating systems." | |
1438 echo "Using configure-time autodetection only." | |
1439 fi | |
1440 | |
1441 | |
1442 dnl -------------------------------------------------------------- | |
1443 dnl $opsys detection complete; defaults depending on $opsys follow | |
1444 dnl -------------------------------------------------------------- | |
1445 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1446 if test -z "$with_pdump"; then |
2651 | 1447 case "$opsys" in |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1448 linux* ) with_pdump=yes ;; dnl glibc 2.3.1 seems to hose unexec |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1449 darwin ) with_pdump=yes ;; dnl No "native" working dumper available |
4848
bde90bc762f2
Remove support for non-pdump on Cygwin.
Jerry James <james@xemacs.org>
parents:
4842
diff
changeset
|
1450 cygwin* ) with_pdump=yes ;; dnl No "native" dumper available |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1451 * ) with_pdump=no ;; |
2651 | 1452 esac |
1453 fi | |
1454 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1455 if test "$with_newgc" = "yes"; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1456 if test "$with_vdb" = "auto"; then |
3092 | 1457 case "$opsys" in |
3520 | 1458 darwin ) case "$machine" in |
5564
209024442c24
Examine $machine more carefully when choosing VDB implementation, NEW_GC
Aidan Kehoe <kehoea@parhasard.net>
parents:
5558
diff
changeset
|
1459 intel386 ) check_vdb_posix=yes ;; |
5761
a9fd35f939a5
Fix VDB detection on x86_64 Macs.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5748
diff
changeset
|
1460 x86_64 ) check_vdb_posix=yes ;; |
3520 | 1461 * ) AC_DEFINE(VDB_MACH) have_vdb_mach=yes ;; |
1462 esac ;; | |
3092 | 1463 cygwin* ) AC_DEFINE(VDB_WIN32) have_vdb_win32=yes ;; |
1464 linux* ) check_vdb_posix=yes ;; | |
1465 freebsd ) check_vdb_posix=yes ;; | |
1466 dnl if not sure, try posix first, maybe we are lucky | |
1467 * ) check_vdb_posix=yes ;; | |
1468 esac | |
1469 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1470 case "$with_vdb" in |
3092 | 1471 mach ) AC_DEFINE(VDB_MACH) have_vdb_mach=yes ;; |
1472 win32 ) AC_DEFINE(VDB_WIN32) have_vdb_win32=yes ;; | |
1473 posix ) check_vdb_posix=yes ;; | |
1474 fake ) have_vdb_fake=yes ;; | |
1475 no ) have_vdb_fake=yes ;; | |
1476 esac | |
1477 fi | |
1478 fi | |
1479 | |
2651 | 1480 if test -z "$with_dynamic"; then |
1481 case "$opsys" in | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
1482 hpux* ) with_dynamic=no ;; |
2651 | 1483 *) with_dynamic=yes ;; |
1484 esac | |
1485 fi | |
1486 if test "$with_dynamic" = "yes"; then | |
1487 case "$opsys" in | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
1488 hpux* ) opsys="${opsys}-shr" ;; |
2651 | 1489 esac |
1490 else dnl "$with_dynamic" = "no" | |
1491 case "$opsys" in | |
1492 sol2 ) | |
1493 echo "Static linking is not supported on Solaris 2." | |
1494 echo "Rerun configure without specifying --without-dynamic." | |
1495 exit 1 ;; | |
1496 linux ) ld_call_shared="-Bstatic" ;; | |
1497 esac | |
1498 fi | |
1499 | |
1500 dnl Tools configuration | |
1501 case "$opsys" in | |
1502 aix* ) NON_GNU_CC=xlc ;; dnl Use xlc by default on AIX | |
1503 darwin ) RANLIB="ranlib -c" ;; dnl Avoid link error in lwlib-config.c | |
1504 esac | |
1505 | |
1506 stack_trace_eye_catcher=`echo ${PROGNAME}_${version}_${ac_cv_build} | sed 'y/.-/__/'` | |
1507 AC_DEFINE_UNQUOTED(STACK_TRACE_EYE_CATCHER, $stack_trace_eye_catcher) | |
1508 | |
1509 dnl -------------------------------------------------- | |
1510 dnl Determine the compiler, set up for feature testing | |
1511 dnl -------------------------------------------------- | |
1512 | |
1513 dnl Sun Development environment support | |
1514 test "$with_sparcworks" = "yes" && with_workshop=yes # compatibility alias | |
1515 XE_CHECK_FEATURE_DEPENDENCY(workshop, tooltalk) | |
1516 if test "$with_workshop" = "yes"; then | |
1517 AC_DEFINE(SUNPRO) | |
1518 fi | |
1519 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1520 if test "$with_clash_detection" != "no"; then |
2651 | 1521 AC_DEFINE(CLASH_DETECTION) |
1522 fi | |
1523 | |
1524 dnl Choose a compiler from (in order) | |
2680 | 1525 dnl --with-compiler, env var CC, with_gcc=no && ${NON_GNU_CC:-cc}, AC_PROG_CC |
2651 | 1526 test -n "$with_compiler" && CC="$with_compiler" |
1527 if test "$with_gcc" = "no"; then dnl Try to find a non-gcc compiler | |
1528 case "$CC" in "" | *gcc* ) CC="${NON_GNU_CC-cc}" ;; esac | |
1529 fi | |
1530 | |
1531 dnl If we don't set CFLAGS here, AC_PROG_CC will set it. | |
1532 dnl But we know better what's good for us, so we do our own | |
1533 dnl computation of real CFLAGS later. | |
1534 dnl --with_cflags overrides environment variable CFLAGS | |
1535 test "${with_cflags-unset}" != unset && CFLAGS="$with_cflags" | |
1536 if test "${CFLAGS-unset}" != unset | |
1537 then cflags_specified=yes; | |
1538 else cflags_specified=no; | |
1539 fi | |
1540 | |
1541 if test "${with_cflags_warning-unset}" != unset | |
1542 then cflags_warning_specified=yes; | |
1543 else cflags_warning_specified=no; | |
1544 fi | |
1545 | |
2667 | 1546 if test "${with_cflags_optimization-unset}" != unset |
2651 | 1547 then cflags_optimization_specified=yes; |
1548 else cflags_optimization_specified=no; | |
1549 fi | |
1550 | |
2667 | 1551 if test "${with_cflags_debugging-unset}" != unset |
2651 | 1552 then cflags_debugging_specified=yes; |
1553 else cflags_debugging_specified=no; | |
1554 fi | |
1555 | |
1556 xe_save_CFLAGS="$CFLAGS" | |
1557 | |
1558 AC_AIX dnl Defines _ALL_SOURCE on AIX. | |
1559 | |
1560 AC_PROG_CC dnl Autoconf has its own magic for compiler autodetection | |
1561 | |
1562 dnl Retry using random guesswork if AC_PROG_CC got it wrong... | |
1563 if test "$with_gcc" = "no" -a "$GCC" = "yes"; then | |
1564 CC=${NON_GNU_CC-cc} | |
1565 AC_PROG_CC | |
1566 elif test "$with_gcc" = "yes" -a "$GCC" != "yes" ; then | |
1567 CC=gcc | |
1568 AC_PROG_CC | |
1569 fi | |
1570 CFLAGS="$xe_save_CFLAGS" | |
1571 | |
1572 dnl Determine GCC version. | |
1573 if test "$GCC" = "yes"; then | |
1574 AC_RUN_IFELSE([AC_LANG_SOURCE([int main () { | |
3494 | 1575 return __GNUC__; |
1576 }])], [:], [__GCC="$?"]) | |
1577 AC_RUN_IFELSE([AC_LANG_SOURCE([int main () { | |
1578 return __GNUC_MINOR__; | |
1579 }])], [:], [__GCC_MINOR="$?"]) | |
1580 __GCC_VERSION=$__GCC"."$__GCC_MINOR | |
1581 echo "You appear to be using GCC version" $__GCC_VERSION | |
2651 | 1582 fi |
1583 | |
1584 dnl Support for using a different compiler for xemacs itself. | |
1585 dnl Useful for building XEmacs with a C++ compiler. | |
1586 dnl For example, `configure --compiler=gcc --xemacs-compiler=g++ | |
1587 | |
1588 dnl The compiler used to build xemacs, as opposed to the compiler | |
1589 dnl used by configure and lib-src, is determined from the following | |
1590 dnl sources, in order of priority: | |
2680 | 1591 dnl o --with-xemacs-compiler configure flag |
2651 | 1592 dnl o XEMACS_CC environment variable |
1593 dnl o same as the regular compiler, (determined previously) | |
1594 | |
1595 dnl We don't do AC_PROG_CC for XEMACS_CC; if we can't trust these people.... | |
1596 test -n "$with_xemacs_compiler" && XEMACS_CC="$with_xemacs_compiler" | |
1597 : ${XEMACS_CC:="$CC"} | |
1598 | |
4932 | 1599 dnl Are we using g++? |
1600 | |
1601 AC_MSG_CHECKING(whether we are using g++) | |
1602 | |
1603 dnl Is it named g++*? | |
1604 XEMACS_CC_GPP=no | |
1605 case "$XEMACS_CC" in | |
1606 *g++* ) XEMACS_CC_GPP=yes ;; | |
1607 esac | |
1608 | |
1609 dnl If it's known to be in the GCC family, does it claim to be g++? We don't | |
1610 dnl run this test unless we know it's GCC-like, because not all compilers | |
1611 dnl accept --version. | |
1612 dnl | |
1613 dnl It's not clear we need both tests, but it doesn't hurt. g++ might not | |
1614 dnl have always output "g++" as the first thing in its version string, and | |
1615 dnl might not always in the future. | |
1616 if test "$XEMACS_CC_GPP" = "no" -a "$GCC" = "yes"; then | |
1617 case "`$XEMACS_CC --version`" in | |
1618 g++* ) XEMACS_CC_GPP=yes ;; | |
1619 esac | |
1620 fi | |
1621 | |
1622 AC_MSG_RESULT($XEMACS_CC_GPP) | |
1623 | |
2651 | 1624 dnl Figure out what C preprocessor to use. |
1625 | |
1626 dnl On Sun systems, people sometimes set up the variable CPP | |
1627 dnl with a value that is a directory, not an executable at all. | |
1628 dnl Detect that case, and ignore that value. | |
1629 test -n "$CPP" -a -d "$CPP" && CPP= | |
1630 | |
1631 test -n "$NON_GNU_CPP" -a "$GCC" != "yes" -a -z "$CPP" && CPP="$NON_GNU_CPP" | |
1632 | |
1633 AC_PROG_CPP | |
1634 | |
1635 dnl -------------------------------------------------------------------- | |
1636 dnl Compiler feature macros | |
1637 dnl -------------------------------------------------------------------- | |
1638 | |
1639 dnl We want feature macros defined here *and* in config.h.in, so that | |
1640 dnl the compilation environment at configure time and compile time agree. | |
1641 | |
1642 AC_MSG_CHECKING(for GNU libc) | |
3312 | 1643 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <features.h>],[ |
2651 | 1644 #if ! (defined __GLIBC__ || defined __GNU_LIBRARY__) |
1645 #error Not a GNU libc system :-( | |
1646 ******* ======= ******** &&&&&&&& | |
1647 #endif | |
3312 | 1648 ])], have_glibc=yes, have_glibc=no) |
2651 | 1649 AC_MSG_RESULT($have_glibc) |
1650 dnl I'm tired of pop being broken with GLIBC -slb | |
1651 dnl Well. then why not fix fucking pop? | |
1652 test "$have_glibc" = "yes" && AC_DEFINE(_GNU_SOURCE) | |
1653 | |
1654 dnl We'd like to use vendor extensions, where available. | |
1655 dnl We'd like to use functions from the latest Unix98 standards. | |
1656 dnl See http://www.opengroup.org/onlinepubs/007908799/xsh/compilation.html | |
1657 case "$opsys" in | |
1658 sol2) | |
1659 AC_DEFINE(__EXTENSIONS__) | |
1660 dnl Solaris 2 before 2.5 had some bugs with feature test macro interaction. | |
1661 if test "$os_release" -ge 505; then | |
1662 AC_DEFINE(_XOPEN_SOURCE,500) | |
1663 AC_DEFINE(_XOPEN_SOURCE_EXTENDED) | |
1664 fi ;; | |
1665 linux) | |
1666 AC_DEFINE(_POSIX_C_SOURCE,199506L) | |
1667 dnl #### should this be 600? | |
1668 AC_DEFINE(_XOPEN_SOURCE,500) | |
1669 AC_DEFINE(_XOPEN_SOURCE_EXTENDED) | |
1670 ;; | |
1671 freebsd4*) | |
1672 AC_DEFINE(_POSIX_C_SOURCE,199506L) | |
1673 dnl #### Do we want these too? Apparently yes for _XOPEN_SOURCE=500. | |
1674 AC_DEFINE(_XOPEN_SOURCE,500) | |
1675 dnl AC_DEFINE(_XOPEN_SOURCE_EXTENDED) | |
1676 ;; | |
1677 esac | |
1678 | |
1679 dnl Identify compilers to enable compiler-specific hacks. | |
1680 dnl Add support for other compilers HERE! | |
1681 dnl GCC is already identified elsewhere. | |
1682 AC_RUN_IFELSE([AC_LANG_SOURCE([int main () { | |
1683 #if defined __SUNPRO_C | |
1684 return 11; | |
1685 #elif defined __DECC | |
1686 return 12; | |
1687 #elif defined __USLC__ && defined __SCO_VERSION__ | |
1688 return 13; | |
1689 #elif defined __INTEL_COMPILER | |
1690 return 14; | |
1691 #else | |
1692 return 0; | |
1693 #endif | |
1694 }])], [], | |
1695 [case "$?" in | |
1696 11) echo "You appear to be using the SunPro C compiler." ; __SUNPRO_C=yes ;; | |
1697 12) echo "You appear to be using the DEC C compiler." ; __DECC=yes ;; | |
1698 13) echo "You appear to be using the SCO C compiler." ; __USLC__=yes ;; | |
1699 14) echo "You appear to be using the Intel C++ compiler."; __ICC=yes | |
1700 dnl Newer versions of icc claim to be GCC | |
1701 GCC=no ;; | |
1702 esac]) | |
1703 | |
1704 dnl -------------------------------------------------------------------- | |
1705 dnl Extract some information from the operating system and machine files | |
1706 dnl -------------------------------------------------------------------- | |
1707 | |
1708 echo "Extracting information from the machine- and system-dependent headers..." | |
1709 | |
1710 dnl It is not important that this name contain the PID; you cannot run | |
1711 dnl two configures in the same directory and have anything work | |
1712 dnl anyway. | |
1713 tempcname="conftest.c" | |
1714 | |
1715 dnl CPP_to_sh(CPP_SYMBOL, SH_VAR, DEFAULT_VALUE) | |
1716 define([CPP_to_sh], | |
1717 [[#]ifndef [$1] | |
1718 [#]define [$1]ifelse([$3],,, [ "$3"]) | |
1719 [#]endif | |
1720 configure___ [$2]=[$1] | |
1721 ])dnl CPP_to_sh | |
1722 | |
1723 dnl CPP_boolean_to_sh(CPP_SYMBOL, SH_VAR) | |
1724 define([CPP_boolean_to_sh], | |
1725 [[#]ifdef [$1] | |
1726 configure___ [$2]=yes | |
1727 [#]else | |
1728 configure___ [$2]=no | |
1729 [#]endif | |
1730 ])dnl CPP_boolean_to_sh | |
1731 | |
1732 cat > $tempcname < confdefs.h | |
1733 cat >> $tempcname <<EOF | |
1734 #define NOT_C_CODE | |
1735 #define C_SWITCH_SITE | |
1736 #define C_SWITCH_X_SITE | |
1737 #define LD_SWITCH_SITE | |
1738 #define LD_SWITCH_X_SITE | |
1739 #define LD_SWITCH_X_SITE_AUX | |
1740 #define OS_RELEASE $os_release | |
1741 | |
1742 #ifdef config_opsysfile | |
1743 #include "$srcdir/src/$opsysfile" | |
1744 #endif | |
1745 | |
1746 #ifdef config_machfile | |
1747 #include "$srcdir/src/$machfile" | |
1748 #endif | |
1749 | |
1750 CPP_to_sh(LIBS_MACHINE, libs_machine) | |
1751 CPP_to_sh(LIBS_SYSTEM, libs_system) | |
1752 CPP_to_sh(LIBS_TERMCAP, libs_termcap) | |
1753 CPP_to_sh(LIB_STANDARD, libs_standard) | |
1754 | |
1755 CPP_to_sh(OBJECTS_MACHINE, objects_machine) | |
1756 CPP_to_sh(OBJECTS_SYSTEM, objects_system) | |
1757 | |
1758 CPP_to_sh(C_SWITCH_MACHINE, c_switch_machine) | |
1759 CPP_to_sh(C_SWITCH_SYSTEM, c_switch_system) | |
1760 | |
1761 CPP_to_sh(LD_SWITCH_MACHINE, ld_switch_machine) | |
1762 CPP_to_sh(LD_SWITCH_SYSTEM, ld_switch_system) | |
1763 | |
1764 CPP_to_sh(UNEXEC, unexec) | |
1765 | |
1766 CPP_to_sh(SYSTEM_TYPE, system_type) | |
1767 | |
1768 CPP_to_sh(LD_SWITCH_SHARED, ld_switch_shared, -c) | |
1769 | |
1770 #define ORDINARY_LD "\$(CC) \$(CFLAGS)" | |
1771 configure___ ordinary_ld=ORDINARY_LD | |
1772 | |
1773 #ifdef ORDINARY_LINK | |
1774 #define LD ORDINARY_LD | |
1775 #else /* no ORDINARY LINK */ | |
1776 #ifdef LINKER | |
1777 #define LD LINKER | |
1778 #else /* ! defined (LINKER) */ | |
1779 #define LD "ld" | |
1780 #endif /* ! defined (LINKER) */ | |
1781 #endif /* not ORDINARY_LINK */ | |
1782 configure___ ld=LD | |
1783 | |
1784 CPP_to_sh(LIB_GCC, lib_gcc) | |
1785 CPP_to_sh(LD_TEXT_START_ADDR, ld_text_start_addr) | |
1786 | |
1787 #if ! defined (ORDINARY_LINK) && !defined (START_FILES) | |
1788 #ifdef NO_REMAP | |
1789 #define START_FILES "pre-crt0.o /lib/crt0.o" | |
1790 #else /* ! defined (NO_REMAP) */ | |
1791 #define START_FILES "ecrt0.o" | |
1792 #endif /* ! defined (NO_REMAP) */ | |
1793 #endif /* no ORDINARY_LINK */ | |
1794 #ifndef START_FILES | |
1795 #define START_FILES | |
1796 #endif | |
1797 configure___ start_files=START_FILES | |
1798 | |
1799 CPP_boolean_to_sh(ORDINARY_LINK, ordinary_link) | |
1800 CPP_boolean_to_sh(SYSTEM_MALLOC, system_malloc) | |
1801 CPP_boolean_to_sh(TERMINFO, have_terminfo) | |
1802 dnl The MAIL_USE_xxx variables come from the s&m headers | |
1803 CPP_boolean_to_sh(MAIL_USE_FLOCK, mail_use_flock) | |
1804 CPP_boolean_to_sh(MAIL_USE_LOCKF, mail_use_lockf) | |
1805 CPP_boolean_to_sh(MAIL_USE_LOCKING, mail_use_locking) | |
1806 CPP_boolean_to_sh(HAVE_WIN32_PROCESSES, win32_processes) | |
1807 EOF | |
1808 | |
1809 dnl The value of CPP is a quoted variable reference, so we need to do this | |
1810 dnl to get its actual value... | |
1811 CPP=`eval "echo $CPP $CPPFLAGS"` | |
1812 define(TAB, [ ])dnl | |
1813 eval `$CPP -Isrc $tempcname \ | |
1814 | sed -n -e "s/[[ TAB]]*=[[ TAB\"]]*/='/" -e "s/[[ TAB\"]]*\$/'/" -e "s/^configure___//p"` | |
1815 | |
1816 rm $tempcname | |
1817 | |
1818 dnl s&m files shouldn't be required to define anything, or even to exist. | |
1819 dnl So we default SYSTEM_TYPE to the obvious documented standard, `uname -s`, | |
1820 dnl appropriately emacsulated. | |
1821 test -z "$system_type" && \ | |
1822 AC_DEFINE_UNQUOTED(SYSTEM_TYPE,"`uname -s | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`") | |
1823 | |
1824 dnl If the s&m files don't define a system-specific dumper, simply use pdump. | |
1825 dnl Sometime in the future, we'll remove all definitions of UNEXEC | |
1826 dnl from all the s&m files. | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1827 test -z "$unexec" && with_pdump=yes |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1828 |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1829 if test "$with_pdump" = "yes"; then |
2651 | 1830 ordinary_link="yes" |
1831 ld="${ordinary_ld}" | |
1832 start_files= | |
1833 libs_standard= | |
1834 unexec= | |
1835 lib_gcc= | |
1836 fi | |
1837 | |
3263 | 1838 dnl Enable KKCC by default |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1839 test -z "$with_kkcc" && with_kkcc=yes |
2790 | 1840 |
2720 | 1841 dnl Dump into executable |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1842 if test -z "$with_dump_in_exec"; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1843 if test "$with_pdump" = "yes"; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1844 if test "$with_newgc" = "yes"; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1845 with_dump_in_exec=no |
2720 | 1846 else |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1847 with_dump_in_exec=yes |
2720 | 1848 fi |
1849 fi | |
1850 fi | |
1851 | |
3092 | 1852 dnl New incremental garbage collector |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1853 if test "$with_newgc" = "yes"; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
1854 with_kkcc=yes |
3092 | 1855 fi |
1856 | |
2651 | 1857 dnl For debugging... |
1858 test "$verbose" = "yes" && \ | |
1859 PRINT_VAR(libs_machine libs_system libs_termcap libs_standard | |
1860 objects_machine objects_system c_switch_machine c_switch_system | |
1861 ld_switch_machine ld_switch_system unexec ld_switch_shared | |
1862 ld lib_gcc ld_text_start_addr start_files ordinary_link | |
1863 have_terminfo mail_use_flock mail_use_lockf) && echo "" | |
1864 | |
1865 dnl Pick up mingw include path | |
1866 dnl We only cope with headers in mingw, not mingw32: no previous version of | |
1867 dnl XEmacs supported mingw and cygnus have made this incompatible change | |
1868 dnl so we just go with the flow. | |
1869 case "$opsys" in mingw* | cygwin*) | |
3228 | 1870 cygwin_include=`eval gcc -print-search-dirs | sed -ne s'/install: //p'` |
1871 cygwin_include=`eval "cd $cygwin_include/../../../..; pwd"` | |
1872 cygwin_include="-I$cygwin_include/include" ; | |
2651 | 1873 extra_includes="$cygwin_include/mingw $cygwin_include" ; |
1874 case "$opsys" in mingw*) | |
1875 XE_APPEND($extra_includes, c_switch_system) ;; | |
1876 esac | |
1877 ;; | |
1878 esac | |
1879 | |
1880 dnl Non-ordinary link usually requires -lc | |
1881 test "$ordinary_link" = "no" -a -z "$libs_standard" && libs_standard="-lc" | |
1882 | |
1883 dnl ----------------------- | |
1884 dnl Compiler-specific hacks | |
1885 dnl ----------------------- | |
1886 | |
1887 dnl DEC C `-std1' means ANSI C mode | |
1888 test "$__DECC" = "yes" && XE_APPEND(-std1, c_switch_site) | |
1889 | |
1890 dnl Some versions of SCO native compiler need -Kalloca | |
1891 if test "$__USLC__" = yes; then | |
1892 AC_MSG_CHECKING(for whether the -Kalloca compiler flag is needed) | |
1893 need_kalloca=no | |
3317 | 1894 AC_LINK_IFELSE([AC_LANG_PROGRAM([], [void *x = alloca(4);])], [:], [ |
2651 | 1895 xe_save_c_switch_system="$c_switch_system" |
1896 c_switch_system="$c_switch_system -Kalloca" | |
3317 | 1897 AC_LINK_IFELSE([AC_LANG_PROGRAM([], [void *x = alloca(4);])], |
3312 | 1898 [ need_kalloca=yes ]) |
2651 | 1899 c_switch_system="$xe_save_c_switch_system"]) |
1900 AC_MSG_RESULT($need_kalloca) | |
1901 test "$need_kalloca" = "yes" && XE_APPEND(-Kalloca,c_switch_system) | |
1902 fi | |
1903 | |
1904 dnl If we're specifying XEMACS_CC, it'd better be in the same family | |
1905 dnl as CC or the following flag calculations are bogus. | |
4510
bd1fbed783dd
Improve g++ detection.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3972
diff
changeset
|
1906 dnl No error/abort; detection is too fragile. |
bd1fbed783dd
Improve g++ detection.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3972
diff
changeset
|
1907 |
bd1fbed783dd
Improve g++ detection.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3972
diff
changeset
|
1908 xemacs_cc_cc_mismatch=no |
2651 | 1909 if test "$CC" != "$XEMACS_CC"; then |
4932 | 1910 if test "$XEMACS_CC_GPP" = "yes" -a "$GCC" != "yes"; then |
1911 AC_MSG_WARN([CC and g++ are mismatched; XE_CFLAGS may be wrong]) | |
1912 xemacs_cc_cc_mismatch=yes | |
1913 fi | |
1914 if test -n "$GCC" -a "$XEMACS_CC_GPP" != "yes" ; then | |
1915 AC_MSG_WARN([gcc and XEMACS_CC are mismatched; XE_CFLAGS may be wrong]) | |
1916 xemacs_cc_cc_mismatch=yes | |
4543
fe64f1351cbd
Fix my syntax errors.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4537
diff
changeset
|
1917 fi |
2651 | 1918 dnl #### Add other detectable mismatches here. |
1919 fi | |
1920 | |
1921 dnl Calculate optimization flags. These will be off by default in beta | |
1922 dnl versions and on in release versions. | |
1923 | |
2667 | 1924 if test -z "$with_optimization"; then |
2992 | 1925 # If user set --with-cflags-optimization, use it to unilaterally |
1926 # determine whether optimization should be enabled. | |
1927 if test "$cflags_optimization_specified" = "yes" ; then | |
3443 | 1928 if test -z "$with_cflags_optimization" ; then |
2992 | 1929 with_optimization=no |
1930 else | |
1931 with_optimization=yes | |
1932 fi | |
1933 elif test -z "$emacs_is_beta" ; then | |
2667 | 1934 with_optimization=yes |
1935 else | |
2651 | 1936 with_optimization=no |
1937 fi | |
1938 fi | |
1939 | |
1940 AC_MSG_CHECKING([for preferred optimization flags]) | |
4932 | 1941 if test "$cflags_optimization_specified" = "no"; then |
1942 if test "$with_optimization" = "yes" ; then | |
2651 | 1943 dnl Following values of cflags_optimization are known to work well. |
1944 dnl Should we take debugging options into consideration? | |
1945 if test "$GCC" = "yes"; then | |
4932 | 1946 dnl If you want to remove the -fno-strict-aliasing, then you will have |
1947 dnl to rewrite all cases of "type-punning" expressions like | |
1948 dnl (* (foo *) (&bar)), which occur all over XEmacs, by making `bar' a | |
1949 dnl union (use an anonymous union if you're willing to put in an ifdef | |
1950 dnl for anon-union support, falling back to the type-punned expression. | |
1951 with_cflags_optimization="-O3 -fno-strict-aliasing" | |
2651 | 1952 elif test "$__SUNPRO_C" = "yes"; then |
1953 case "$opsys" in | |
1954 sol2 ) with_cflags_optimization="-xO4" ;; | |
1955 esac | |
1956 elif test "$__DECC" = "yes"; then | |
1957 with_cflags_optimization="-O3" | |
1958 elif test "$CC" = "xlc"; then | |
1959 dnl see http://www.nersc.gov/vendor_docs/ibm/vac/sc094959.pdf | |
1960 with_cflags_optimization="-O3 -qstrict -qnoansialias -qlibansi -qmaxmem=20000" | |
1961 elif test "$__ICC" = "yes"; then | |
1962 with_cflags_optimization="-O3 -Ob2" | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1963 elif test "$opsys" = "irix6-5"; then |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1964 dnl Optimize, inaccurate debugging, increase limit on size of what's |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1965 dnl optimized. |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1966 dnl |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1967 dnl This should also be applicable other than on Irix 6.5, but I don't |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1968 dnl know for which compiler versions. -- fx |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1969 with_cflags_optimization="-O -OPT:Olimit=3500" |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1970 dnl #### FIXME FOR LCC: |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1971 dnl elif test "USE_LCC" = "yes"; then |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1972 dnl with_cflags_optimization="-O4 -Oi" |
2651 | 1973 dnl ### Add optimal cflags_optimization support for other compilers HERE! |
1974 else | |
1975 with_cflags_optimization="-O" ;dnl The only POSIX-approved flag | |
1976 fi | |
4932 | 1977 elif test "$XEMACS_CC_GPP" = "yes" ; then |
1978 dnl Fuck me! g++ v4 turns on strict aliasing by default, even without | |
1979 dnl optimization. See comment above about why we can't have strict | |
1980 dnl aliasing currently in XEmacs. | |
1981 with_cflags_optimization="-fno-strict-aliasing" | |
2651 | 1982 fi |
1983 fi | |
1984 | |
1985 AC_MSG_RESULT([${with_cflags_optimization}]) | |
1986 | |
1987 AC_MSG_CHECKING([for preferred debugging flags]) | |
1988 if test "$cflags_debugging_specified" = "no"; then | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1989 if test "$GCC" = "no" -a "$opsys" = "irix6-5" -a "$with_optimization" = "yes" ; then |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1990 dnl MIPSpro C special debugging stuff for use with optimization |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1991 with_cflags_debugging="-g3" |
2651 | 1992 dnl ### Add optimal debugging support for other compilers HERE! |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1993 else |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1994 with_cflags_debugging="-g" |
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1995 fi |
2651 | 1996 |
1997 debugging_ok_with_optimization=no | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
1998 if test "$GCC" = "yes" -o "$CC" = "xlc" -o "$__ICC" = "yes" -o "$opsys" = "irix6-5"; then |
2651 | 1999 debugging_ok_with_optimization=yes |
2000 fi | |
2001 | |
2002 if test "$with_optimization" = "yes" -a "$debugging_ok_with_optimization" = "no"; then | |
2003 with_cflags_debugging= | |
2004 fi | |
2005 fi | |
2006 AC_MSG_RESULT([${with_cflags_debugging}]) | |
2007 | |
2008 dnl Calculate warning flags. We separate the flags for warnings from | |
2009 dnl the other flags because we want to force the warnings to be seen | |
2010 dnl by everyone who doesn't specifically override them. | |
2011 | |
2012 AC_MSG_CHECKING([for preferred warning flags for XEMACS_CC]) | |
2013 | |
2014 dnl If this stays nil, it will be set to cflags_warning before use. | |
2015 xe_cflags_warning="" | |
2016 | |
2017 if test "$cflags_warning_specified" = "no"; then | |
2018 dnl Following warning flags are known to work well. | |
2019 if test "$__SUNPRO_C" = "yes"; then | |
2020 case "$opsys" in | |
2021 sol2 ) with_cflags_warning="-v" ;; | |
2022 esac | |
2023 elif test "$CC" = "xlc"; then | |
2024 with_cflags_warning="-qinfo" | |
2025 elif test "$GCC" = "yes"; then | |
2026 with_cflags_warning="-Wall -Wno-switch -Wundef" | |
2027 dnl This is not very useful, as it issues warnings that may appear | |
2028 dnl or disappear rather randomly, cannot easily be fixed, and are | |
2029 dnl not a big deal. If you want it, add it yourself. | |
2030 dnl with_cflags_warning="$with_cflags_warning -Winline" | |
2031 | |
2032 dnl Yuck, bad compares have been worth at least 3 crashes! | |
2033 dnl Warnings about char subscripts are pretty pointless, though, | |
2034 dnl and we use them in various places. | |
2035 with_cflags_warning="$with_cflags_warning -Wsign-compare -Wno-char-subscripts" | |
3494 | 2036 test "$__GCC" -ge 3 && with_cflags_warning="$with_cflags_warning -Wpacked" |
2651 | 2037 dnl glibc is intentionally not `-Wpointer-arith'-clean. |
2038 dnl Ulrich Drepper has rejected patches to fix the glibc header files. | |
2039 test "$have_glibc" != "yes" && \ | |
2040 with_cflags_warning="$with_cflags_warning -Wpointer-arith" | |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2041 dnl |
2651 | 2042 dnl Warning flags that may differ for gcc and g++ (xemacs_compiler) |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2043 dnl |
2651 | 2044 dnl With g++, -Wshadow produces five zillion utterly random warnings -- |
2045 dnl a local var named `buffer' conflicts with `struct buffer' for | |
2046 dnl example. Even with gcc, -Wshadow is questionable because of its | |
2047 dnl complaints about parameters with the same names as global functions. | |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2048 dnl There is no -Wmissing-declarations, -Wmissing-prototypes, or |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2049 dnl -Wstrict-prototypes under g++. |
2651 | 2050 dnl But gcc warns about -Weffc++ in C compiles. |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2051 dnl |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2052 dnl with_cflags_warning_c is for C-only warnings. |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2053 dnl with_cflags_warning_cxx is for C++-only warnings. |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2054 dnl with_cflags_warning_c_xe is for C-only warnings and only when |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2055 dnl compiling the source tree (i.e. when --xemacs-compiler is used). |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2056 with_cflags_warning_c="-Wshadow -Wmissing-declarations" |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2057 with_cflags_warning_c="$with_cflags_warning_c -Wmissing-prototypes -Wstrict-prototypes" |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2058 with_cflags_warning_cxx="-Weffc++" |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2059 with_cflags_warning_c_xe="" |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2060 dnl -Wunused-parameter only appeared in gcc 3. |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2061 dnl -Wdeclaration-after-statement only appeared in gcc 3.4, and is C-only. |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2062 dnl -Wunused-parameter is too annoying for use in lib-src, partly because |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2063 dnl the UNUSED() decl is in compiler.h and we don't include that in any |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2064 dnl of the lib-src files. |
2651 | 2065 dnl With g++, there is no effective way to use -Wunused-parameter without |
2066 dnl some very ugly code changes. | |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2067 if test "$__GCC" -ge 3; then |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2068 with_cflags_warning_c_xe="$with_cflags_warning_c_xe -Wunused-parameter" |
3494 | 2069 if test "$__GCC" -gt 3 || test "$__GCC_MINOR" -ge 4; then |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2070 with_cflags_warning_c="$with_cflags_warning_c -Wdeclaration-after-statement" |
3494 | 2071 fi |
2651 | 2072 fi |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2073 dnl **** If more gcc/g++ flags are added, add them above, not below |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2074 dnl |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2075 dnl Now set warnings for the source tree (xe_cflags_warning) and for |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2076 dnl lib-src (with_cflags_warning). Note that if we didn't set |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2077 dnl xe_cflags_warning, it would automatically be initialized from |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2078 dnl with_cflags_warning. |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2079 if test "$XEMACS_CC_GPP" = "yes"; then |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2080 xe_cflags_warning="$with_cflags_warning $with_cflags_warning_cxx" |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2081 else |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2082 xe_cflags_warning="$with_cflags_warning $with_cflags_warning_c $with_cflags_warning_c_xe" |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2083 fi |
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2084 with_cflags_warning="$with_cflags_warning $with_cflags_warning_c" |
2651 | 2085 elif test "$__ICC" = "yes"; then |
5016
2ade80e8c640
enable more warnings and fix them
Ben Wing <ben@xemacs.org>
parents:
4991
diff
changeset
|
2086 dnl This will apply to both source tree and lib-src |
2651 | 2087 with_cflags_warning="-Wall -w1 -we147" |
2088 dnl ### Add optimal with_cflags_warning support for other compilers HERE! | |
2089 fi | |
2090 fi | |
2091 test -z "$xe_cflags_warning" && xe_cflags_warning="$with_cflags_warning" | |
2092 AC_MSG_RESULT([${xe_cflags_warning}]) | |
2093 | |
2094 AC_MSG_CHECKING([for preferred warning flags for CC]) | |
2095 AC_MSG_RESULT([${with_cflags_warning}]) | |
2096 | |
2097 dnl Calculate remaining cflags. | |
2098 dnl Use either command line flag, environment var, or autodetection | |
2099 | |
2100 AC_MSG_CHECKING([for remaining CFLAGS]) | |
2101 | |
2102 if test "$cflags_specified" = "no"; then | |
2103 dnl Following values of CFLAGS are known to work well. | |
2104 if test "$CC" = "xlc"; then | |
2105 CFLAGS="-qro" | |
2106 dnl ### Add optimal CFLAGS support for other compilers HERE! | |
2107 fi | |
2108 fi | |
2109 AC_MSG_RESULT([${CFLAGS}]) | |
2110 | |
2111 dnl Now combine all C flags. Put the warning and optimization flags first | |
2112 dnl so that user-specified flags will override. | |
2113 dnl Do XE_CFLAGS before adding flags to CFLAGS. | |
2114 dnl Flags for XEMACS_CC: | |
2115 | |
2116 XE_CFLAGS="$xe_cflags_warning $with_cflags_debugging $with_cflags_optimization $CFLAGS" | |
2117 dnl Flags for CC: | |
2118 CFLAGS="$with_cflags_warning $with_cflags_debugging $with_cflags_optimization $CFLAGS" | |
2119 | |
2120 AC_MSG_CHECKING([total value of XE_CFLAGS]) | |
2121 AC_MSG_RESULT([${XE_CFLAGS}]) | |
2122 AC_MSG_CHECKING([total value of CFLAGS]) | |
2123 AC_MSG_RESULT([${CFLAGS}]) | |
2124 | |
2125 dnl Search for GCC specific build problems we know about | |
2126 if test "$GCC" = "yes"; then | |
2127 AC_MSG_CHECKING(for buggy gcc versions) | |
2128 GCC_VERSION=`$CC --version` | |
2129 case `uname -s`:`uname -m`:$GCC_VERSION in | |
2130 dnl egcs 2.90.21 (egcs-1.00 release) | |
2131 dnl egcs 2.90.29 (egcs-1.0.3 release) | |
2132 *:sun4*:2.8.1|*:sun4*:egcs-2.90.*) | |
2133 dnl Don't use -O2 with gcc 2.8.1 and egcs 1.0 under SPARC architectures | |
2134 dnl without also using `-fno-schedule-insns'. | |
2135 case "$CFLAGS" in | |
2136 *-O2*|*-O3*) | |
2137 case "$CFLAGS" in | |
2138 *-fno-schedule-insns*) ;; | |
2139 *) | |
2140 AC_MSG_RESULT(yes) | |
2141 AC_MSG_WARN([Don't use -O2 with gcc 2.8.1 and egcs 1.0 under SPARC architectures]) | |
2142 AC_MSG_WARN([without also using -fno-schedule-insns.]) | |
2143 AC_MSG_ERROR([Aborting due to known problem]) | |
2144 ;; | |
2145 esac | |
2146 ;; | |
2147 esac | |
2148 ;; | |
2149 dnl egcs-2.91.57 (egcs-1.1 release) | |
2150 dnl egcs-2.91.66 (egcs-1.1.2 release) | |
2151 Linux:alpha:egcs-2.91.*) | |
2152 AC_MSG_RESULT(yes) | |
2153 AC_MSG_WARN([There have been reports of egcs-1.1 not compiling XEmacs correctly on]) | |
2154 AC_MSG_WARN([Alpha Linux. There have also been reports that egcs-1.0.3a is O.K.]) | |
2155 AC_MSG_ERROR([Aborting due to known problem]) | |
2156 ;; | |
2157 *:i*86*:2.7.2*) | |
2158 case "$CFLAGS" in | |
2159 *-O2*|*-O3*) | |
2160 case "$GCC_VERSION" in | |
2161 2.7.2) | |
2162 case "$CFLAGS" in | |
2163 *-fno-strength-reduce*) ;; | |
2164 *) | |
2165 AC_MSG_RESULT(yes) | |
2166 AC_MSG_WARN([Don't use -O2 with gcc 2.7.2 under Intel/XXX without also using]) | |
2167 AC_MSG_WARN([-fno-strength-reduce.]) | |
2168 AC_MSG_ERROR([Aborting due to known problem]) | |
2169 ;; | |
2170 esac | |
2171 ;; | |
2172 esac | |
2173 case "$CFLAGS" in | |
2174 *-fno-caller-saves*) ;; | |
2175 *) | |
2176 AC_MSG_RESULT(yes) | |
2177 AC_MSG_WARN([Don't use -O2 with gcc 2.7.2 under Intel/XXX without also using]) | |
2178 AC_MSG_WARN([-fno-caller-saves.]) | |
2179 AC_MSG_ERROR([Aborting due to known problem]) | |
2180 ;; | |
2181 esac | |
2182 ;; | |
2183 esac | |
2184 ;; | |
2185 esac | |
2186 AC_MSG_RESULT(no) | |
2187 fi | |
2188 | |
2189 dnl GNU ld now defaults to combreloc, which screws up unexec, but not pdump. | |
2190 dnl Note that it's OK if the GNU style long option causes non-GNU ld to barf | |
2191 dnl a usage message, that's often good enough. Please report it, though. | |
2192 dnl #### Should make this Solaris-friendly. | |
2193 dnl Link with -z nocombreloc for now. | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2194 if test "$with_pdump" != "yes"; then |
3312 | 2195 AC_MSG_CHECKING([for "-z nocombreloc" linker flag]) |
2651 | 2196 case "`ld --help 2>&1`" in |
2197 *-z\ nocombreloc* ) AC_MSG_RESULT(yes) | |
2198 XE_PREPEND(-z nocombreloc, ld_switch_site) ;; | |
2199 *) AC_MSG_RESULT(no) ;; | |
2200 esac | |
2201 fi | |
2202 | |
2203 dnl Inform compiler that certain flags are meant for the linker | |
2204 XE_PROTECT_LINKER_FLAGS(ld_switch_system) | |
2205 XE_PROTECT_LINKER_FLAGS(ld_switch_machine) | |
2206 XE_PROTECT_LINKER_FLAGS(ld_switch_site) | |
2207 XE_PROTECT_LINKER_FLAGS(LDFLAGS) | |
2208 XE_PROTECT_LINKER_FLAGS(ld_call_shared) | |
2209 | |
2210 dnl Add s&m-determined objects (including unexec) to link line | |
2211 test -n "$objects_machine" && XE_ADD_OBJS($objects_machine) | |
2212 test -n "$objects_system" && XE_ADD_OBJS($objects_system) | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2213 test -n "$unexec" && test ! "$with_pdump" = "yes" && XE_ADD_OBJS($unexec) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2214 test "$with_pdump" = "yes" && XE_ADD_OBJS(dumper.o) |
2651 | 2215 |
2216 dnl Feed s&m crud to src/Makefile | |
2217 | |
2218 dnl Linux/powerpc needs the following magic for some reason | |
2219 dnl [Not needed with YellowDog 2.3 and causes link problems with YellowDog 3.0, | |
2220 dnl the two most popular PowerPC distributions.] | |
2221 dnl test "$machine$opsys" = "powerpclinux" && start_flags="-T $srcdir/src/ppc.ldscript" | |
2222 | |
2223 AC_LANG(C) | |
2224 if test "$unexec" = "unexaix.o"; then | |
2225 dnl AIX needs various hacks to make static linking work. | |
2226 if test "$with_dynamic" = "no"; then | |
2227 start_flags="-Wl,-bnso,-bnodelcsect" | |
2228 test "$GCC" = "yes" && start_flags="-B/bin/ ${start_flags}" | |
2229 for f in "/lib/syscalls.exp" "/lib/threads.exp"; do | |
2230 if test -r "$f"; then start_flags="${start_flags},-bI:${f}"; fi | |
2231 done | |
2232 for f in "/usr/lpp/X11/bin/smt.exp" "/usr/bin/X11/smt.exp"; do | |
2233 if test -r "$f"; then start_flags="${start_flags},-bI:${f}"; break; fi | |
2234 done | |
2235 AC_CHECK_LIB([c], [terminateAndUnload], [XE_APPEND(-lC, libs_system)]) | |
2236 fi | |
2237 elif test -n "$ld_text_start_addr"; then | |
2238 start_flags="-T $ld_text_start_addr -e __start" | |
2239 fi | |
2240 AC_SUBST(start_flags) | |
2241 | |
2242 AC_SUBST(ld_switch_shared) | |
2243 AC_SUBST(start_files) | |
2244 if test "$ordinary_link" = "no" -a "$GCC" = "yes"; then | |
2245 test -z "$linker" && linker='$(CC) -nostdlib' | |
2246 test -z "$lib_gcc" && lib_gcc='`$(CC) -print-libgcc-file-name`' | |
2247 fi | |
2248 test "$GCC" != "yes" && lib_gcc= | |
2249 AC_SUBST(ld) | |
2250 AC_SUBST(lib_gcc) | |
2251 | |
2252 dnl --------------------------------------------------------------- | |
2253 dnl Get version information for: | |
2254 dnl C compiler, libc | |
2255 dnl #### should do CC compiler, too, if different from XEMACS_CC | |
2256 dnl --------------------------------------------------------------- | |
2257 | |
2258 compiler_version="" | |
2259 gcc_compiler_specs="" | |
2260 libc_version="" | |
2261 | |
2262 AC_MSG_CHECKING([for compiler version information]) | |
2263 | |
2264 dnl First try portable compilers, then crack system secrets | |
2265 dnl #### Is this code correct if $XEMACS_CC != $CC? XEMACS_CC hasn't been | |
2266 dnl run through the AC_PROG_CC mill. | |
2267 dnl Would anybody really build libsrc with GCC and XEmacs with non-GCC? | |
2268 if test "$GCC" = "yes"; then | |
2692 | 2269 compiler_version=`$XEMACS_CC --version | sed 1q` |
2270 gcc_compiler_specs=`$XEMACS_CC -v 2>&1 | sed 's/.* \([[^ ]]\)/\1/' | sed 1q` | |
2651 | 2271 else case "$XEMACS_CC" in |
2272 dnl The Intel cc compiler | |
2273 ic*) | |
2692 | 2274 compiler_version=`icc -V 2>&1 | sed 1q` |
2651 | 2275 ;; |
2276 dnl non-gcc machine-specific magic - contributions welcome | |
2277 *) case "$ac_cv_build" in | |
2278 *-*-aix* ) | |
2279 dnl Yes, it's this ugly for AIX... | |
2280 realcc=`which $XEMACS_CC` | |
2281 dnl Might be a symlink created by replaceCset command | |
2282 if test -L $realcc ; then | |
2283 ccdir=`dirname $realcc` | |
2284 ccprog=`/bin/ls -l $realcc | sed 's/.* \([[^ ]]\)/\1/'` | |
2285 dnl This doesn't handle ../../xlc type stuff, but I've not seen one... | |
2286 case $ccprog in | |
2287 */*) realcc=$ccprog;; | |
2288 *) realcc=$ccdir/$ccprog;; | |
2289 esac | |
2290 fi | |
2291 lpp=`lslpp -wqc $realcc | cut -f2 -d:` | |
2292 if test ! -z "$lpp" ; then | |
2293 lppstr=`lslpp -Lqc $lpp` | |
2294 lpplev=`echo "$lppstr" | cut -f3 -d:` | |
2295 lppdesc=`echo "$lppstr" | cut -f8 -d:` | |
2296 fi | |
2297 if test ! -z "$lpplev" ; then | |
2298 compiler_version="$lpp $lpplev - $lppdesc" | |
2299 fi | |
2300 ;; | |
2301 | |
2302 *-*-solaris*) | |
2692 | 2303 compiler_version=`$XEMACS_CC -V 2>&1 | sed 1q` |
2651 | 2304 ;; |
2305 | |
2306 alpha*-dec-osf*) | |
2307 compiler_version=`$XEMACS_CC -V | tr '\n' ' '` | |
2308 ;; | |
2309 | |
2310 mips-sgi-irix*) | |
2311 compiler_version=`$XEMACS_CC -version` | |
2312 ;; | |
2313 esac | |
2314 esac | |
2315 fi | |
2316 | |
2317 dnl Awww, shucks. | |
2318 if test -z "$compiler_version"; then | |
2319 compiler_version="detection failed (please report this)" | |
2320 fi | |
2321 AC_MSG_RESULT([$compiler_version]) | |
2322 | |
2323 AC_MSG_CHECKING(for standard C library version information) | |
2324 | |
2325 case "$ac_cv_build" in | |
2326 *-*-linux*) | |
2327 dnl #### who would ever _not_ be running the distro's libc? | |
2328 dnl Maybe it would be better to get/augment this info with ldd? | |
2329 if test -f /etc/redhat-release ; then | |
2330 libc_version=`rpm -q glibc` | |
2331 elif test -f /etc/debian_version ; then | |
2332 libc_version=`dpkg-query --showformat='${version}' --show libc6` | |
2333 libc_version="GNU libc $libc_version (Debian)" | |
2334 dnl need SuSE et al checks here... | |
2335 fi | |
2336 dnl #### Tested on Debian, does this actually work elsewhere? ;-) | |
2337 if test -z "$libc_version"; then | |
2338 libc_version=`ls /lib/libc-*.so | sed -e 's,/lib/libc-\(.*\)\.so,\1,'` | |
2339 fi | |
2340 ;; | |
2341 | |
2342 *-*-aix*) | |
2343 libc_version="bos.rte.libc `lslpp -Lqc bos.rte.libc | cut -f3 -d:`" | |
2344 ;; | |
2345 | |
2346 *-*-solaris*) | |
2347 libc=`pkginfo -l SUNWcsl | grep VERSION: | awk '{print $2}'` | |
2348 libc_version="SUNWcsl $libc" | |
2349 | |
2350 ;; | |
2351 | |
2352 mips-sgi-irix*) | |
2353 libc_version="IRIX libc `uname -sRm`" | |
2354 ;; | |
2355 | |
2356 alpha*-dec-osf*) | |
2357 dnl Another ugly case | |
2358 (cd /usr/.smdb.; | |
2359 libc_version=` grep -h libc.so *.inv | awk '$9 == "f" {print $12}' | tr '\n' ','` | |
2360 ) | |
2361 ;; | |
2362 esac | |
2363 | |
2364 dnl Awww, shucks. | |
2365 if test -z "libc_version"; then | |
2366 libc_version="detection failed (please report this)" | |
2367 fi | |
2368 AC_MSG_RESULT([$libc_version]) | |
2369 | |
2370 dnl --------------------------------------------------------------- | |
2371 dnl Add site and system specific flags to compile and link commands | |
2372 dnl --------------------------------------------------------------- | |
2373 | |
2374 dnl --with-site-libraries (multiple dirs) | |
2375 COLON_TO_SPACE(with_site_libraries) | |
2376 if test -n "$with_site_libraries"; then | |
2377 for arg in $with_site_libraries; do | |
2378 case "$arg" in | |
2379 -* ) ;; | |
2380 * ) test -d "$arg" || \ | |
2381 XE_DIE("Invalid site library \`$arg': no such directory") | |
2382 arg="-L${arg}" ;; | |
2383 esac | |
2384 XE_APPEND($arg, ld_switch_site) | |
2385 done | |
2386 fi | |
2387 | |
2388 dnl --with-site-includes (multiple dirs) | |
2389 COLON_TO_SPACE(with_site_includes) | |
2390 if test -n "$with_site_includes"; then | |
2391 for arg in $with_site_includes; do | |
2392 case "$arg" in | |
2393 -* ) ;; | |
2394 * ) test -d "$arg" || \ | |
2395 XE_DIE("Invalid site include \`$arg': no such directory") | |
2396 arg="-I${arg}" ;; | |
2397 esac | |
2398 XE_APPEND($arg, c_switch_site) | |
2399 done | |
2400 fi | |
2401 | |
2402 dnl --with-site-prefixes (multiple dirs) | |
2403 dnl --with-site-prefixes=dir1:dir2 is a convenient shorthand for | |
2404 dnl --with-site-libraries=dir1/lib:dir2/lib --with-site-includes=dir1/include:dir2/include | |
2405 dnl Site prefixes take precedence over the standard places, but not over | |
2406 dnl with-site-includes and with-site-libraries. | |
2407 COLON_TO_SPACE(with_site_prefixes) | |
2408 if test -n "$with_site_prefixes"; then | |
2409 for dir in $with_site_prefixes; do | |
2410 lib_dir="${dir}/lib" | |
2411 inc_dir="${dir}/include" | |
2412 if test ! -d "$dir"; then | |
2413 XE_DIE("Invalid site prefix \`$dir': no such directory") | |
2414 elif test ! -d "$lib_dir"; then | |
2415 XE_DIE("Invalid site prefix \`$dir': no such directory \`$lib_dir'") | |
2416 else | |
2417 if test -d "$inc_dir"; then | |
2418 XE_APPEND("-I$inc_dir", c_switch_site) | |
2419 fi | |
2420 XE_APPEND("-L$lib_dir", ld_switch_site) | |
2421 fi | |
2422 done | |
2423 fi | |
2424 | |
2425 dnl GNU software installs by default into /usr/local/{include,lib} | |
2426 dnl if test -d "/usr/local/include" -a -d "/usr/local/lib"; then | |
2427 dnl XE_APPEND("-L/usr/local/lib", ld_switch_site) | |
2428 dnl XE_APPEND("-I/usr/local/include", c_switch_site) | |
2429 dnl fi | |
2430 | |
2431 dnl Extra system-specific library directories - please add to list | |
2432 for dir in "/usr/ccs/lib"; do | |
2433 test -d "$dir" && XE_APPEND(-L${dir}, ld_switch_system) | |
2434 done | |
2435 | |
2436 dnl --with-site-runtime-libraries (multiple dirs) | |
2437 COLON_TO_SPACE(with_site_runtime_libraries) | |
2438 if test -n "$with_site_runtime_libraries"; then | |
2439 LD_RUN_PATH="`echo $with_site_runtime_libraries | sed -e 's/ */:/g'`" | |
2440 export LD_RUN_PATH | |
2441 fi | |
2442 | |
2443 dnl Linux systems have dynamic runtime library directories listed in | |
2444 dnl /etc/ld.so.conf. Since those are used at run time, it seems pretty | |
2445 dnl safe to use them at link time, and less controversial than forcing | |
2446 dnl the run-time to use the link-time libraries. This also helps avoid | |
2447 dnl mismatches between the link-time and run-time libraries. | |
2448 | |
2449 dnl #### Unfortunately, there are horrible libc4 and libc5 libraries | |
2450 dnl listed in /etc/ld.so.conf on some systems, and including them on | |
2451 dnl the link path leads to linking in utterly broken libc's. | |
2452 dnl There are many clever ways of approaching this problem, | |
2453 dnl but finding one that actually works... | |
2454 | |
2455 dnl if test -z "$LD_RUN_PATH" -a -r "/etc/ld.so.conf"; then | |
2456 dnl for dir in `cat /etc/ld.so.conf`; do | |
2457 dnl test -d "$dir" && XE_APPEND(-L${dir}, ld_switch_system) | |
2458 dnl done | |
2459 dnl add_runtime_path=no | |
2460 dnl fi | |
2461 | |
2462 dnl ------------------------------------- | |
2463 dnl Compute runtime library path | |
2464 dnl ------------------------------------- | |
2465 | |
2466 if test -n "$add_runtime_path"; then :; | |
2467 elif test "$with_dynamic" = "no"; then add_runtime_path=no | |
2468 elif test -n "$LD_RUN_PATH"; then add_runtime_path=yes | |
2469 else case "$opsys" in | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
2470 sol2 | irix* | *bsd* ) add_runtime_path=yes ;; |
2651 | 2471 * ) add_runtime_path=no ;; |
2472 esac | |
2473 fi | |
2474 | |
2475 if test "$add_runtime_path" = "yes"; then | |
2476 dnl Try to autodetect runtime library flag (usually -R), | |
2477 dnl and whether it works (or at least does no harm) | |
3312 | 2478 AC_MSG_CHECKING([for runtime libraries flag]) |
2651 | 2479 case "$opsys" in |
2480 sol2 ) dash_r="-R" ;; | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
2481 linux* | irix*) dash_r="-rpath " ;; |
2651 | 2482 *) |
2483 dash_r="" | |
2484 for try_dash_r in "-R" "-R " "-rpath "; do | |
2485 xe_check_libs="${try_dash_r}/no/such/file-or-directory" | |
2486 XE_PROTECT_LINKER_FLAGS(xe_check_libs) | |
3312 | 2487 AC_LINK_IFELSE([], dash_r="$try_dash_r") |
2651 | 2488 xe_check_libs="" |
2489 test -n "$dash_r" && break | |
2490 done ;; | |
2491 esac | |
2492 if test -n "$dash_r"; | |
3312 | 2493 then AC_MSG_RESULT(["${dash_r}"]) |
2651 | 2494 else AC_MSG_RESULT(NONE) |
2495 fi | |
2496 fi | |
2497 | |
2498 xe_add_unique_runpath_dir=' | |
2499 xe_add_p=yes | |
2500 for xe_dir in $runpath_dirs; do dnl Uniquify | |
2501 test "$xe_dir" = "$xe_runpath_dir" && xe_add_p=no | |
2502 done | |
2503 if test "$xe_add_p" = "yes"; then | |
2504 test -n "$runpath" && runpath="${runpath}:" | |
2505 runpath="${runpath}${xe_runpath_dir}" | |
2506 runpath_dirs="$runpath_dirs $xe_runpath_dir" | |
2507 fi' | |
2508 | |
2509 XE_COMPUTE_RUNPATH() | |
2510 | |
2511 dnl ----------------------------------- | |
2512 dnl Do some misc autoconf-special tests | |
2513 dnl ----------------------------------- | |
2514 | |
4738
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2515 dnl Can we use GNU malloc on this system? |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2516 dnl First, configure based-checks. |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2517 case "$opsys" in |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2518 darwin ) |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2519 if test "$with_system_malloc" = "default"; then |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2520 system_malloc=yes |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2521 with_system_malloc=yes |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2522 AC_MSG_WARN([Forcing system malloc on Darwin.]) |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2523 fi ;; |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2524 esac |
a6f27e2b3d84
Move functionality of s/darwin.h to configure.ac and config.h.in.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4735
diff
changeset
|
2525 |
2651 | 2526 dnl Do the opsystem or machine files prohibit the use of the GNU malloc? |
2527 dnl Assume not, until told otherwise. | |
2528 GNU_MALLOC=yes | |
2529 if test "$with_dlmalloc" != "no"; then | |
2530 doug_lea_malloc=yes | |
2531 else | |
2532 doug_lea_malloc=no | |
2533 fi | |
2534 after_morecore_hook_exists=yes | |
2535 AC_CHECK_FUNC(malloc_set_state, ,doug_lea_malloc=no) | |
2536 AC_MSG_CHECKING(whether __after_morecore_hook exists) | |
3312 | 2537 AC_LINK_IFELSE([AC_LANG_PROGRAM([extern void (* __after_morecore_hook)();], |
2538 [__after_morecore_hook = 0])], | |
2651 | 2539 [AC_MSG_RESULT(yes)], |
2540 [AC_MSG_RESULT(no) | |
2541 after_morecore_hook_exists=no]) | |
2542 if test "$system_malloc" = "yes" ; then | |
2543 GNU_MALLOC=no | |
2544 GNU_MALLOC_reason=" | |
2545 - The GNU allocators don't work with this system configuration." | |
2546 elif test "$with_system_malloc" = "yes" ; then | |
2547 GNU_MALLOC=no | |
2548 GNU_MALLOC_reason=" | |
2549 - User chose not to use GNU allocators." | |
2550 elif test "$with_debug_malloc" = "yes" ; then | |
2551 GNU_MALLOC=no | |
2552 GNU_MALLOC_reason=" | |
2553 - User chose to use Debugging Malloc." | |
2554 fi | |
2555 | |
2556 if test "$doug_lea_malloc" = "yes" -a "$GNU_MALLOC" = "yes" ; then | |
2557 GNU_MALLOC_reason=" | |
2558 - Using Doug Lea's new malloc from the GNU C Library." | |
2559 AC_DEFINE(DOUG_LEA_MALLOC) | |
2560 if test "$after_morecore_hook_exists" = "no" ; then | |
2561 GNU_MALLOC_reason=" | |
2562 - Using Doug Lea's new malloc from the Linux C Library." | |
2563 AC_DEFINE(_NO_MALLOC_WARNING_) | |
2564 fi | |
2565 fi | |
2566 | |
2567 dnl #### mcheck is broken in all versions of Linux libc and glibc. | |
2568 dnl Try this again when 2.1 hits the streets. | |
2569 dnl Avoid using free-hook.c if support exists for malloc debugging in libc | |
2570 dnl have_libmcheck=no | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2571 dnl if test "$with_error_checking_malloc" = "yes" -a \ |
2651 | 2572 dnl "$have_glibc" = "yes" -a \ |
2573 dnl "$doug_lea_malloc" = "yes"; then | |
2574 dnl AC_CHECK_HEADERS(mcheck.h) | |
2575 dnl AC_CHECK_LIB(mcheck, mcheck, have_libmcheck=yes, have_libmcheck=no) | |
2576 dnl fi | |
2577 | |
2578 dnl if test "$have_libmcheck" = "yes"; then | |
2579 dnl AC_DEFINE(HAVE_LIBMCHECK) | |
2580 dnl libmcheck=-lmcheck | |
2581 dnl AC_SUBST(libmcheck) | |
2582 dnl fi | |
2583 | |
2584 dnl Some other nice autoconf tests. If you add a test here which | |
2585 dnl should make an entry in src/config.h, do not forget to add an | |
2586 dnl #undef clause to src/config.h.in for autoconf to modify. | |
2587 | |
3862 | 2588 dnl Sun likes to hide these utilities. Steve Baur asked that we make |
2589 dnl the failure occur at configure time, not at use time. | |
2590 AC_CHECK_PROG(AR,ar,ar,not_found) | |
2591 if test "$AR" = "not_found"; then | |
2592 XE_DIE(["ar not found -- is PATH set correctly?"]) | |
2593 fi | |
2594 dnl These tests don't necessarily check that the program exists. | |
2651 | 2595 AC_PROG_RANLIB |
2596 AC_PROG_INSTALL | |
2597 AC_PROG_YACC | |
2598 | |
5744
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2599 dnl We need a recent version of makeinfo |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2600 AC_MSG_CHECKING([for makeinfo >= 4.12]) |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2601 MAKEINFO= |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2602 for prog in `which -a makeinfo`; do |
5748
3ccb4aaf91c7
* configure.ac (makeinfo):
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5744
diff
changeset
|
2603 mi_verstr=[`$prog --version | sed -n '1s/^.* \([0-9][0-9]*\.[0-9][0-9]*\)$/\1/p'`] |
5744
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2604 mi_major=`echo $mi_verstr | cut -d. -f1` |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2605 mi_minor=`echo $mi_verstr | cut -d. -f2` |
5748
3ccb4aaf91c7
* configure.ac (makeinfo):
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5744
diff
changeset
|
2606 if test "$mi_major" -gt 4 || ( test "$mi_major" -eq 4 && test "$mi_minor" -gt 11 ); |
5744
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2607 then |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2608 MAKEINFO=$prog |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2609 break |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2610 fi |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2611 done |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2612 if test -z $MAKEINFO; then |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2613 AC_MSG_RESULT([no]) |
5748
3ccb4aaf91c7
* configure.ac (makeinfo):
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5744
diff
changeset
|
2614 AC_MSG_WARN([Found Makeinfo $mi_verstr. 4.12 or later required.]) |
5744
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2615 else |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2616 AC_MSG_RESULT([yes]) |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2617 fi |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2618 AC_CONFIG_FILES([man/Makefile]) |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
2619 |
2651 | 2620 dnl checks for header files |
2621 AC_CHECK_HEADERS(dnl | |
2622 a.out.h dnl | |
2623 elf.h dnl | |
2624 cygwin/version.h dnl | |
2625 fcntl.h dnl | |
2626 libgen.h dnl | |
2627 locale.h dnl | |
2628 wchar.h dnl | |
2629 mach/mach.h dnl | |
2630 sys/param.h dnl | |
2631 sys/pstat.h dnl | |
2632 sys/resource.h dnl | |
2633 sys/time.h dnl | |
2634 sys/timeb.h dnl | |
2635 sys/times.h dnl | |
2636 sys/un.h dnl | |
2637 sys/vlimit.h dnl | |
2638 ulimit.h dnl | |
2639 ) | |
2640 AC_HEADER_SYS_WAIT | |
2641 AC_HEADER_STDC | |
2642 AC_HEADER_TIME | |
2643 AC_CHECK_DECLS([sys_siglist],,, | |
2644 [#include <signal.h> | |
2645 /* NetBSD declares sys_siglist in unistd.h. */ | |
2646 #if HAVE_UNISTD_H | |
2647 # include <unistd.h> | |
2648 #endif | |
667 | 2649 ]) |
2651 | 2650 |
2651 | |
2652 dnl ---------------------------------------------------------------- | |
2653 dnl Checking for utime() or utimes(). | |
2654 dnl We prefer utime, since it is more standard. | |
2655 dnl Some systems have utime.h but do not declare the struct anyplace, | |
2656 dnl so we use a more sophisticated test for utime than AC_CHECK_FUNCS. | |
2657 dnl ---------------------------------------------------------------- | |
2658 AC_MSG_CHECKING(for utime) | |
3312 | 2659 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <sys/types.h> |
2651 | 2660 #include <utime.h>], |
3312 | 2661 [struct utimbuf x; x.actime = x.modtime = 0; utime ("/", &x);])], |
2651 | 2662 [AC_MSG_RESULT(yes) |
2663 AC_DEFINE(HAVE_UTIME)], | |
2664 [AC_MSG_RESULT(no) | |
2665 dnl We don't have utime(); how about utimes()? | |
2666 AC_CHECK_FUNCS(utimes)]) | |
2667 | |
2668 | |
2669 dnl checks for typedefs | |
2670 AC_TYPE_SIGNAL | |
2671 AC_TYPE_SIZE_T | |
2672 AC_TYPE_PID_T | |
2673 AC_TYPE_UID_T | |
2674 AC_TYPE_MODE_T | |
2675 AC_TYPE_OFF_T | |
3862 | 2676 dnl #### Translated from deprecated 2.13-ism. |
2677 dnl We probably want to DTRT with #ifdef HAVE_SSIZE_T in src/config.h.in. | |
2678 dnl Specifically, we should typedef st sizeof(ssize_t) == sizeof(size_t). | |
2679 AC_CHECK_TYPE([ssize_t],, | |
2680 [AC_DEFINE_UNQUOTED([ssize_t], [int], | |
2681 [Define to `int' if | |
2682 <sys/types.h> does not define.])]) | |
2651 | 2683 |
2684 dnl not AC_CHECK_TYPE; lisp.h does hairy conditional typedef | |
2685 if test "$ac_cv_header_inttypes_h" != "yes"; then | |
2686 AC_MSG_CHECKING(for intptr_t in sys/types.h) | |
3312 | 2687 AC_COMPILE_IFELSE([AC_LANG_SOURCE([#include <sys/types.h> |
2651 | 2688 intptr_t x; |
3312 | 2689 ])],[AC_MSG_RESULT(yes) |
2651 | 2690 AC_DEFINE(HAVE_INTPTR_T_IN_SYS_TYPES_H,1)], |
2691 [AC_MSG_RESULT(no)]) | |
2692 fi | |
2693 | |
2694 dnl check for Unix98 socklen_t | |
2695 AC_MSG_CHECKING(for socklen_t) | |
3312 | 2696 AC_COMPILE_IFELSE([AC_LANG_SOURCE([#include <sys/types.h> |
2651 | 2697 #include <sys/socket.h> |
2698 socklen_t x; | |
3312 | 2699 ])],[AC_MSG_RESULT(yes)],[ |
2700 AC_COMPILE_IFELSE([AC_LANG_SOURCE([#include <sys/types.h> | |
2651 | 2701 #include <sys/socket.h> |
2702 int accept (int, struct sockaddr *, size_t *); | |
3312 | 2703 ])],[ |
2651 | 2704 AC_MSG_RESULT(size_t) |
2705 AC_DEFINE(socklen_t,size_t)], [ | |
2706 AC_MSG_RESULT(int) | |
2707 AC_DEFINE(socklen_t,int)])]) | |
2708 | |
2709 AC_MSG_CHECKING(for struct timeval) | |
3312 | 2710 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#ifdef TIME_WITH_SYS_TIME |
2651 | 2711 #include <sys/time.h> |
2712 #include <time.h> | |
2713 #else | |
2714 #ifdef HAVE_SYS_TIME_H | |
2715 #include <sys/time.h> | |
2716 #else | |
2717 #include <time.h> | |
2718 #endif | |
3312 | 2719 #endif], [static struct timeval x; x.tv_sec = x.tv_usec;])], |
2651 | 2720 [AC_MSG_RESULT(yes) |
2721 HAVE_TIMEVAL=yes | |
2722 AC_DEFINE(HAVE_TIMEVAL)], | |
2723 [AC_MSG_RESULT(no) | |
2724 HAVE_TIMEVAL=no]) | |
2725 | |
2726 dnl checks for structure members | |
2727 AC_STRUCT_TM | |
2728 AC_STRUCT_TIMEZONE | |
2729 | |
2730 dnl checks for compiler characteristics | |
2731 AC_C_CONST | |
2732 | |
2733 dnl check for Make feature | |
2734 AC_PROG_MAKE_SET | |
2735 | |
2736 dnl check byte order | |
2737 AC_C_BIGENDIAN | |
2738 | |
2739 dnl define SIZEOF_TYPE | |
2740 AC_CHECK_SIZEOF(short) | |
2741 if test "$ac_cv_sizeof_short" = 0; then | |
2742 echo "" | |
2743 echo "*** PANIC *** Configure tests are not working - compiler is broken." | |
2744 echo "*** PANIC *** Please examine config.log for compilation errors." | |
2745 exit 1 | |
2746 fi | |
2747 AC_CHECK_SIZEOF(int) | |
2748 AC_CHECK_SIZEOF(long) | |
2749 AC_CHECK_SIZEOF(long long) | |
2750 AC_CHECK_SIZEOF(void *) | |
2751 AC_CHECK_SIZEOF(double) | |
2752 | |
2753 dnl check for long file names | |
2754 AC_SYS_LONG_FILE_NAMES | |
2755 | |
5727
86d33ddc7fd6
Avoid EOVERFLOW from stat() calls due to overflowing inode numbers.
Jerry James <james@xemacs.org>
parents:
5725
diff
changeset
|
2756 dnl check for large file support |
86d33ddc7fd6
Avoid EOVERFLOW from stat() calls due to overflowing inode numbers.
Jerry James <james@xemacs.org>
parents:
5725
diff
changeset
|
2757 AC_SYS_LARGEFILE |
86d33ddc7fd6
Avoid EOVERFLOW from stat() calls due to overflowing inode numbers.
Jerry James <james@xemacs.org>
parents:
5725
diff
changeset
|
2758 AC_FUNC_FSEEKO |
86d33ddc7fd6
Avoid EOVERFLOW from stat() calls due to overflowing inode numbers.
Jerry James <james@xemacs.org>
parents:
5725
diff
changeset
|
2759 AC_CHECK_SIZEOF(off_t) |
86d33ddc7fd6
Avoid EOVERFLOW from stat() calls due to overflowing inode numbers.
Jerry James <james@xemacs.org>
parents:
5725
diff
changeset
|
2760 |
2651 | 2761 dnl -lm is required for floating point support, among other things |
2762 AC_CHECK_FUNC(sin, ,AC_CHECK_LIB(m, sin)) | |
2763 | |
3312 | 2764 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <math.h>], |
2765 [return atanh(1.0) + asinh(1.0) + acosh(1.0); ])], | |
2651 | 2766 AC_DEFINE(HAVE_INVERSE_HYPERBOLIC)) |
2767 | |
2768 dnl See if mkstemp is available | |
2769 AC_CHECK_FUNCS(mkstemp) | |
2770 | |
2771 dnl Determine type of mail locking from configure args and s&m headers | |
3312 | 2772 AC_MSG_CHECKING([type of mail spool file locking]) |
2773 AC_MSG_RESULT() | |
2651 | 2774 AC_CHECK_FUNCS(lockf flock) |
2775 dnl The mail_use_xxx variables are set according to the s&m headers. | |
2776 test -z "$with_mail_locking" -a "$mail_use_flock" = "yes" && with_mail_locking=flock | |
2777 test -z "$with_mail_locking" -a "$mail_use_lockf" = "yes" && with_mail_locking=lockf | |
2778 test -z "$with_mail_locking" -a "$mail_use_locking" = "yes" && with_mail_locking=locking | |
2779 if test -z "$with_mail_locking"; then | |
2780 case "$opsys" in cygwin* | mingw*) | |
2781 with_mail_locking=pop ;; | |
2782 esac | |
2783 fi | |
2784 | |
2785 if test "$with_mail_locking" = "lockf"; then AC_DEFINE(MAIL_LOCK_LOCKF) | |
2786 elif test "$with_mail_locking" = "flock"; then AC_DEFINE(MAIL_LOCK_FLOCK) | |
2787 elif test "$with_mail_locking" = "locking"; then AC_DEFINE(MAIL_LOCK_LOCKING) | |
2788 elif test "$with_mail_locking" = "pop"; then | |
2789 with_pop=yes | |
2790 with_mail_locking= | |
2791 elif test "$with_mail_locking" = "mmdf"; then AC_DEFINE(MAIL_LOCK_MMDF) | |
2792 else with_mail_locking="file"; AC_DEFINE(MAIL_LOCK_DOT) | |
2793 fi | |
2794 test "$with_mail_locking" = "lockf" -a "$ac_cv_func_lockf" != "yes" && \ | |
2795 XE_DIE("lockf mail locking requested but not available.") | |
2796 test "$with_mail_locking" = "flock" -a "$ac_cv_func_flock" != "yes" && \ | |
2797 XE_DIE("flock mail locking requested but not available.") | |
2798 test "$with_mail_locking" = "locking" -a "$ac_cv_func_locking" != "yes" && \ | |
2799 XE_DIE("locking mail locking requested but not available.") | |
2800 | |
2801 dnl ---------------------------------------------------------------- | |
2802 dnl Miscellaneous flags | |
2803 dnl ---------------------------------------------------------------- | |
2804 | |
2805 AC_MSG_CHECKING(whether the -xildoff compiler flag is required) | |
2806 if ${CC-cc} '-###' -xildon no_such_file.c 2>&1 | grep '^[^ ]*/ild ' > /dev/null ; then | |
2807 if ${CC-cc} '-###' -xildoff no_such_file.c 2>&1 | grep '^[^ ]*/ild ' > /dev/null ; | |
2808 then AC_MSG_RESULT(no); | |
2809 else AC_MSG_RESULT(yes); XE_APPEND(-xildoff, ld_switch_site) | |
2810 fi | |
2811 else AC_MSG_RESULT(no) | |
2812 fi | |
2813 | |
2814 dnl Link with "-z ignore" on Solaris if supported | |
2815 if test "$opsys" = "sol2"; then | |
2816 if test "$os_release" -ge 506; then | |
3312 | 2817 AC_MSG_CHECKING([for "-z ignore" linker flag]) |
2651 | 2818 case "`ld -h 2>&1`" in |
2819 *-z\ ignore\|record* ) AC_MSG_RESULT(yes) | |
2820 XE_PREPEND(-z ignore, ld_switch_site) ;; | |
2821 *) AC_MSG_RESULT(no) ;; | |
2822 esac | |
2823 fi | |
2824 fi | |
2825 | |
5604
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2826 dnl Disable ASLR on systems where it breaks pdump. |
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2827 AC_MSG_CHECKING([whether ASLR needs to be disabled]) |
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2828 case `uname -s`:`uname -r` in |
5767
4e69b24a2301
Disable ASLR on Mavericks.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5765
diff
changeset
|
2829 dnl Mac OS X 10.7 Lion, 10.8 Mountain Lion, 10.9 Mavericks |
4e69b24a2301
Disable ASLR on Mavericks.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5765
diff
changeset
|
2830 Darwin:1[[123]].*) |
5604
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2831 AC_MSG_RESULT(yes) |
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2832 XE_APPEND([-Wl,-no_pie], LDFLAGS) |
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2833 ;; |
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2834 *) AC_MSG_RESULT(no) ;; |
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2835 esac |
e9f58d024c3c
Disable ASLR on Mac OS X Lion.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5601
diff
changeset
|
2836 |
2651 | 2837 dnl ---------------------- |
2838 dnl Choose a window system | |
2839 dnl ---------------------- | |
2840 | |
3312 | 2841 AC_MSG_CHECKING([for specified window system]) |
2842 AC_MSG_RESULT() | |
2651 | 2843 |
2844 dnl Autodetection of Gdk libraries and includes | |
2845 dnl ------------------------------------------- | |
2846 dnl On some systems (FreeBSD springs to mind), they use | |
2847 dnl versions on the utility routines, so instead of gtk-config | |
2848 dnl you must use gtk12-config, etc, etc. | |
2849 | |
2850 GNOME_CONFIG=no | |
2851 GTK_CONFIG=no | |
2852 | |
2853 if test "$with_gnome" != "no"; then | |
2854 AC_MSG_CHECKING(for GNOME configuration script) | |
2855 for possible in gnome-config | |
2856 do | |
2857 possible_version=`${possible} --version 2> /dev/null` | |
2858 if test "x${possible_version}" != "x"; then | |
2859 GNOME_CONFIG="${possible}" | |
2860 with_gnome=yes | |
2861 with_gtk=yes | |
2862 break | |
2863 fi | |
2864 done | |
2865 AC_MSG_RESULT([${GNOME_CONFIG}]) | |
2866 fi | |
2867 | |
2868 if test "${GNOME_CONFIG}" != "no"; then | |
2869 GNOME_LIBS=`${GNOME_CONFIG} --libs gnomeui` | |
2870 GNOME_CFLAGS=`${GNOME_CONFIG} --cflags gnomeui` | |
2871 AC_DEFINE(HAVE_GNOME) | |
2872 XE_APPEND(${GNOME_LIBS}, libs_gtk) | |
2873 XE_APPEND(${GNOME_CFLAGS}, c_switch_gtk) | |
2874 fi | |
2875 | |
2876 if test "$with_gtk" != "no";then | |
2877 AC_MSG_CHECKING(for GTK configuration script) | |
2878 for possible in gtk12-config gtk14-config gtk-config | |
2879 do | |
2880 possible_version=`${possible} --version 2> /dev/null` | |
2881 if test "x${possible_version}" != "x"; then | |
2882 GTK_CONFIG="${possible}" | |
2883 case "${possible_version}" in | |
2884 1.0.*) AC_MSG_WARN([GTK 1.2 is required, please upgrade your version of GTK.]); with_gtk=no;; | |
2885 1.3.*) AC_MSG_WARN([GTK 1.3 is not supported right now]); with_gtk=no;; | |
2886 1.2.*) | |
2887 with_gtk=yes | |
2888 break | |
2889 ;; | |
2890 *) AC_MSG_WARN([Found unsupported version of GTK: $possible_version]);; | |
2891 esac | |
2892 fi | |
2893 done | |
2894 AC_MSG_RESULT([${GTK_CONFIG}]) | |
2895 fi | |
2896 | |
2897 if test "${GTK_CONFIG}" != "no"; then | |
2898 AC_MSG_CHECKING(gtk version) | |
2899 GTK_VERSION=`${GTK_CONFIG} --version` | |
2900 AC_MSG_RESULT(${GTK_VERSION}) | |
2901 | |
2902 AC_MSG_CHECKING(gtk libs) | |
2903 GTK_LIBS=`${GTK_CONFIG} --libs` | |
2904 XE_APPEND(${GTK_LIBS}, libs_gtk) | |
2905 AC_MSG_RESULT(${GTK_LIBS}) | |
2906 | |
2907 AC_MSG_CHECKING(gtk cflags) | |
2908 GTK_CFLAGS=`${GTK_CONFIG} --cflags` | |
2909 if test "$GCC" = "yes"; then | |
2910 GTK_CFLAGS="${GTK_CFLAGS} -Wno-shadow" | |
2911 fi | |
2912 XE_APPEND(${GTK_CFLAGS}, c_switch_gtk) | |
2913 AC_MSG_RESULT(${GTK_CFLAGS}) | |
2914 | |
2915 AC_CHECK_LIB(gdk_imlib, main, XE_PREPEND(-lgdk_imlib, libs_gtk)) | |
2916 AC_CHECK_LIB(Imlib, Imlib_init, XE_APPEND(-lImlib, libs_gtk)) | |
2917 AC_CHECK_FUNCS(gdk_imlib_init) | |
2918 | |
2919 AC_DEFINE(HAVE_XPM) | |
2920 AC_DEFINE(HAVE_GTK) | |
2921 AC_SUBST(GTK_CONFIG) | |
2922 | |
2923 window_system=gtk | |
2924 with_gtk=yes | |
2925 if test "$with_x11" != "no"; then | |
2926 AC_MSG_WARN([Configuring GTK, forcing with_x11 to no]) | |
2927 with_x11=no | |
2928 fi | |
2929 | |
2930 for feature in scrollbars toolbars menubars dialogs widgets | |
2931 do | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2932 eval "feature_value=\${with_${feature}}" |
2651 | 2933 case "${feature_value}" in |
2934 yes|no|gtk|"" ) | |
2935 ;; | |
2936 * ) | |
2937 feature_conflict_with_gtk=yes | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2938 AC_MSG_WARN([--with-${feature}=${feature_value} is incompatible with --with-gtk]) ;; |
2651 | 2939 esac |
2940 done | |
2941 if test "${feature_conflict_with_gtk}" = "yes"; then | |
2942 XE_DIE(["One or more GUI toolkit features conflict with GTK"]) | |
2943 fi | |
2944 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2945 test "${with_scrollbars}" != "no" && with_scrollbars=gtk |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2946 test "${with_toolbars}" != "no" && with_toolbars=gtk |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2947 test "${with_menubars}" != "no" && with_menubars=gtk |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2948 test "${with_dialogs}" != "no" && with_dialogs=gtk |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
2949 test "${with_widgets}" != "no" && with_widgets=gtk |
2651 | 2950 |
2951 dnl Check for libglade support (it rocks) | |
2952 OLD_CFLAGS="${CFLAGS}" | |
2953 OLD_CPPFLAGS="${CPPFLAGS}" | |
2954 OLD_LDFLAGS="${LDFLAGS}" | |
2955 CFLAGS="${GTK_CFLAGS} ${CFLAGS}" | |
2956 CPPFLAGS="${GTK_CFLAGS} ${CFLAGS}" | |
2957 LDFLAGS="${LDFLAGS} ${GTK_LIBS}" | |
2958 AC_CHECK_HEADERS(glade/glade.h glade.h) | |
2959 AC_CHECK_LIB(xml, main, XE_PREPEND(-lxml, libs_gtk)) | |
2960 AC_CHECK_LIB(glade, main, XE_PREPEND(-lglade, libs_gtk)) | |
2961 AC_CHECK_LIB(glade-gnome, main, XE_PREPEND(-lglade-gnome, libs_gtk)) | |
2962 AC_EGREP_HEADER([char \*txtdomain;], [glade/glade-xml.h], | |
2963 [AC_MSG_RESULT(yes) | |
2964 AC_DEFINE(LIBGLADE_XML_TXTDOMAIN,1)], | |
2965 [AC_MSG_RESULT(no)]) | |
2966 CFLAGS="${OLD_CFLAGS}" | |
2967 CPPFLAGS="${OLD_CPPFLAGS}" | |
2968 LDFLAGS="${OLD_LDFLAGS}" | |
2969 fi | |
2970 | |
2971 dnl We may eventually prefer gtk/gdk over vanilla X11... | |
2972 | |
2973 if test "$with_x11" != "no"; then | |
2974 dnl User-specified --x-includes or --x-libraries implies --with-x11. | |
2975 test "$x_includes $x_libraries" != "NONE NONE" && \ | |
2976 window_system=x11 with_x11=yes | |
2977 | |
2978 dnl Autodetection of X11 libraries and includes | |
2979 dnl ------------------------------------------- | |
2980 dnl AC_PATH_XTRA thinks it can find our X headers and includes, but | |
2981 dnl it often gets it wrong, so we only use it as a last resort. | |
2982 | |
2983 dnl $OPENWINHOME implies --x-includes and --x-libraries | |
2984 dnl Not (yet) handled by autoconf2 | |
2985 if test "$x_includes $x_libraries" = "NONE NONE" \ | |
2986 -a -n "$OPENWINHOME" \ | |
2987 -a "$OPENWINHOME" != "/usr/openwin" \ | |
2988 -a -d "$OPENWINHOME"; then | |
2989 test -d "$OPENWINHOME/lib" && x_libraries="$OPENWINHOME/lib" | |
2990 test -d "$OPENWINHOME/include" && x_includes="$OPENWINHOME/include" | |
2991 test -d "$OPENWINHOME/share/include" && x_includes="$OPENWINHOME/share/include" | |
2992 fi | |
2993 | |
2994 if test "$x_includes" = "NONE"; then | |
2995 dnl AC_PATH_XTRA often guesses /usr/include, when some other | |
2996 dnl include directory is a MUCH better guess (Linux, HP-UX 10.20). | |
2997 dnl This is a workaround for idiot (esp. HP) system vendors, who | |
2998 dnl provide a /usr/include/X11, but DON'T FULLY POPULATE IT. | |
2999 for dir in "/usr/X11" "/usr/X11R6"; do | |
3000 if test -d "$dir/include/X11"; then x_includes="$dir/include"; break; fi | |
3001 done | |
3002 fi | |
3003 | |
3004 if test "$x_libraries" = "NONE"; then | |
3005 for dir in "/usr/X11/lib" "/usr/X11R6/lib" "/usr/lib/X11R6"; do | |
3006 if test -r "$dir/libX11.a"; then x_libraries="$dir"; break; fi | |
3007 done | |
3008 fi | |
3009 | |
3010 AC_PATH_XTRA # Autoconf claims to find X library and include dirs for us. | |
3011 if test "$no_x" = "yes" | |
3012 then with_x11=no window_system=none HAVE_X_WINDOWS=no | |
3013 else with_x11=yes window_system=x11 HAVE_X_WINDOWS=yes | |
3014 fi | |
3015 fi | |
3016 | |
3017 dnl #### wmperry:: !x11 != NONE | |
3018 dnl case "$with_x11" in | |
3019 dnl yes ) window_system=x11 HAVE_X_WINDOWS=yes ;; | |
3020 dnl no ) window_system=none HAVE_X_WINDOWS=no ;; | |
3021 dnl esac | |
3022 | |
3023 if test "$with_x11" = "yes"; then | |
3024 AC_DEFINE(HAVE_X_WINDOWS) | |
3025 XE_APPEND(lwlib, MAKE_SUBDIR) | |
3026 XE_APPEND(lwlib, SRC_SUBDIR_DEPS) | |
3027 | |
3028 dnl Look for Motif, but only if not found in $x_includes and $x_libraries | |
3029 AC_CHECK_HEADER(Xm/Xm.h, [AC_CHECK_LIB(Xm, XmStringFree, got_motif=yes)]) | |
3030 | |
3031 if test "$got_motif" != "yes"; then | |
3032 dnl Try to find Motif/CDE/Tooltalk dirs | |
3033 dnl These take precedence over other X libs/includes, so PRE-pend | |
3034 for lib_dir in "/usr/dt/lib" "/usr/lib/Motif2.1" \ | |
3035 "/usr/lib/Motif1.2" "/usr/lib/Motif1.1"; do | |
3036 inc_dir=`echo $lib_dir | sed -e 's/lib/include/'` | |
3037 if test -d "$lib_dir" -a -d "$inc_dir"; then | |
3038 case "$x_libraries" in *"$lib_dir"* ) ;; *) | |
3039 x_libraries="$lib_dir $x_libraries" | |
3040 XE_PREPEND(-L${lib_dir}, X_LIBS) ;; | |
3041 esac | |
3042 case "$x_includes" in "$inc_dir"* ) ;; *) | |
3043 x_includes="$inc_dir $x_includes" | |
3044 XE_PREPEND(-I${inc_dir}, X_CFLAGS) ;; | |
3045 esac | |
3046 break; dnl only need ONE Motif implementation! | |
3047 fi | |
3048 done | |
3049 fi | |
3050 | |
3051 dnl Contrib X libs/includes do NOT take precedence, so AP-pend | |
3052 for rel in "X11R6" "X11R5" "X11R4"; do | |
3053 lib_dir="/usr/contrib/$rel/lib" inc_dir="/usr/contrib/$rel/include" | |
3054 if test -d "$lib_dir" -a -d "$inc_dir"; then | |
3055 case "$x_libraries" in *"$lib_dir"* ) ;; *) | |
3056 x_libraries="$x_libraries $lib_dir" | |
3057 XE_APPEND(-L${lib_dir}, X_LIBS) | |
3058 esac | |
3059 case "$x_includes" in "$inc_dir"* ) ;; *) | |
3060 x_includes="$x_includes $inc_dir" | |
3061 XE_APPEND(-I${inc_dir}, X_CFLAGS) | |
3062 esac | |
3063 break; dnl Only need ONE X11 implementation ! | |
3064 fi | |
3065 done | |
3066 | |
3067 ld_switch_x_site="$X_LIBS" | |
3068 | |
3069 XE_COMPUTE_RUNPATH() | |
3070 | |
3071 if test "$verbose" = "yes"; then | |
3072 echo; echo "X11 compilation variables:" | |
3073 PRINT_VAR(x_libraries x_includes X_CFLAGS X_LIBS X_PRE_LIBS X_EXTRA_LIBS) | |
3074 echo | |
3075 fi | |
3076 | |
3077 dnl Set up bitmaps search path. | |
3078 dnl The original suggestion was to unconditionally to append X11/bitmaps | |
3079 dnl to each element of $x_includes, I'm pretty sure this is the wrong | |
3080 dnl thing to do. We test for bitmaps and X11/bitmaps directories on each | |
3081 dnl element and add them to BITMAPDIR if they exist. | |
3082 bitmapdirs= | |
3083 if test "$x_includes" != NONE; then | |
3084 for i in $x_includes; do | |
3085 if test -d "$i/bitmaps"; then | |
3086 bitmapdirs="$i/bitmaps:$bitmapdirs" | |
3087 fi | |
3088 if test -d "$i/X11/bitmaps"; then | |
3089 bitmapdirs="$i/X11/bitmaps:$bitmapdirs" | |
3090 fi | |
3091 done | |
3092 bitmapdirs=`echo "$bitmapdirs" | sed s/.$//` | |
3093 fi | |
3094 test ! -z "$bitmapdirs" && AC_DEFINE_UNQUOTED(BITMAPDIR, "$bitmapdirs") | |
3095 | |
3096 dnl Autodetect defines extracted from X config by xmkmf, e.g. NARROWPROTO | |
3312 | 3097 AC_MSG_CHECKING([for X defines extracted by xmkmf]) |
3098 AC_MSG_RESULT() | |
2651 | 3099 rm -fr conftestdir |
3100 if mkdir conftestdir; then | |
3101 cd conftestdir | |
3102 cat > Imakefile <<'EOF' | |
3103 xetest: | |
3104 @echo ${PROTO_DEFINES} ${STD_DEFINES} | |
3105 EOF | |
3106 if (xmkmf) >/dev/null 2>/dev/null && test -f Makefile; then | |
3107 # GNU make sometimes prints "make[1]: Entering...", which would confuse us. | |
3108 xmkmf_defines=`${MAKE-make} xetest 2>/dev/null | grep -v make` | |
3109 fi | |
3110 cd .. | |
3111 rm -fr conftestdir | |
3112 for word in $xmkmf_defines; do | |
3113 case "$word" in | |
3114 -D__STDC__*) ;; | |
3115 -D* ) | |
3116 sym=`echo '' $word | sed -e 's:^ *-D::' -e 's:=.*::'` | |
3117 case "$word" in | |
3118 -D*=* ) val=`echo '' $word | sed -e 's:^.*=::'` ;; | |
3119 * ) val=1 ;; | |
3120 esac | |
3121 dnl Avoid re-AC_DEFINE-ing xmkmf symbols we've already defined above. | |
3122 if grep "^#define $sym " confdefs.h >/dev/null; then :; else | |
3123 if test "$val" = "1" | |
3124 then AC_DEFINE_UNQUOTED($sym) | |
3125 else AC_DEFINE_UNQUOTED($sym,$val) | |
3126 fi | |
3127 fi ;; | |
3128 esac | |
3129 done | |
3130 fi | |
3131 | |
3132 dnl make sure we can find Intrinsic.h | |
3133 AC_CHECK_HEADER(X11/Intrinsic.h, , | |
3134 [AC_MSG_ERROR([Unable to find X11 header files.])]) | |
3135 | |
3136 dnl -lXt and -lX11 are required | |
3137 dnl Some broken systems require the magic "-b i486-linuxaout" flag | |
3138 AC_CHECK_LIB(X11, XOpenDisplay, have_lib_x11=yes) | |
3139 if test "$have_lib_x11" != "yes"; then | |
3140 AC_CHECK_LIB(X11, XGetFontProperty, | |
3141 ld_switch_x_site="-b i486-linuxaout $ld_switch_x_site", | |
3142 [AC_MSG_ERROR([Unable to find X11 libraries.])], | |
3143 -b i486-linuxaout) | |
3144 fi | |
3145 libs_x="-lX11" | |
3146 test "$verbose" = "yes" && echo " Setting libs_x to \"-lX11\"" | |
3147 | |
3148 dnl Autodetect -lXext | |
3149 AC_CHECK_LIB(Xext, XShapeSelectInput, XE_PREPEND(-lXext, libs_x)) | |
3150 | |
3151 dnl Require -lXt | |
3152 AC_CHECK_LIB(Xt, XtOpenDisplay, XE_PREPEND(-lXt, libs_x), | |
3153 AC_MSG_ERROR([Unable to find X11 libraries.])) | |
3154 | |
3155 AC_MSG_CHECKING(the version of X11 being used) | |
3156 AC_RUN_IFELSE([AC_LANG_SOURCE([#include <X11/Intrinsic.h> | |
4537
7ca6d57ce12d
Clarify syntax in configure.ac following Vladimir Ivanovic's change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4536
diff
changeset
|
3157 int main(int c, char **v) { return c>1 ? XlibSpecificationRelease : 0; }])], |
2651 | 3158 [./conftest foobar; x11_release=$?],[x11_release=4],[x11_release=4]) |
3159 AC_MSG_RESULT(R${x11_release}) | |
3160 AC_DEFINE_UNQUOTED(THIS_IS_X11R${x11_release}) | |
3161 | |
3162 if test "${x11_release}" = "4"; then | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3163 case "$with_widgets" in |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3164 "" | "no") with_widgets=no ;; |
2651 | 3165 *) XE_DIE("Widget support requires X11R5 or greater") ;; |
3166 esac | |
3167 fi | |
3168 | |
3169 AC_CHECK_FUNCS(XConvertCase XtRegisterDrawable) | |
3170 | |
5558
10455659ab64
Backed out changeset 53c066311921, I have a better approach.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5557
diff
changeset
|
3171 AC_CHECK_HEADERS(X11/Xlocale.h X11/Xfuncproto.h) |
2651 | 3172 |
3173 dnl XFree86 has a non-standard prototype for this X11R6 function | |
3174 AC_CHECK_FUNCS(XRegisterIMInstantiateCallback) | |
3175 AC_MSG_CHECKING(for standard XRegisterIMInstantiateCallback prototype) | |
3312 | 3176 AC_COMPILE_IFELSE([AC_LANG_SOURCE([ |
2651 | 3177 #define NeedFunctionPrototypes 1 |
3178 #include <X11/Xlib.h> | |
3179 extern Bool XRegisterIMInstantiateCallback( | |
3180 Display*, struct _XrmHashBucketRec*, char*, char*, XIMProc, XPointer*); | |
3312 | 3181 ])], |
2651 | 3182 [AC_MSG_RESULT(yes)], |
3183 [AC_MSG_RESULT(no) | |
3184 AC_DEFINE(XREGISTERIMINSTANTIATECALLBACK_NONSTANDARD_PROTOTYPE)]) | |
3185 | |
3186 dnl autodetect -lXmu | |
4769
5460287a3327
Remove support for pre-X11R5 systems, including systems without Xmu. See
Jerry James <james@xemacs.org>
parents:
4762
diff
changeset
|
3187 AC_CHECK_LIB(Xmu, XmuReadBitmapDataFromFile, with_xmu=yes, with_xmu=no) |
2651 | 3188 if test "$with_xmu" = "no"; then |
4769
5460287a3327
Remove support for pre-X11R5 systems, including systems without Xmu. See
Jerry James <james@xemacs.org>
parents:
4762
diff
changeset
|
3189 AC_MSG_ERROR([We're sorry, but we thought there were no systems without Xmu by now. |
5460287a3327
Remove support for pre-X11R5 systems, including systems without Xmu. See
Jerry James <james@xemacs.org>
parents:
4762
diff
changeset
|
3190 You cannot build this version of XEmacs for X11 without Xmu. Please report |
5460287a3327
Remove support for pre-X11R5 systems, including systems without Xmu. See
Jerry James <james@xemacs.org>
parents:
4762
diff
changeset
|
3191 this to xemacs-beta@xemacs.org. As a workaround, revert to XEmacs 21.5.29.]) |
2651 | 3192 else |
3193 XE_PREPEND(-lXmu, libs_x) | |
3194 fi | |
3195 | |
3196 dnl Autodetect -lXbsd | |
3197 dnl #### Someone, please add a better function than main | |
3198 AC_CHECK_LIB(Xbsd, main, XE_PREPEND(-lXbsd, libs_x)) | |
3199 | |
3200 dnl Problem with the MIT distribution of X on AIX | |
3201 if test "$unexec" = "unexaix.o" -a "$x11_release" = "6"; then | |
3202 dnl X11R6 requires thread-safe code on AIX for some reason | |
3203 if test "$GCC" = "yes"; then | |
3204 XE_PREPEND(-mthreads, X_CFLAGS) | |
3205 XE_PREPEND(-mthreads, libs_x) | |
3206 else | |
3207 case "$CC" in | |
3208 "xlc" ) CC="xlc_r" ;; | |
3209 "xlC" ) CC="xlC_r" ;; | |
3210 "cc" ) CC="cc_r" ;; | |
3211 esac | |
3212 fi | |
3213 fi | |
3214 | |
3094 | 3215 dnl include xft/AA support? |
3216 dnl #### need to check for includes here (especially, freetype.h for v.2) | |
3217 | |
3218 if test "$with_xft_emacs" = "yes"; then | |
3312 | 3219 AC_MSG_CHECKING([for Xrender, fontconfig, and Xft]) |
3094 | 3220 xft_includes_found=no |
4152 | 3221 dnl try pkg-config |
3222 xft_config_prog="pkg-config xft" | |
3223 xft_config_ok=`$xft_config_prog --cflags 2>/dev/null` | |
3224 if test "$?" = 0 ; then | |
3225 xft_cflags=`$xft_config_prog --cflags` | |
3226 xft_libs=`$xft_config_prog --libs` | |
3227 c_switch_site="$c_switch_site $xft_cflags" | |
3228 ld_switch_site="$ld_switch_site $xft_libs" | |
3229 xft_includes_found=yes | |
3230 else | |
3231 AC_CHECK_HEADERS([freetype/config/ftheader.h], | |
3232 [xft_includes_found=yes], | |
3233 [ | |
3234 dnl #### How about /sw/include, and /opt/local/include? | |
3235 dnl these directories need to be the parent of the freetype directory | |
3236 for freetype_include_top in "/usr/local/include/freetype2" \ | |
3237 "/usr/X11R6/include/freetype2" \ | |
3238 "/usr/include/freetype2" | |
3239 do | |
3240 if test -d $freetype_include_top; then | |
3241 AC_MSG_CHECKING([in ${freetype_include_top}]) | |
3242 dnl disable autoconf's fucking cache; why these fuckheads think it | |
3243 dnl is better to be broken than to be slow, I don't know! | |
3244 dnl #### there's gotta be a better-looking way to do this!! | |
3245 unset "$as_ac_Header" | |
3246 save_c_switch_site="$c_switch_site" | |
3247 c_switch_site="$c_switch_site -I${freetype_include_top}" | |
3248 AC_CHECK_HEADERS([freetype/config/ftheader.h], | |
3249 [xft_includes_found=yes], | |
3250 [c_switch_site=$save_c_switch_site]) | |
3251 fi | |
3252 done]) | |
3253 fi | |
3158 | 3254 if test "$xft_includes_found" != "yes"; then |
3255 XE_DIE(["Unable to find headers for --with-xft"]) | |
3256 else | |
3257 AC_CHECK_LIB(Xrender, XRenderQueryExtension, XE_PREPEND(-lXrender, libs_x), | |
3258 [XE_DIE(["Unable to find libXrender for --with-xft"])]) | |
3259 AC_CHECK_LIB(fontconfig, FcPatternCreate, XE_PREPEND(-lfontconfig, libs_x), | |
3260 [XE_DIE(["Unable to find libfontconfig for --with-xft"])]) | |
3261 AC_CHECK_LIB(Xft, XftFontOpen, XE_PREPEND(-lXft, libs_x), | |
3262 [XE_DIE(["Unable to find libXft for --with-xft"])]) | |
4328
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4152
diff
changeset
|
3263 |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4152
diff
changeset
|
3264 AC_CHECK_FUNCS(FcConfigGetRescanInterval) |
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4152
diff
changeset
|
3265 AC_CHECK_FUNCS(FcConfigSetRescanInterval) |
3354 | 3266 dnl #### detect fontconfig properly!!!! |
3267 with_fontconfig=yes | |
3268 AC_DEFINE(HAVE_FONTCONFIG) | |
4916
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4848
diff
changeset
|
3269 AC_DEFINE(HAVE_XFT) |
3158 | 3270 dnl Due to interactions with other libraries, must postpone AC_DEFINE |
4916
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4848
diff
changeset
|
3271 dnl of HAVE_XFT_MENUBARS, HAVE_XFT_TABS, and HAVE_XFT_GAUGES. |
3158 | 3272 unset xft_includes_found |
3273 fi | |
3094 | 3274 fi |
3275 | |
2651 | 3276 fi dnl $with_x11 = yes |
3277 | |
3278 if test "$with_msw" != "no"; then | |
3312 | 3279 AC_MSG_CHECKING([for MS-Windows]) |
3280 AC_MSG_RESULT() | |
2651 | 3281 AC_CHECK_LIB(gdi32,main,with_msw=yes) |
3282 if test "$with_msw" = "yes"; then | |
3283 AC_DEFINE(HAVE_MS_WINDOWS) | |
3284 | |
3285 dnl The net installer only works with MS-Windows currently | |
3286 if test "$with_netinstall" = "yes"; then | |
3287 XE_APPEND(netinstall, MAKE_SUBDIR) | |
3288 XE_APPEND(netinstall, SRC_SUBDIR_DEPS) | |
3289 XE_APPEND(netinstall, INSTALL_ARCH_DEP_SUBDIR) | |
3290 fi | |
3291 | |
3292 install_pp="$srcdir/lib-src/installexe.sh" | |
5499
4b5b7dcc19d6
Fix for issue745, linking on cygwin 1.7.
Jeff Sparkes <jsparkes@gmail.com>
parents:
5495
diff
changeset
|
3293 XE_APPEND(-L/usr/lib/w32api -limm32 -lshell32 -lgdi32 -luser32 -lcomdlg32 -lcomctl32 -lole32 -luuid -lwinspool -lmpr, libs_system) |
2651 | 3294 if test "$with_dragndrop" != no; then |
3295 XE_APPEND(msw, dragndrop_proto) | |
3296 with_dragndrop=yes | |
3297 fi | |
3298 if test "$window_system" != x11; then | |
3299 window_system=msw | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3300 test "$with_scrollbars" != "no" && with_scrollbars=msw |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3301 test "$with_menubars" != "no" && with_menubars=msw |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3302 test "$with_toolbars" != "no" && with_toolbars=msw |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3303 test "$with_dialogs" != "no" && with_dialogs=msw |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3304 test "$with_widgets" != "no" && with_widgets=msw |
2651 | 3305 fi |
3306 dnl check for our special version of select | |
3307 AC_RUN_IFELSE([AC_LANG_SOURCE([#include <fcntl.h> | |
3308 int main() { return (open("/dev/windows", O_RDONLY, 0) > 0)? 0 : 1; }])], | |
3309 [AC_DEFINE(HAVE_MSG_SELECT)]) | |
3310 fi | |
3311 fi | |
3312 | |
3313 AC_SUBST(install_pp) | |
3314 | |
3315 test -z "$with_dragndrop" && with_dragndrop="$with_dragndrop_default" | |
3316 test -z "$window_system" && window_system="none" | |
3317 | |
3318 dnl Test for features that require a window system - ANY window system | |
3319 if test "$window_system" = "none"; then | |
3320 for feature in menubars scrollbars toolbars dialogs dragndrop xface | |
3321 do | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3322 if eval "test -n \"\$with_${feature}\" -a \"\$with_${feature}\" != no" ; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3323 AC_MSG_WARN([--with-$feature ignored: Not valid without window system support]) |
2651 | 3324 fi |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3325 eval "with_${feature}=no" |
2651 | 3326 done |
3327 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3328 test -z "$with_toolbars" && with_toolbars=yes |
2651 | 3329 fi |
3330 | |
3331 dnl ### Test for features that require mswindows support - currently none | |
3332 dnl ### MS-Windows folks: add code here..... (martin) | |
3333 if test "$with_msw" != "yes"; then | |
3334 for feature in MARTIN_IS_CLUELESS_ABOUT_MSW_FEATURES | |
3335 do | |
3336 if eval "test -n \"\$with_${feature}\" -a \"\$with_${feature}\" != no" ; then | |
3337 AC_MSG_WARN([--with-$feature ignored: Not valid without MS-Windows support]) | |
3338 fi | |
3339 eval "with_${feature}=no" | |
3340 done | |
3341 else | |
3342 : | |
3343 fi | |
3344 | |
3345 dnl Test for features that require X11 support | |
3346 if test "$with_x11" != "yes"; then | |
3347 dnl It ought to be reasonable to have no output device at all, and only use | |
3348 dnl XEmacs in --batch mode. | |
3349 dnl if test "$with_tty" = "no" ; then | |
3350 dnl AC_MSG_ERROR([No window system support and no TTY support - Unable to proceed.]) | |
3351 dnl fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3352 for feature in with_tooltalk with_cde with_wmcommand with_xim with_sound_nas |
2651 | 3353 do |
3354 if eval "test -n \"\$${feature}\" -a \"\$${feature}\" != \"no\"" ; then | |
3355 AC_MSG_WARN([--$feature ignored: Not valid without X support]) | |
3356 fi | |
3357 eval "${feature}=no" | |
3358 done | |
3359 fi | |
3360 | |
3361 dnl Balloon Help requires the Shape extension, not available everywhere, | |
3362 dnl for example not on AIX 4.3. | |
3363 if test "$with_x11" = "yes"; then | |
3364 AC_CHECK_HEADER(X11/extensions/shape.h, [ | |
3365 AC_DEFINE(HAVE_BALLOON_HELP) | |
2741 | 3366 ],[], |
3367 [ | |
3368 #include <X11/Xlib.h> | |
3369 #include <X11/Xutil.h> | |
3370 ]) | |
2651 | 3371 fi |
3372 | |
3373 dnl FSF 19.29 has some bitmapdir stuff here. | |
3374 bitmapdir= | |
3375 | |
3376 case "$window_system" in | |
3377 x11 ) HAVE_X_WINDOWS=yes; echo " Using X11." ;; | |
3378 msw ) HAVE_X_WINDOWS=no ; echo " Using MS-Windows." ;; | |
3379 gtk ) | |
3380 HAVE_X_WINDOWS=no | |
3381 test "$with_gnome" = "yes" && echo " Using GNOME." | |
3382 test "$with_gnome" = "no" && echo " Using GTK." | |
3383 ;; | |
3384 none ) HAVE_X_WINDOWS=no ; echo " Using no window system." ;; | |
3385 esac | |
3386 | |
3387 dnl Enable or disable proper handling of WM_COMMAND | |
3312 | 3388 AC_MSG_CHECKING([for WM_COMMAND option]) |
2651 | 3389 dnl if test "$with_wmcommand" = "yes"; then |
3390 if test "$with_wmcommand" != "no"; then | |
3391 AC_DEFINE(HAVE_WMCOMMAND) | |
3312 | 3392 AC_MSG_RESULT(yes) |
3393 else | |
3394 AC_MSG_RESULT(no) | |
2651 | 3395 fi |
3396 | |
3397 dnl Autodetect Xauth | |
3398 dnl -lXau is only used by gnuclient, so use a special variable for Xauth X libs | |
3399 test -z "$with_xauth" && test "$window_system" = "none" && with_xauth=no | |
3400 test -z "$with_xauth" && { AC_CHECK_HEADER(X11/Xauth.h, ,with_xauth=no) } | |
3401 test -z "$with_xauth" && { AC_CHECK_LIB(Xau, XauGetAuthByAddr,[:],with_xauth=no) } | |
3402 test -z "$with_xauth" && with_xauth=yes | |
3403 if test "$with_xauth" = "yes"; then | |
3404 AC_DEFINE(HAVE_XAUTH) | |
3405 XE_SPACE(libs_xauth, $GTK_LIBS $X_EXTRA_LIBS -lXau $libs_x $X_PRE_LIBS) | |
3406 fi | |
3407 AC_SUBST(libs_xauth) | |
3408 | |
3409 dnl This one is for the static initializeds variables in | |
3410 dnl offix.c, so that the thing is dumped after lastfile.o | |
3411 AC_SUBST(dnd_objs) | |
3412 | |
3413 dnl Autodetect dll support | |
3414 | |
3415 dnl If g++ is used, we have to explicitly link modules with -lstdc++ on Cygwin | |
3416 dnl to avoid undefined symbol errors. This will never hurt, so just do it on | |
3417 dnl all platforms in case others have the same brain damage. | |
4932 | 3418 if test "$XEMACS_CC_GPP" = "yes"; then |
2651 | 3419 LIBSTDCPP=-lstdc++ |
3420 else | |
3421 LIBSTDCPP= | |
3422 fi | |
3423 AC_SUBST(LIBSTDCPP) | |
3424 | |
5556
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3425 dnl Tell the pathname handling code about a couple of Darwin-specific things |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3426 dnl it needs to know: |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3427 if test "$opsys" = "darwin"; then |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3428 AC_DEFINE(REALPATH_CORRECTS_CASE) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3429 AC_DEFINE(DEFAULT_FILE_SYSTEM_IGNORE_CASE) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3430 fi |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3431 |
2651 | 3432 dnl This must come before the detection code for anything that is in a module |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3433 if test "$with_modules" != "no"; then |
3312 | 3434 AC_MSG_CHECKING([for module support]) |
3435 AC_MSG_RESULT() | |
2651 | 3436 |
3437 case "$opsys" in | |
3438 mingw* | cygwin* ) have_dl=yes ;; | |
5556
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3439 *) |
2651 | 3440 dnl Check for the ELFish dlopen() |
3441 AC_CHECK_HEADER(dlfcn.h, [ | |
3442 AC_MSG_CHECKING([for dlopen in -lc]) | |
3312 | 3443 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <dlfcn.h>], |
3444 [dlopen ("", 0);])], [ have_dl=yes ; AC_MSG_RESULT($have_dl)], [ | |
2741 | 3445 AC_MSG_RESULT([no]) |
2651 | 3446 AC_MSG_CHECKING([for dlopen in -ldl]) |
3447 ac_save_LIBS="$LIBS" | |
3448 LIBS="$LIBS -ldl" | |
3312 | 3449 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <dlfcn.h>], |
3450 [dlopen ("", 0);])], [ have_dl=yes; AC_MSG_RESULT($have_dl)], [ | |
2741 | 3451 AC_MSG_RESULT([no]) |
2651 | 3452 AC_MSG_CHECKING([for dlopen in -lsvld]) |
3453 LIBS="$ac_save_LIBS -lsvld" | |
3312 | 3454 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <dlfcn.h>], |
3455 [dlopen ("", 0);])], [ have_dl=yes; AC_MSG_RESULT($have_dl) ], | |
2741 | 3456 [LIBS="$ac_save_LIBS" ; AC_MSG_RESULT([no])])])])]) |
2651 | 3457 if test "$have_dl" = "yes"; then |
3458 AC_DEFINE(HAVE_DLOPEN) | |
3459 else | |
5556
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3460 dnl On Darwin, the DYLD API is deprecated, so we prefer dlopen if |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3461 dnl available, above. |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3462 if test "$opsys" = "darwin"; then |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3463 have_dl=yes |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3464 AC_DEFINE(HAVE_DYLD) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3465 AC_DEFINE(DLSYM_NEEDS_UNDERSCORE) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3466 else |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3467 dnl Check for HP/UX shl_load |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3468 AC_CHECK_HEADER(dl.h, [ |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3469 AC_MSG_CHECKING([for shl_load in -lc]) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3470 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <dl.h>], |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3471 [shl_load ("", 0, 0);])], [have_dl=yes; AC_MSG_RESULT($have_dl)],[ |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3472 AC_MSG_RESULT([no]) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3473 AC_MSG_CHECKING([for shl_load in -ldl]) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3474 ac_save_LIBS="$LIBS" |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3475 LIBS="$LIBS -ldld" |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3476 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <dl.h>], |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3477 [shl_load ("", 0, 0);])], [have_dl=yes], |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3478 [LIBS="$ac_save_LIBS"; AC_MSG_RESULT([no])])])]) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3479 if test "$have_dl" = "yes"; then |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3480 AC_DEFINE(HAVE_SHL_LOAD) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3481 else |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3482 dnl Check for libtool's libltdl |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3483 AC_CHECK_HEADER(ltdl.h, [ |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3484 AC_MSG_CHECKING([for lt_dlinit in -lltdl]) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3485 ac_save_LIBS="$LIBS" |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3486 LIBS="$LIBS -lltdl" |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3487 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <ltdl.h>], |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3488 [lt_dlinit ();])], [have_dl=yes], [LIBS="$ac_save_LIBS"])]) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3489 AC_MSG_RESULT($have_dl) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3490 if test "$have_dl" = "yes"; then |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3491 AC_DEFINE(HAVE_LTDL) |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3492 fi |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3493 dnl end !HP/UX |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3494 fi |
a142ad1a9140
Use dlsym() in preference to NSLookupSymbolInModule() on Darwin, if available.
Aidan Kehoe <kehoea@parhasard.net>
parents:
5499
diff
changeset
|
3495 fi |
2651 | 3496 dnl end !dlopen |
3497 fi | |
3498 ac_save_LIBS= | |
3499 esac | |
3500 | |
3501 if test -n "$have_dl"; then | |
3502 dnl XE_SHLIB_STUFF (in aclocal.m4) defines $can_build_shared | |
3503 XE_SHLIB_STUFF | |
3504 fi | |
3505 | |
3506 if test "$can_build_shared" = "yes"; then | |
3507 AC_DEFINE(HAVE_SHLIB) | |
3508 dnl src must be built before modules on MacOSX and Windows platforms, since | |
3509 dnl the binary must be available to properly link the modules | |
3510 dnl For no-module builds, this is added *after* the module directories | |
3511 XE_APPEND(src, MAKE_SUBDIR) | |
3512 XE_APPEND(src, INSTALL_ARCH_DEP_SUBDIR) | |
3513 test -n "$libdl" && XE_PREPEND(-l${libdl}, LIBS) | |
3514 AC_CHECK_FUNCS(dlerror _dlerror) | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3515 with_modules=yes |
2651 | 3516 MOD_CC="../../lib-src/ellcc" |
3517 MODCFLAGS="\$(CFLAGS) --mode=compile --mod-output=\$@ -I../../src -I\$(srcdir)/../../src" | |
3518 INSTALLPATH="\$(moduledir)" | |
3519 MOD_INSTALL_PROGRAM=${INSTALL_PROGRAM} | |
3520 OBJECT_TO_BUILD="\$(MODNAME).ell" | |
3521 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3522 if test "$with_modules" = "yes"; then |
2651 | 3523 XE_DIE("Required module support cannot be provided.") |
3524 else | |
3525 echo " No module support." | |
3526 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3527 with_modules=no |
2651 | 3528 fi |
3529 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3530 if test "$with_modules" != "yes"; then |
2651 | 3531 MOD_CC="$XEMACS_CC" |
3532 MODCFLAGS="\$(XE_CFLAGS) -I../../src -I\$(srcdir)/../../src" | |
3533 INSTALLPATH="" | |
3534 MOD_INSTALL_PROGRAM="true" | |
3535 OBJECT_TO_BUILD="\$(MODNAME).o" | |
3536 fi | |
3537 MODARCHDIR= | |
3538 MAKE_DOCFILE="../../lib-src/make-docfile" | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3539 AC_SUBST(with_modules, $with_modules) |
2651 | 3540 AC_SUBST(MOD_CC) |
3541 AC_SUBST(MODARCHDIR) | |
3542 AC_SUBST(MAKE_DOCFILE) | |
3543 AC_SUBST(MODCFLAGS) | |
3544 AC_SUBST(INSTALLPATH) | |
3545 AC_SUBST(MOD_INSTALL_PROGRAM) | |
3546 AC_SUBST(OBJECT_TO_BUILD) | |
3547 | |
3548 dnl Autodetect tooltalk | |
3549 if test "$with_tooltalk" != "no" ; then | |
3550 dnl autodetect the location of tt_c.h | |
3551 dnl tt_c.h might be in Tt or desktop include directories | |
3552 for dir in "" "Tt/" "desktop/" ; do | |
3553 AC_CHECK_HEADER(${dir}tt_c.h, tt_c_h_file="${dir}tt_c.h"; break) | |
3554 done | |
3555 if test -z "$tt_c_h_file"; then | |
3556 if test "$with_tooltalk" = "yes"; then | |
3557 USAGE_ERROR("Unable to find required tooltalk header files.") | |
3558 fi | |
3559 with_tooltalk=no | |
3560 fi | |
3561 fi | |
3562 if test "$with_tooltalk" != "no" ; then | |
3563 for extra_libs in "" "-lI18N -lce" "-lcxx"; do | |
3564 AC_CHECK_LIB(tt, tt_message_create, | |
3565 tt_libs="-ltt $extra_libs"; break, [:],$extra_libs) | |
3566 done | |
3567 if test -z "$tt_libs"; then | |
3568 if test "$with_tooltalk" = "yes"; then | |
3569 USAGE_ERROR("Unable to find required tooltalk libraries.") | |
3570 fi | |
3571 with_tooltalk=no | |
3572 fi | |
3573 fi | |
3574 test -z "$with_tooltalk" && with_tooltalk=yes | |
3575 if test "$with_tooltalk" = "yes"; then | |
3576 AC_DEFINE(TOOLTALK) | |
3577 AC_DEFINE_UNQUOTED(TT_C_H_FILE, "$tt_c_h_file") | |
3578 XE_PREPEND($tt_libs, libs_x) | |
3579 fi | |
3580 | |
3581 dnl Autodetect CDE | |
3582 test -z "$with_cde" && { AC_CHECK_HEADER(Dt/Dt.h, , with_cde=no) } | |
3583 test -z "$with_cde" && { AC_CHECK_LIB(DtSvc, DtDndDragStart, [:], with_cde=no) } | |
3584 if test "$with_dragndrop" = "no" ; then | |
3585 if test "$with_cde" = "yes" ; then | |
3312 | 3586 AC_MSG_WARN([--with-cde forced to `no'; no generic Drag'n'Drop support]) |
2651 | 3587 fi |
3588 with_cde=no | |
3589 fi | |
3590 test -z "$with_cde" && with_cde=yes | |
3591 if test "$with_cde" = "yes" ; then | |
3592 AC_DEFINE(HAVE_CDE) | |
3593 XE_PREPEND(-lDtSvc, libs_x) | |
3594 XE_APPEND(CDE, dragndrop_proto) | |
3595 with_tooltalk=yes # CDE requires Tooltalk | |
3596 need_motif=yes # CDE requires Motif | |
3597 fi | |
3598 | |
3599 if test "$with_gtk" = "yes"; then | |
3600 XE_APPEND(GTK, dragndrop_proto) | |
3601 fi | |
3602 | |
3603 dnl Autodetect Drag'n'Drop support | |
4790
bc4f2511bbea
Remove support for the OffiX drag-and-drop protocol. See xemacs-patches
Jerry James <james@xemacs.org>
parents:
4769
diff
changeset
|
3604 dnl always included if CDE or MSWindows is defined |
2651 | 3605 if test "$with_dragndrop" != "no" ; then |
3606 AC_MSG_CHECKING(if drag and drop API is needed) | |
3607 if test -n "$dragndrop_proto" ; then | |
3608 with_dragndrop=yes | |
3609 AC_MSG_RESULT([yes (${dragndrop_proto} )]) | |
3610 AC_DEFINE(HAVE_DRAGNDROP) | |
3611 XE_APPEND(dragdrop.o, extra_objs) | |
3612 else | |
3613 with_dragndrop=no | |
3614 AC_MSG_RESULT(no) | |
3615 fi | |
3616 fi | |
3617 | |
3618 dnl Autodetect LDAP | |
3312 | 3619 AC_MSG_CHECKING([for LDAP]) |
3620 AC_MSG_RESULT() | |
2651 | 3621 ldap_libs= |
3622 test -z "$with_ldap" && { AC_CHECK_HEADER(ldap.h, ,with_ldap=no) } | |
3623 test -z "$with_ldap" && { AC_CHECK_HEADER(lber.h, ,with_ldap=no) } | |
3624 if test "$with_ldap" != "no"; then | |
3625 AC_CHECK_LIB(ldap, ldap_search, with_ldap=yes) | |
3626 dnl Check for other libraries we need to link with to get the main routines. | |
3627 test "$with_ldap" != "yes" && { AC_CHECK_LIB(ldap, ldap_open, [with_ldap=yes with_ldap_lber=yes], , -llber) } | |
3628 test "$with_ldap" != "yes" && { AC_CHECK_LIB(ldap, ldap_open, [with_ldap=yes with_ldap_lber=yes with_ldap_krb=yes], , -llber -lkrb) } | |
3629 test "$with_ldap" != "yes" && { AC_CHECK_LIB(ldap, ldap_open, [with_ldap=yes with_ldap_lber=yes with_ldap_krb=yes with_ldap_des=yes], , -llber -lkrb -ldes) } | |
3630 dnl Recently, we need -lber even though the main routines are elsewhere, | |
3631 dnl because otherwise be get link errors w.r.t. ber_pvt_opt_on. So just | |
3632 dnl check for that (it's a variable not a fun but that doesn't seem to | |
3633 dnl matter in these checks) and stick in -lber if so. Can't hurt (even to | |
3634 dnl stick it in always shouldn't hurt, I don't think) ... #### Someone who | |
3635 dnl #### understands LDAP needs to fix this properly. | |
3636 test "$with_ldap_lber" != "yes" && { AC_CHECK_LIB(lber, ber_pvt_opt_on, with_ldap_lber=yes) } | |
3637 fi | |
3638 if test "$with_ldap" = "yes"; then | |
3639 AC_DEFINE(HAVE_LDAP) | |
3640 if test "$with_ldap_des" = "yes" ; then | |
3641 XE_PREPEND(-ldes, ldap_libs) | |
3642 fi | |
3643 if test "$with_ldap_krb" = "yes" ; then | |
3644 XE_PREPEND(-lkrb, ldap_libs) | |
3645 fi | |
3646 if test "$with_ldap_lber" = "yes" ; then | |
3647 XE_PREPEND(-llber, ldap_libs) | |
3648 fi | |
3649 XE_PREPEND(-lldap, ldap_libs) | |
3650 save_LIBS="$LIBS" LIBS="$LIBS $ldap_libs" | |
3651 AC_CHECK_FUNCS(ldap_set_option ldap_get_lderrno ldap_result2error ldap_parse_result) | |
3652 LIBS="$save_LIBS" | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3653 if test "$with_modules" = "yes"; then |
5724
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3654 XE_APPEND(modules/ldap, MAKE_SUBDIR) |
2651 | 3655 XE_APPEND(modules/ldap, INSTALL_ARCH_DEP_SUBDIR) |
5724
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3656 else |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3657 mkdir src |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3658 for fil in eldap.c eldap.h; do |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3659 ${LN_S} "$srcdir/modules/ldap/$fil" "src/$fil" |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3660 done |
2651 | 3661 fi |
3662 fi | |
3663 AC_SUBST(ldap_libs) | |
3664 | |
3665 dnl Autodetect PostgreSQL | |
3666 dnl On many Linux systems, PostgreSQL is packaged to be installed in /usr; | |
3667 dnl in this case, configure will easily detect it there. | |
3668 dnl | |
3669 dnl If PostgreSQL is installed into a different prefix, | |
3670 dnl (such as the default /usr/local/pgsql when building from source), | |
3671 dnl that prefix must be specified using the --with-site-prefixes flag. | |
3672 postgresql_libs= | |
3673 if test "$with_postgresql" != "no"; then | |
3312 | 3674 AC_MSG_CHECKING([for PostgreSQL]) |
3675 AC_MSG_RESULT() | |
2651 | 3676 |
3677 dnl Look for these standard header file locations, known to be used on Linux | |
3678 for header_dir in "" "pgsql/" "postgresql/"; do | |
3679 AC_CHECK_HEADER(${header_dir}libpq-fe.h, | |
3680 libpq_fe_h_file=${header_dir}libpq-fe.h; break) | |
3681 done | |
3682 | |
3050 | 3683 pq_libs= |
3684 extra_libs= | |
3685 if test -n "$libpq_fe_h_file"; then | |
3686 dnl #### Would it be nicer to do this with a loop? | |
3687 dnl It seems unlikely that checking for SSL/crypto support can hurt, | |
3688 dnl even if it's found. | |
3689 AC_CHECK_LIB(pq, PQconnectdb,[pq_libs="-lpq"],[ | |
3690 unset ac_cv_lib_pq_PQconnectdb; | |
3691 AC_CHECK_LIB(pq, PQconnectdb,[pq_libs="-lpq -lcrypto -lssl"],, | |
3692 [-lcrypto -lssl])]) | |
3693 if test -z "$pq_libs"; then | |
3694 have_libpq="no" | |
3695 else | |
3696 have_libpq="yes" | |
3697 fi | |
3698 fi | |
2651 | 3699 |
3700 if test -n "$libpq_fe_h_file" -a "$have_libpq" = "yes"; then | |
3701 with_postgresql=yes | |
3702 AC_DEFINE(HAVE_POSTGRESQL) | |
3703 AC_CHECK_LIB(pq,PQconnectStart, [ | |
3704 with_postgresqlv7=yes; | |
3050 | 3705 AC_DEFINE(HAVE_POSTGRESQLV7)], [:], $extra_libs) |
2651 | 3706 AC_DEFINE_UNQUOTED(LIBPQ_FE_H_FILE, "$libpq_fe_h_file") |
3050 | 3707 XE_PREPEND([$pq_libs], postgresql_libs) |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3708 if test "$with_modules" = "yes"; then |
5724
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3709 XE_APPEND(modules/postgresql, MAKE_SUBDIR) |
2651 | 3710 XE_APPEND(modules/postgresql, INSTALL_ARCH_DEP_SUBDIR) |
5724
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3711 else |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3712 mkdir src |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3713 for fil in postgresql.c postgresql.h; do |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3714 ${LN_S} "$srcdir/modules/postgresql/$fil" "src/$fil" |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
3715 done |
2651 | 3716 fi |
3717 elif test "$with_postgresql" = "yes"; then | |
3718 XE_DIE("Required PostgreSQL support cannot be provided. Check --with-site-prefixes.") | |
3719 fi | |
3720 fi | |
3721 AC_SUBST(postgresql_libs) | |
3722 | |
3723 dnl ---------------------- | |
3724 dnl Graphics libraries | |
3725 dnl ---------------------- | |
3726 | |
3727 if test "$window_system" != "none"; then | |
3312 | 3728 AC_MSG_CHECKING([for graphics libraries]) |
3729 AC_MSG_RESULT() | |
2651 | 3730 |
3731 dnl add special code to handle xpm-nox on Cygwin (csw) | |
3732 dnl -- should only happen if CYGWIN && WITH_XPM && WITH_MSW && !WITH_X | |
3733 libpath_xpm= | |
3734 incpath_xpm= | |
3727 | 3735 libname_xpm="-lXpm" |
2651 | 3736 case "$opsys" in |
3737 cygwin*) | |
3228 | 3738 cygwin_top=`eval gcc -print-search-dirs | sed -ne s'/install: //p'` |
3739 cygwin_top=`eval "cd $cygwin_top/../../../..; pwd"` | |
2651 | 3740 case "$window_system" in |
3741 dnl use "standard" search pattern | |
3742 x11) ;; | |
3743 dnl hardcode "standard" non-X11 xpm lib/inc dirs | |
3744 msw) libpath_xpm="-L${cygwin_top}/lib/noX" | |
3745 incpath_xpm="-I${cygwin_top}/include/noX" | |
3727 | 3746 libname_xpm="-lXpm-noX" |
2651 | 3747 ;; |
3748 dnl not supported on cygwin (yet?) | |
3749 gtk) ;; | |
3750 dnl probably not reached... | |
3751 none) ;; | |
3752 dnl ditto | |
3753 *) ;; | |
3754 esac | |
3755 ;; | |
3756 dnl use "standard" search pattern for all other OS's | |
3757 *) ;; | |
3758 esac | |
3759 dnl Autodetect Xpm | |
3760 xpm_problem="" | |
3761 if test -z "$with_xpm"; then | |
3762 XE_PREPEND("$incpath_xpm", CFLAGS) | |
2940 | 3763 XE_PREPEND("$incpath_xpm", XE_CFLAGS) |
2651 | 3764 XE_PREPEND("$libpath_xpm", LDFLAGS) |
3765 AC_MSG_CHECKING(for Xpm - no older than 3.4f) | |
3727 | 3766 xe_check_libs="$libname_xpm" |
2651 | 3767 AC_RUN_IFELSE([AC_LANG_SOURCE([#define XPM_NUMBERS |
3768 #include <X11/xpm.h> | |
3769 int main(int c, char **v) { | |
3770 return c == 1 ? 0 : | |
3771 XpmIncludeVersion != XpmLibraryVersion() ? 1 : | |
3772 XpmIncludeVersion < 30406 ? 2 : 0 ;}])], | |
3773 [./conftest dummy_arg; xpm_status=$?; | |
3774 if test "$xpm_status" = "0"; then | |
3775 with_xpm=yes; | |
3776 else | |
3777 with_xpm=no; | |
3778 if test "$xpm_status" = "1"; then | |
3779 xpm_problem="Xpm library version and header file version don't match!" | |
3780 elif test "$xpm_status" = "2"; then | |
3781 xpm_problem="Xpm library version is too old!" | |
3782 else | |
3783 xpm_problem="Internal xpm detection logic error!" | |
3784 fi | |
3785 echo " | |
3786 *** WARNING *** $xpm_problem | |
3787 I'm not touching that with a 10-foot pole! | |
3788 If you really want to use the installed version of Xpm, rerun | |
3789 configure and add '--with-xpm=yes', but don't blame me if XEmacs crashes!" | |
3790 fi], | |
3791 [with_xpm=no]) | |
3792 xe_check_libs= | |
3793 AC_MSG_RESULT($with_xpm) | |
3794 fi | |
3795 if test "$with_xpm" = "yes"; then | |
3796 dnl #### This code assumes that if AC_CHECK_LIB fails, | |
3797 dnl #### then it will succeed if FOR_MSW is defined, | |
3798 dnl #### but doesn't actually verify this assumption. | |
3799 AC_DEFINE(HAVE_XPM) | |
3800 XE_PREPEND("$libpath_xpm", LDFLAGS) | |
3727 | 3801 XE_PREPEND("$libname_xpm", libs_x) |
2651 | 3802 XE_PREPEND("$incpath_xpm", CFLAGS) |
2940 | 3803 XE_PREPEND("$incpath_xpm", XE_CFLAGS) |
3312 | 3804 AC_MSG_CHECKING([for "FOR_MSW" xpm]) |
3727 | 3805 xe_check_libs="$libname_xpm" |
3316 | 3806 AC_LINK_IFELSE([AC_LANG_PROGRAM([],[XpmCreatePixmapFromData();])], |
2651 | 3807 [xpm_for_msw=no], |
3808 [xpm_for_msw=yes]) | |
3809 xe_check_libs= | |
3810 AC_MSG_RESULT($xpm_for_msw) | |
3811 if test "$xpm_for_msw" = "yes"; then | |
3812 AC_DEFINE(FOR_MSW) | |
3813 fi | |
3814 fi | |
3815 | |
3816 dnl Autodetect XFACE | |
3817 test -z "$with_xface" && { AC_CHECK_HEADER(compface.h, ,with_xface=no) } | |
3818 test -z "$with_xface" && { AC_CHECK_LIB(compface, UnGenFace,[:] ,with_xface=no) } | |
3819 test -z "$with_xface" && with_xface=yes | |
3820 if test "$with_xface" = "yes"; then | |
3821 AC_DEFINE(HAVE_XFACE) | |
3822 XE_PREPEND(-lcompface, libs_x) | |
3823 fi | |
3824 | |
4708
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3825 dnl autodetect GIF |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3826 test -z "$with_gif" && { AC_CHECK_HEADER(gif_lib.h, , with_gif=no) } |
2651 | 3827 if test "$with_gif" != "no"; then |
3828 with_gif="yes" | |
4708
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3829 dnl Versions of libgif and libungif prior to the introduction of |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3830 dnl EGifPutExtensionLast caused Emacs crashes. We'll require that |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3831 dnl function, too, in hopes that we can avoid similar crashes. |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3832 AC_CHECK_LIB(gif, EGifPutExtensionLast, |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3833 [XE_PREPEND(-lgif, libs_x)], |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3834 [AC_CHECK_LIB(ungif, EGifPutExtensionLast, |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3835 [XE_PREPEND(-lungif, libs_x)], with_gif=no)]) |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3836 fi |
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
3837 if test "$with_gif" != "no"; then |
2651 | 3838 AC_DEFINE(HAVE_GIF) |
3839 fi | |
3840 | |
3841 dnl Too many stupid linkers can't detect cascaded lib dependencies until runtime | |
3842 dnl So we always search for libz compression support. | |
3843 if test "$with_png $with_tiff" != "no no"; then | |
3844 AC_CHECK_LIB(c, inflate, [:], [ | |
3845 AC_CHECK_LIB(z, inflate, [XE_PREPEND(-lz, libs_x)],[ | |
3846 AC_CHECK_LIB(gz, inflate, [XE_PREPEND(-lgz, libs_x)])])]) | |
3847 fi | |
3848 | |
3849 dnl autodetect JPEG | |
3850 test -z "$with_jpeg" && { AC_CHECK_HEADER(jpeglib.h, ,with_jpeg=no) } | |
3851 test -z "$with_jpeg" && { AC_CHECK_LIB(jpeg, jpeg_destroy_decompress,[:],with_jpeg=no) } | |
3852 test -z "$with_jpeg" && with_jpeg=yes | |
3853 if test "$with_jpeg" = "yes"; then | |
3854 AC_DEFINE(HAVE_JPEG) | |
3855 XE_PREPEND(-ljpeg, libs_x) | |
3856 fi | |
3857 | |
3858 dnl autodetect PNG | |
3859 png_problem="" | |
3860 test -z "$with_png" && { AC_CHECK_FUNC(pow, ,with_png=no) } | |
3861 test -z "$with_png" && { AC_CHECK_HEADER(png.h, ,with_png=no) } | |
2667 | 3862 test -z "$with_png" && { AC_CHECK_LIB(png, png_read_image,[:],with_png=no,[-lz]) } |
2651 | 3863 if test -z "$with_png"; then |
3864 AC_MSG_CHECKING(for workable png version information) | |
3865 xe_check_libs="-lpng -lz" | |
3866 AC_RUN_IFELSE([AC_LANG_SOURCE([#include <png.h> | |
3867 int main(int c, char **v) { | |
3868 if (c == 1) return 0; | |
3869 if (strcmp(png_libpng_ver, PNG_LIBPNG_VER_STRING) != 0) return 1; | |
3870 return (PNG_LIBPNG_VER < 10002) ? 2 : 0 ;}])], | |
3871 [./conftest dummy_arg; png_status=$?; | |
3872 if test "$png_status" = "0"; then | |
3873 with_png=yes; | |
3874 else | |
3875 with_png=no; | |
3876 if test "$png_status" = "1"; then | |
3877 png_problem="PNG library version and header file don't match!" | |
3878 elif test "$png_status" = "2"; then | |
3879 png_problem="PNG library version too old (pre 1.0.2)!" | |
3880 fi | |
3881 echo " | |
3882 *** WARNING *** $png_problem | |
3883 I'm not touching that with a 10-foot pole! | |
3884 If you really want to use the installed version of libPNG, rerun | |
3885 configure and add '--with-png=yes', but don't blame me if XEmacs crashes!" | |
3886 fi], | |
3887 [with_png=no]) | |
3888 xe_check_libs= | |
3889 AC_MSG_RESULT($with_png) | |
3890 fi | |
3891 if test "$with_png" = "yes"; then | |
3892 AC_DEFINE(HAVE_PNG) | |
3893 XE_PREPEND(-lpng, libs_x) | |
3894 fi | |
3895 | |
3896 dnl autodetect TIFF | |
3897 test -z "$with_tiff" && { AC_CHECK_HEADER(tiffio.h, ,with_tiff=no) } | |
2667 | 3898 test -z "$with_tiff" && { AC_CHECK_LIB(tiff, TIFFClientOpen,[:],with_tiff=no,[-lz]) } |
2651 | 3899 test -z "$with_tiff" && with_tiff=yes |
3900 if test "$with_tiff" = "yes"; then | |
3901 AC_DEFINE(HAVE_TIFF) | |
3902 XE_PREPEND(-ltiff, libs_x) | |
3903 fi | |
3904 fi | |
3905 | |
3906 dnl ---------------------- | |
3907 dnl GTK-Specific Graphics libraries | |
3908 dnl ---------------------- | |
3909 | |
3910 if test "$with_gtk" = "yes"; then | |
3911 dnl Autodetect XFACE | |
3912 test -z "$with_xface" && { AC_CHECK_HEADER(compface.h, ,with_xface=no) } | |
3913 test -z "$with_xface" && { AC_CHECK_LIB(compface, UnGenFace,[:] ,with_xface=no) } | |
3914 test -z "$with_xface" && with_xface=yes | |
3915 if test "$with_xface" = "yes"; then | |
3916 AC_DEFINE(HAVE_XFACE) | |
3917 XE_PREPEND(-lcompface, libs_gtk) | |
3918 fi | |
3919 fi | |
3920 | |
3921 dnl ---------------------- | |
3922 dnl X-Specific Graphics libraries | |
3923 dnl ---------------------- | |
3924 | |
3925 if test "$with_x11" = "yes"; then | |
3312 | 3926 AC_MSG_CHECKING([for X11 graphics libraries]) |
3927 AC_MSG_RESULT() | |
2651 | 3928 fi |
3929 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3930 case "$with_widgets" in |
3019 | 3931 "" | "yes" | "athena") detect_athena=yes ;; |
2651 | 3932 *) detect_athena=no ;; |
3933 esac | |
3934 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
3935 case "$with_dialogs" in |
3019 | 3936 "" | "yes" | "athena") detect_athena=yes ;; |
3937 esac | |
3938 | |
2651 | 3939 if test "$with_x11" = "yes" -a "$detect_athena" = "yes" ; then |
3312 | 3940 AC_MSG_CHECKING([for the Athena widgets]) |
3941 AC_MSG_RESULT() | |
2651 | 3942 |
3943 dnl What in heck did the user actually want? | |
3944 case "$with_athena" in | |
3945 dnl This is the default, old fashioned flat Athena. | |
3946 "xaw" | "") athena_variant=Xaw athena_3d=no ;; | |
3947 "3d") athena_variant=Xaw3d athena_3d=yes ;; | |
3948 "next") athena_variant=neXtaw athena_3d=yes ;; | |
3949 "95") athena_variant=Xaw95 athena_3d=yes ;; | |
3950 "xpm") athena_variant=XawXpm athena_3d=yes ;; | |
3951 *) XE_DIE("Unknown Athena widget set \`$with_athena'. This should not happen.") ;; | |
3952 esac | |
3953 | |
5585
86d6adeb1cf4
Refactor check for Xaw3d.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5564
diff
changeset
|
3954 athena_3d_function=Xaw3dComputeBottomShadowRGB |
86d6adeb1cf4
Refactor check for Xaw3d.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5564
diff
changeset
|
3955 |
2651 | 3956 dnl Search for the Athena library... |
3957 if test "$athena_3d" = "no"; then | |
3958 AC_CHECK_LIB($athena_variant, XawScrollbarSetThumb, | |
3959 [ | |
3960 dnl Must not be a 3d library... | |
5585
86d6adeb1cf4
Refactor check for Xaw3d.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5564
diff
changeset
|
3961 AC_CHECK_LIB($athena_variant, $athena_3d_function, |
2651 | 3962 [AC_MSG_WARN([Could not find a non-3d Athena widget library.])], |
3963 athena_lib=$athena_variant) | |
3964 ], | |
3965 AC_MSG_WARN([Could not find an Athena widget library.])) | |
3966 else | |
3967 dnl The real configuration, need 3d library | |
5585
86d6adeb1cf4
Refactor check for Xaw3d.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5564
diff
changeset
|
3968 AC_CHECK_LIB($athena_variant, $athena_3d_function, athena_lib=$athena_variant, |
2651 | 3969 dnl OK, couldn't find it with a proper name, try the standard Athena lib |
3970 dnl If that is 3d, presume the user asked for what they have installed. | |
5585
86d6adeb1cf4
Refactor check for Xaw3d.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5564
diff
changeset
|
3971 AC_CHECK_LIB(Xaw, $athena_3d_function, |
2651 | 3972 [ |
3973 athena_lib=Xaw; | |
3974 AC_MSG_WARN([Assuming that libXaw is actually $athena_variant.]); | |
3975 ], | |
3976 [AC_MSG_WARN([Could not find a 3d Athena widget library that looked like $athena_variant.])])) | |
3977 fi | |
3978 | |
3979 dnl Now we locate the Athena headers that we need. | |
3980 if test "$athena_3d" = "no"; then | |
3981 AC_CHECK_HEADER(X11/Xaw/ThreeD.h, | |
3982 [AC_MSG_WARN([Could not find a non-3d Athena header set.])], | |
3983 [AC_CHECK_HEADER(X11/Xaw/XawInit.h, | |
3984 [athena_h_path=X11/Xaw], | |
2694 | 3985 [AC_MSG_WARN([Could not find a non-3d Athena header set.])], |
3986 [ | |
3987 #include <X11/Intrinsic.h> | |
3988 ])]) | |
2651 | 3989 else |
3990 dnl The three-d Athena headers are so much more slippery. | |
3991 dnl Curse this `Lets replace standard libraries' thing that they did. :/ | |
3992 AC_CHECK_HEADER(X11/$athena_variant/XawInit.h, | |
3993 [AC_CHECK_HEADER(X11/$athena_variant/ThreeD.h, | |
3994 [athena_h_path=X11/$athena_variant])],[], | |
3995 [ | |
3996 #if HAVE_X11_XFUNCPROTO_H | |
3997 #include <X11/Xfuncproto.h> | |
3998 #endif | |
2705 | 3999 #include <X11/Intrinsic.h> |
2651 | 4000 ]) |
4001 | |
4002 dnl Is the variant specific header directory directly under include? | |
4003 if test -z "$athena_h_path"; then | |
4004 AC_CHECK_HEADER($athena_variant/XawInit.h, | |
4005 [AC_CHECK_HEADER($athena_variant/ThreeD.h, | |
4006 athena_h_path=$athena_variant)],[], | |
4007 [ | |
4008 #if HAVE_X11_XFUNCPROTO_H | |
4009 #include <X11/Xfuncproto.h> | |
4010 #endif | |
2694 | 4011 #include <X11/Intrinsic.h> |
2651 | 4012 ]) |
4013 fi | |
4014 | |
4015 dnl If we couldn't find the specific variant, try the generic Athena 3d headers | |
4016 if test -z "$athena_h_path" -a "$athena_variant" != "Xaw3d"; then | |
4017 AC_CHECK_HEADER(X11/Xaw3d/XawInit.h, | |
4018 [AC_CHECK_HEADER(X11/Xaw3d/ThreeD.h, | |
4019 [ | |
4020 AC_MSG_WARN([Assuming that X11/Xaw3d headers are suitable for $athena_variant.]) | |
4021 athena_h_path=X11/Xaw3d | |
4022 ])],[], | |
4023 [ | |
4024 #if HAVE_X11_XFUNCPROTO_H | |
4025 #include <X11/Xfuncproto.h> | |
4026 #endif | |
2694 | 4027 #include <X11/Intrinsic.h> |
2651 | 4028 ]) |
4029 fi | |
4030 | |
4031 dnl Also generic 3d headers directly under include dir | |
4032 if test -z "$athena_h_path" -a "$athena_variant" != "Xaw3d"; then | |
4033 AC_CHECK_HEADER(Xaw3d/XawInit.h, | |
4034 [AC_CHECK_HEADER(Xaw3d/ThreeD.h, | |
4035 [ | |
4036 AC_MSG_WARN([Assuming that Xaw3d headers are suitable for $athena_variant.]) | |
4037 athena_h_path=Xaw3d | |
4038 ])],[], | |
4039 [ | |
4040 #if HAVE_X11_XFUNCPROTO_H | |
4041 #include <X11/Xfuncproto.h> | |
4042 #endif | |
2694 | 4043 #include <X11/Intrinsic.h> |
2651 | 4044 ]) |
4045 fi | |
4046 | |
4047 dnl If nothing yet found, see if Xaw is a 3d header set... | |
4048 dnl We AC_MSG_WARN if we fail because I am all out of ideas... | |
4049 if test -z "$athena_h_path"; then | |
4050 AC_CHECK_HEADER(X11/Xaw/ThreeD.h, | |
4051 [ | |
4052 AC_MSG_WARN([Assuming that X11/Xaw headers are suitable for $athena_variant.]) | |
4053 athena_h_path=X11/Xaw | |
4054 ], | |
4055 [AC_MSG_WARN([Could not find a suitable 3d Athena header set.])]) | |
4056 fi | |
4057 fi | |
4058 | |
4059 dnl Do we actually have a usable Athena widget set? Please? | |
4060 if test -n "$athena_lib" -a -n "$athena_h_path"; then | |
4061 have_xaw=yes | |
4062 else | |
4063 have_xaw=no | |
4064 fi | |
4065 | |
4066 else | |
4067 have_xaw=no | |
4068 fi dnl "$with_x11" = "yes" -a "detect_athena" = "yes" | |
4069 | |
4070 if test "$with_x11" = "yes"; then | |
4071 dnl autodetect Motif - but only add to libs_x later (if necessary) | |
4072 dnl Use a different function to the earlier test to avoid problems with the | |
4073 dnl internal cache. | |
4074 AC_CHECK_HEADER(Xm/Xm.h, | |
4075 [AC_CHECK_LIB(Xm, XmStringCreate, have_motif=yes, have_motif=no)], | |
4076 have_motif=no) | |
4077 | |
4078 if test "$have_motif" = "yes"; then | |
4079 dnl autodetect lesstif | |
4080 AC_MSG_CHECKING(for Lesstif) | |
4081 AC_EGREP_CPP(yes, | |
4082 [#include <Xm/Xm.h> | |
4083 #ifdef LESSTIF_VERSION | |
4084 yes | |
4085 #endif | |
4086 ], have_lesstif=yes, have_lesstif=no) | |
4087 AC_MSG_RESULT($have_lesstif) | |
4088 fi | |
4089 | |
4090 fi dnl "$with_x11" = "yes" | |
4091 | |
4092 dnl Finish ensuring that we have values for the various toolkit items. | |
4093 dnl Not all toolkits support all widgets | |
3019 | 4094 |
4095 dnl Avoid using Motif :-( | |
4096 case "$opsys" in | |
3738 | 4097 *linux* | *darwin* | *bsd* | *cygwin* ) lucid_prefers_motif="no" ;; |
3019 | 4098 * ) lucid_prefers_motif="yes" ;; |
4099 esac | |
2651 | 4100 |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4101 case "$with_menubars" in "" | "yes" | "athena" ) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4102 with_menubars="lucid" ;; |
2651 | 4103 esac |
3094 | 4104 dnl this is not in xft reloaded #3 |
4105 if test "$with_xft_menubars" != "no" ; then | |
4106 if test "$with_xft_emacs" = "yes" -a "$with_menubars" != "no" ; then | |
4107 with_xft_menubars="yes" | |
4108 else | |
4109 with_xft_menubars="no" | |
4110 fi | |
4111 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4112 case "$with_dialogs" in "" | "yes" | "lucid" ) |
3019 | 4113 if test "$lucid_prefers_motif" = "yes"; then |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4114 if test "$have_motif" = "yes"; then with_dialogs="motif" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4115 elif test "$have_xaw" = "yes"; then with_dialogs="athena" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4116 elif test "$with_msw" = "yes"; then with_dialogs="msw" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4117 else with_dialogs=no |
3019 | 4118 fi |
4119 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4120 if test "$have_xaw" = "yes"; then with_dialogs="athena" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4121 elif test "$have_motif" = "yes"; then with_dialogs="motif" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4122 elif test "$with_msw" = "yes"; then with_dialogs="msw" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4123 else with_dialogs=no |
3019 | 4124 fi |
2651 | 4125 fi ;; |
4126 esac | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4127 case "$with_scrollbars" in "" | "yes" ) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4128 with_scrollbars="lucid" ;; |
2651 | 4129 esac |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4130 case "$with_widgets" in "" | "yes" | "lucid") |
3019 | 4131 if test "$lucid_prefers_motif" = "yes"; then |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4132 if test "$have_motif" = "yes"; then with_widgets="motif" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4133 elif test "$have_xaw" = "yes"; then with_widgets="athena" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4134 elif test "$with_msw" = "yes"; then with_widgets="msw" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4135 else with_widgets=no |
3019 | 4136 fi |
4137 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4138 if test "$have_xaw" = "yes"; then with_widgets="athena" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4139 elif test "$have_motif" = "yes"; then with_widgets="motif" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4140 elif test "$with_msw" = "yes"; then with_widgets="msw" |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4141 else with_widgets=no |
3019 | 4142 fi |
2651 | 4143 fi ;; |
4144 esac | |
3094 | 4145 dnl this is not in xft reloaded #3 |
4146 if test "$with_xft_tabs" != "no" ; then | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4147 if test "$with_xft_emacs" = "yes" -a "$with_widgets" != "no" ; then |
3094 | 4148 with_xft_tabs="yes" |
4149 else | |
4150 with_xft_tabs="no" | |
4151 fi | |
4152 fi | |
4153 dnl this is not in xft reloaded #3 | |
4497
f863b2ee146f
Rename xft_gauge to xft_gauges.
Mats Lidell <matsl@xemacs.org>
parents:
4496
diff
changeset
|
4154 if test "$with_xft_gauges" != "no" ; then |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4155 if test "$with_xft_emacs" = "yes" -a "$with_widgets" != "no" ; then |
4497
f863b2ee146f
Rename xft_gauge to xft_gauges.
Mats Lidell <matsl@xemacs.org>
parents:
4496
diff
changeset
|
4156 with_xft_gauges="yes" |
3094 | 4157 else |
4497
f863b2ee146f
Rename xft_gauge to xft_gauges.
Mats Lidell <matsl@xemacs.org>
parents:
4496
diff
changeset
|
4158 with_xft_gauges="no" |
3094 | 4159 fi |
4160 fi | |
2651 | 4161 |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4162 all_widgets="$with_menubars $with_scrollbars $with_dialogs $with_toolbars $with_widgets" |
2651 | 4163 |
4164 case "$all_widgets" in | |
4165 *athena* ) | |
4166 if test "$have_xaw" != "yes"; then | |
4167 XE_DIE("Could not find a suitable Athena library to build with.") | |
4168 fi | |
4169 | |
4170 dnl Add the Lucid widget Athena code | |
4171 XE_APPEND(lwlib-Xaw.o, lwlib_objs) | |
4172 | |
4173 dnl Add the Athena widget library we located earlier | |
4174 XE_PREPEND(-l$athena_lib, libs_x) | |
4175 | |
4176 dnl Tell lwlib where to find the Athena header files. | |
4177 dnl Many people have tried to create a `smart' way of doing this, | |
4178 dnl but all have failed. Before changing the following ugly definitions, | |
4179 dnl consult the veterans of many a battle. | |
4180 AC_DEFINE_UNQUOTED(ATHENA_Scrollbar_h_,"$athena_h_path/Scrollbar.h") | |
4181 AC_DEFINE_UNQUOTED(ATHENA_Dialog_h_,"$athena_h_path/Dialog.h") | |
4182 AC_DEFINE_UNQUOTED(ATHENA_Form_h_,"$athena_h_path/Form.h") | |
4183 AC_DEFINE_UNQUOTED(ATHENA_Command_h_,"$athena_h_path/Command.h") | |
4184 AC_DEFINE_UNQUOTED(ATHENA_Label_h_,"$athena_h_path/Label.h") | |
4185 AC_DEFINE_UNQUOTED(ATHENA_LabelP_h_,"$athena_h_path/LabelP.h") | |
4186 AC_DEFINE_UNQUOTED(ATHENA_Toggle_h_,"$athena_h_path/Toggle.h") | |
4187 AC_DEFINE_UNQUOTED(ATHENA_ToggleP_h_,"$athena_h_path/ToggleP.h") | |
4188 AC_DEFINE_UNQUOTED(ATHENA_AsciiText_h_,"$athena_h_path/AsciiText.h") | |
4189 AC_DEFINE_UNQUOTED(ATHENA_XawInit_h_,"$athena_h_path/XawInit.h") | |
4190 | |
4191 AC_DEFINE(LWLIB_USES_ATHENA) | |
4192 AC_DEFINE(NEED_ATHENA) | |
4193 need_athena="yes" | |
4194 | |
4195 if test "$athena_3d" = "yes"; then | |
4196 AC_DEFINE(HAVE_ATHENA_3D) | |
4197 fi | |
4198 ;; | |
4199 esac | |
4200 | |
4201 case "$all_widgets" in *motif* ) | |
4202 AC_DEFINE(LWLIB_USES_MOTIF) | |
4203 AC_DEFINE(NEED_MOTIF) | |
4204 XE_APPEND(lwlib-Xm.o, lwlib_objs) | |
4205 need_motif=yes ;; | |
4206 esac | |
4207 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4208 test "$with_menubars" = "lucid" && XE_APPEND(xlwmenu.o, lwlib_objs) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4209 test "$with_menubars" = "motif" && XE_APPEND(xlwmenu.o, lwlib_objs) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4210 test "$with_scrollbars" = "lucid" && XE_APPEND(xlwscrollbar.o, lwlib_objs) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4211 test "$with_widgets" != "no" && test "$with_widgets" != "msw" && \ |
2651 | 4212 XE_APPEND(xlwtabs.o xlwgcs.o, lwlib_objs) |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4213 case "$with_widgets" in athena* ) |
2651 | 4214 XE_APPEND(xlwradio.o xlwcheckbox.o xlwgauge.o, lwlib_objs);; |
4215 esac | |
4216 case "$all_widgets" in *lucid* ) | |
4217 AC_DEFINE(NEED_LUCID) | |
4218 XE_APPEND(lwlib-Xlw.o, lwlib_objs) ;; | |
4219 esac | |
4220 | |
4221 AC_SUBST(lwlib_objs) | |
4222 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4223 test "$with_scrollbars" = "athena" && AC_DEFINE(LWLIB_SCROLLBARS_ATHENA) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4224 test "$with_dialogs" = "athena" && AC_DEFINE(LWLIB_DIALOGS_ATHENA) |
2651 | 4225 |
4226 if test "$athena_3d" = "yes"; then | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4227 test "$with_scrollbars" = "athena" && AC_DEFINE(LWLIB_SCROLLBARS_ATHENA3D) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4228 test "$with_dialogs" = "athena" && AC_DEFINE(LWLIB_DIALOGS_ATHENA3D) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4229 fi |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4230 |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4231 case "$with_widgets" in athena* ) AC_DEFINE(LWLIB_WIDGETS_ATHENA);; esac |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4232 test "$with_widgets" != "no" && test "$with_widgets" != "msw" && \ |
2651 | 4233 AC_DEFINE(LWLIB_TABS_LUCID) |
4234 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4235 test "$with_menubars" != "no" && AC_DEFINE(HAVE_MENUBARS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4236 test "$with_scrollbars" != "no" && AC_DEFINE(HAVE_SCROLLBARS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4237 test "$with_dialogs" != "no" && AC_DEFINE(HAVE_DIALOGS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4238 test "$with_toolbars" != "no" && AC_DEFINE(HAVE_TOOLBARS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4239 test "$with_widgets" != "no" && AC_DEFINE(HAVE_WIDGETS) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4240 |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4241 test "$with_menubars" = "lucid" && AC_DEFINE(LWLIB_MENUBARS_LUCID) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4242 test "$with_scrollbars" = "lucid" && AC_DEFINE(LWLIB_SCROLLBARS_LUCID) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4243 |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4244 test "$with_menubars" = "motif" && AC_DEFINE(LWLIB_MENUBARS_MOTIF) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4245 test "$with_scrollbars" = "motif" && AC_DEFINE(LWLIB_SCROLLBARS_MOTIF) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4246 test "$with_dialogs" = "motif" && AC_DEFINE(LWLIB_DIALOGS_MOTIF) |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4247 test "$with_widgets" = "motif" && AC_DEFINE(LWLIB_WIDGETS_MOTIF) |
2651 | 4248 |
4916
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4848
diff
changeset
|
4249 test "$with_xft_menubars" = "yes" && AC_DEFINE(HAVE_XFT_MENUBARS) |
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4848
diff
changeset
|
4250 test "$with_xft_tabs" = "yes" && AC_DEFINE(HAVE_XFT_TABS) |
a6c778975d7d
split USE_XFT into HAVE_XFT/USE_XFT
Ben Wing <ben@xemacs.org>
parents:
4848
diff
changeset
|
4251 test "$with_xft_gauges" = "yes" && AC_DEFINE(HAVE_XFT_GAUGES) |
3094 | 4252 |
2651 | 4253 dnl ---------------------- |
4254 dnl Mule-dependent options | |
4255 dnl ---------------------- | |
4256 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4257 test -z "$with_mule" && with_mule=no |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4258 |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4259 dnl if test "$with_mule" = "yes" && test ! -d "$srcdir/lisp/mule"; then |
2651 | 4260 dnl echo "Attempt to Build with Mule without Mule/Lisp" |
4261 dnl echo "Please install the XEmacs/Mule tarball or" | |
4262 dnl echo "rerun configure with --with-mule=no" | |
4263 dnl exit 1 | |
4264 dnl fi | |
4265 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4266 if test "$with_default_eol_detection" = "yes"; then |
2651 | 4267 AC_DEFINE(HAVE_DEFAULT_EOL_DETECTION) |
4268 fi | |
4269 | |
2973 | 4270 dnl initialize _libs variables for possible modules at top level |
4271 canna_libs= | |
4272 wnn_libs= | |
4273 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4274 if test "$with_mule" = "yes" ; then |
3312 | 4275 AC_MSG_CHECKING([for Mule-related features]) |
2651 | 4276 AC_DEFINE(MULE) |
4277 | |
4278 dnl Use -lintl to get internationalized strerror for Mule | |
4279 AC_CHECK_HEADERS(libintl.h) | |
4280 AC_CHECK_LIB(intl, strerror) | |
4281 | |
3312 | 4282 AC_MSG_CHECKING([for Mule input methods]) |
2651 | 4283 dnl Do we have the XmIm* routines? And if so, do we want to use them? |
4284 case "$with_xim" in "" | "yes" ) | |
3312 | 4285 AC_MSG_CHECKING([for XIM]) |
2651 | 4286 AC_CHECK_LIB(X11, XOpenIM, with_xim=xlib, with_xim=no) |
4287 dnl XIM + Lesstif is not (yet?) usable | |
3019 | 4288 dnl Only use Motif if linking Motif anyway, or don't have xlib XIM |
4289 if test "$need_motif $have_lesstif" = "yes no"; then | |
4290 AC_CHECK_LIB(Xm, XmImMbLookupString, with_xim=motif) | |
3248 | 4291 dnl #### This is always false. |
4292 dnl Not clear what we want, although "yes no yes" is insufficient. | |
3019 | 4293 elif test "$have_motif $have_lesstif $with_xim" = "yes no no"; then |
2651 | 4294 AC_CHECK_LIB(Xm, XmImMbLookupString, with_xim=motif) |
4295 fi ;; | |
4296 esac | |
4297 if test "$with_xim" != "no"; then | |
4298 AC_DEFINE(HAVE_XIM) | |
4299 if test "$with_xim" = "xlib"; then | |
4300 AC_DEFINE(XIM_XLIB) | |
4301 XE_ADD_OBJS(input-method-xlib.o) | |
4302 fi | |
4303 if test "$with_xim" = "motif"; then | |
4304 AC_DEFINE(XIM_MOTIF) | |
4305 need_motif=yes | |
4306 XE_ADD_OBJS(input-method-motif.o) | |
4307 fi | |
4308 if test "$with_xim" = "motif"; then | |
4309 with_xfs=no | |
4310 fi | |
4311 fi | |
4312 | |
4313 dnl "with_xfs" = "yes" | |
4314 if test "$with_xfs" = "yes" ; then | |
3312 | 4315 AC_MSG_CHECKING([for XFontSet]) |
2651 | 4316 AC_CHECK_LIB(X11, XmbDrawString, [:], with_xfs=no) |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4317 if test "$with_xfs" = "yes" && test "$with_menubars" = "lucid"; then |
2651 | 4318 AC_DEFINE(USE_XFONTSET) |
4319 if test "$with_xim" = "no" ; then | |
4320 XE_ADD_OBJS(input-method-xlib.o) | |
4321 fi | |
4322 fi | |
4323 fi dnl with_xfs | |
4324 | |
4325 dnl Autodetect WNN | |
4326 test "$with_wnn6" = "yes" && with_wnn=yes # wnn6 implies wnn support | |
4327 test -z "$with_wnn" && { AC_CHECK_HEADER(wnn/jllib.h, ,with_wnn=no) } | |
4328 dnl gcc 2.97 fixincludes breaks inclusion of wnn/commonhd.h | |
4329 test -z "$with_wnn" && { AC_CHECK_HEADER(wnn/commonhd.h, ,with_wnn=no) } | |
4330 dnl Detour to find crypt | |
4331 if test "$with_wnn" != "no"; then | |
4332 AC_CHECK_FUNCS(crypt) | |
4333 test "$ac_cv_func_crypt" != "yes" && { AC_CHECK_LIB(crypt, crypt) } | |
4334 fi | |
4335 dnl Back to our regularly scheduled wnn hunting | |
4336 if test -z "$with_wnn" -o "$with_wnn" = "yes"; then | |
4337 AC_CHECK_LIB(wnn,jl_dic_list_e,libwnn=wnn, | |
4338 AC_CHECK_LIB(wnn4,jl_dic_list_e,libwnn=wnn4, | |
4339 AC_CHECK_LIB(wnn6,jl_dic_list_e,libwnn=wnn6, | |
4340 AC_CHECK_LIB(wnn6_fromsrc,dic_list_e,libwnn=wnn6_fromsrc,with_wnn=no)))) | |
4341 fi | |
4342 test -z "$with_wnn" && with_wnn=yes | |
4343 if test "$with_wnn" = "yes"; then | |
4344 AC_DEFINE(HAVE_WNN) | |
4345 XE_PREPEND(-l$libwnn, libs_x) | |
4346 if test "$with_wnn6" != "no"; then | |
4347 AC_CHECK_LIB($libwnn, jl_fi_dic_list, with_wnn6=yes) | |
4348 test "$with_wnn6" = "yes" && AC_DEFINE(WNN6) | |
4349 fi | |
4350 fi | |
4351 | |
3830 | 4352 dnl Configure canna |
2973 | 4353 dnl canna_libs variable is initialized at toplevel |
3830 | 4354 dnl #### the hard-coding of /usr/local/canna/include is bogus and |
4355 dnl my Mac OS X 10.4 system needs /usr/local/canna/lib, too | |
4356 dnl #### this whole mess should be in modules/canna, no? maybe not | |
4357 have_canna=no | |
2651 | 4358 if test "$with_canna" != "no"; then |
4359 save_c_switch_site="$c_switch_site" | |
3830 | 4360 for canna_include_path in "" " -I/usr/local/canna/include"; do |
4361 for canna_wchar_aware in "" " -DCANNA_NEW_WCHAR_AWARE=1"; do | |
4362 c_switch_site="$save_c_switch_site$canna_include_path$canna_wchar_aware" | |
4363 # defeat autoconf's cache mechanism | |
4364 $as_unset ac_cv_header_canna_jrkanji_h | |
4365 $as_unset ac_cv_header_canna_RK_h | |
4366 # using $ac_header_compiler is a hack, but autoconf doesn't let us | |
4367 # get at this information otherwise :-( | |
4368 AC_CHECK_HEADER(canna/jrkanji.h,[AC_CHECK_HEADER(canna/RK.h,have_canna=$ac_header_compiler)]) | |
4369 test "$have_canna" = "yes" && break | |
4370 AC_MSG_WARN([You may ignore any *Present but not compiled* message | |
4371 from autoconf. We detect that condition and recheck, but there | |
4372 is no way to suppress autoconf's message.]) | |
4373 done | |
4374 test "$have_canna" = "yes" && break | |
4375 done | |
4376 if test "$have_canna" = "yes"; then | |
4377 c_switch_site="$save_c_switch_site$canna_include_path" | |
4378 else | |
2651 | 4379 c_switch_site="$save_c_switch_site" |
4380 fi | |
4381 fi | |
4382 | |
3830 | 4383 test "$have_canna" = "yes" && { AC_CHECK_LIB(RKC, RkBgnBun, [:],have_canna=no) } |
4384 test "$have_canna" = "yes" && { AC_CHECK_LIB(canna,jrKanjiControl,[:],have_canna=no) } | |
4385 if test "$have_canna" = "yes"; then | |
2651 | 4386 AC_DEFINE(HAVE_CANNA) |
3830 | 4387 test -n "$canna_wchar_aware" && AC_DEFINE(CANNA_NEW_WCHAR_AWARE) |
2973 | 4388 if test "$with_modules" = "yes"; then |
5724
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
4389 XE_APPEND(modules/canna, MAKE_SUBDIR) |
2973 | 4390 XE_APPEND(modules/canna, INSTALL_ARCH_DEP_SUBDIR) |
5724
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
4391 else |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
4392 mkdir src |
ede80ef92a74
Make soft links in src for module source files, if built in to the executable.
Jerry James <james@xemacs.org>
parents:
5676
diff
changeset
|
4393 ${LN_S} "$srcdir/modules/canna/canna_api.c" "src/canna_api.c" |
2973 | 4394 fi |
4395 XE_PREPEND(-lcanna -lRKC, canna_libs) | |
3830 | 4396 elif test "$with_canna" != "no"; then |
4397 AC_MSG_WARN([Canna configuration failed. If you expected success, | |
4398 maybe you need --with-site-prefixes=/usr/local/canna?]) | |
2651 | 4399 fi |
2973 | 4400 AC_SUBST(canna_libs) |
2651 | 4401 |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4402 else dnl "$with_mule" = "no" |
2651 | 4403 for feature in xim canna wnn; do |
4404 if eval "test -n \"\$with_${feature}\" -a \"\$with_${feature}\" != no" ; then | |
4405 AC_MSG_WARN([--with-${feature} ignored: Not valid without Mule support]) | |
4406 fi | |
4407 eval "with_${feature}=no" | |
4408 done | |
4409 fi dnl with_mule | |
4410 | |
4411 | |
4412 dnl At this point, we know whether we need the motif lib or not. | |
4413 if test "$need_motif" = "yes" ; then | |
4414 XE_PREPEND(-lXm, libs_x) | |
4415 dnl AIX needs the following library for use with Motif | |
4416 AC_CHECK_LIB(i18n, layout_object_getvalue, [XE_PREPEND(-li18n, libs_x)]) | |
4417 XE_COMPUTE_RUNPATH() | |
4418 fi | |
4419 | |
4834
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
4420 dnl Check for UTF-8 path-conversion functions in Cygwin 1.7 and on |
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
4421 case "$opsys" in |
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
4422 *cygwin* ) AC_CHECK_FUNCS(cygwin_conv_path) |
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
4423 ;; |
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
4424 esac |
b3ea9c582280
Use new cygwin_conv_path API with Cygwin 1.7 for converting names between Win32 and POSIX, UTF-8-aware, with attendant changes elsewhere
Ben Wing <ben@xemacs.org>
parents:
4833
diff
changeset
|
4425 |
2651 | 4426 dnl ---------------------------------------------------------------- |
4427 dnl Check for POSIX functions. | |
4428 dnl ---------------------------------------------------------------- | |
4429 | |
4430 AC_CHECK_FUNCS(cbrt closedir dup2 eaccess fmod fpathconf frexp fsync ftime ftruncate getaddrinfo gethostname getnameinfo getpagesize getrlimit gettimeofday getcwd link logb lrand48 matherr mkdir mktime perror poll random readlink rename res_init rint rmdir select setitimer setpgid setsid sigblock sighold sigprocmask snprintf strerror strlwr strupr symlink tzset ulimit umask usleep vlimit vsnprintf waitpid wcscmp wcslen) | |
4431 | |
4432 dnl getaddrinfo() is borked under hpux11 | |
4433 if test "$ac_cv_func_getaddrinfo" != "no" ; then | |
4434 case "$opsys" in | |
4435 hpux11 ) | |
4436 AC_MSG_WARN([Use of getaddrinfo is disabled for HP-UX 11.XX.]) | |
4437 ac_cv_func_getaddrinfo=no | |
4438 ;; | |
4439 esac | |
4440 fi | |
4441 | |
3092 | 4442 dnl check for vdb-related stuff |
4443 if test "$check_vdb_posix" = "yes" ; then | |
4444 dnl no mprotect, no vdb | |
4445 AC_CHECK_FUNC(mprotect,AC_DEFINE(HAVE_MPROTECT) have_vdb_mprotect=yes,) | |
4446 | |
4447 dnl sigaction needs either struct siginfo or siginfo_t | |
4448 AC_CHECK_FUNC(sigaction, AC_DEFINE(HAVE_SIGACTION) have_vdb_sigaction=yes, | |
4449 have_vdb_sigaction=no) | |
4450 AC_CHECK_MEMBER(struct siginfo.si_addr, | |
4451 AC_DEFINE(HAVE_STRUCT_SIGINFO_SI_ADDR) have_si_addr=yes,, | |
4452 [#include <signal.h>]) | |
4453 AC_CHECK_MEMBER(siginfo_t.si_addr, | |
4454 AC_DEFINE(HAVE_SIGINFO_T_SI_ADDR) have_si_addr=yes,, | |
4455 [#include <signal.h>]) | |
4456 if test "$have_si_addr" != "yes" ; then | |
4457 have_vdb_sigaction=no | |
4458 fi | |
4459 | |
4460 dnl signal needs struct sigcontext | |
4461 AC_CHECK_FUNC(signal, AC_DEFINE(HAVE_SIGNAL) have_vdb_signal=yes,) | |
4462 AC_CHECK_MEMBER(struct sigcontext.cr2, | |
4463 AC_DEFINE(HAVE_STRUCT_SIGCONTEXT_CR2) have_cr2=yes,, | |
4464 [#include <signal.h>]) | |
4465 | |
4466 if test "$have_cr2" != "yes" ; then | |
4467 have_vdb_signal=no | |
4468 fi | |
4469 | |
4470 if test "$have_vdb_mprotect" != "yes" ; then | |
4471 have_vdb_sigaction=no | |
4472 have_vdb_signal=no | |
4473 fi | |
4474 | |
4475 if test "$have_vdb_sigaction" != "yes" -a "$have_vdb_signal" != "yes" ; then | |
4476 have_vdb_posix=no | |
4477 have_vdb_fake=yes | |
3102 | 4478 XE_DIE("No working write-barrier implementation found for this system. |
4479 Please report this and provide information about your system.") | |
3092 | 4480 else |
4481 have_vdb_posix=yes | |
4482 have_vdb_fake=no | |
4483 fi | |
4484 fi | |
4485 | |
2651 | 4486 dnl ---------------------------------------------------------------- |
4487 dnl Check for Unixoid pty/process support. | |
4488 dnl ---------------------------------------------------------------- | |
4489 | |
4490 dnl There is no "standard" pty allocation method. Every system is different. | |
4491 dnl getpt() is the preferred pty allocation method on glibc systems. | |
4492 dnl _getpty() is the preferred pty allocation method on SGI systems. | |
4493 dnl grantpt(), unlockpt(), ptsname() are defined by Unix98. | |
4494 AC_CHECK_FUNCS(getpt _getpty grantpt unlockpt ptsname killpg tcgetpgrp) | |
4495 | |
4496 dnl openpty() is the preferred pty allocation method on BSD and Tru64 systems. | |
4497 dnl openpty() might be declared in: | |
4498 dnl - pty.h (Tru64 or Linux) | |
4499 dnl - libutil.h (FreeBSD) | |
4500 dnl - util.h (NetBSD) | |
4501 AC_CHECK_FUNC(openpty, have_openpty=yes, [ | |
4502 AC_CHECK_LIB(util, openpty, have_openpty=yes need_libutil=yes)]) | |
4503 if test "$have_openpty" = "yes"; then | |
4504 AC_DEFINE(HAVE_OPENPTY) | |
4505 AC_CHECK_HEADERS(libutil.h util.h, break) | |
4506 test "$need_libutil" = "yes" && XE_APPEND(-lutil, libs_system) | |
4507 fi | |
4508 | |
4509 dnl Check for system-specific pty header files | |
4510 dnl Often the TIOCSIG* symbols are hiding there. | |
4511 case "$opsys" in | |
4512 dnl HPUX pty.h #defines TRUE and FALSE, so just use ptyio.h there. | |
4513 hpux*) AC_CHECK_HEADERS(sys/ptyio.h) ;; | |
4514 *) AC_CHECK_HEADERS(pty.h) | |
4515 test "$ac_cv_header_pty_h" = "no" && AC_CHECK_HEADERS(sys/pty.h) | |
4516 ;; | |
4517 esac | |
4518 | |
4519 dnl Check for STREAM support functions. | |
4520 dnl Confusingly, "str" means both "string" and "SysV Streams". | |
4521 AC_CHECK_HEADERS(stropts.h) | |
4522 if test "$ac_cv_header_stropts_h" = "yes"; then | |
4523 AC_CHECK_FUNCS(isastream) | |
4524 AC_CHECK_HEADERS(strtio.h) dnl TIOCSIGNAL | |
4525 fi | |
4526 | |
5494
861f2601a38b
Sync s/ files with GNU 23.1.92, delete obsolete stuff, simplify other stuff
Ben Wing <ben@xemacs.org>
parents:
5016
diff
changeset
|
4527 dnl There is also AC_FUNC_GETLOADAVG; why don't we use it? |
2651 | 4528 dnl Check whether the system provides getloadavg(). |
4529 AC_CHECK_FUNCS(getloadavg) | |
4530 | |
4531 if test "$ac_cv_func_getloadavg" = "yes"; then | |
4532 dnl Solaris 8 declares getloadavg() in <sys/loadavg.h>. | |
4533 dnl glibc 2.2 declares getloadavg() in <stdlib.h>... | |
4534 dnl ...if we #define _GNU_SOURCE, which we do. | |
4535 AC_CHECK_HEADERS(sys/loadavg.h) | |
4536 else | |
4537 dnl We define our own getloadavg() using lower level functions. | |
4538 XE_ADD_OBJS(getloadavg.o) | |
4539 | |
5384
3889ef128488
Fix misspelled words, and some grammar, across the entire source tree.
Jerry James <james@xemacs.org>
parents:
5228
diff
changeset
|
4540 dnl Used by getloadavg() - does not require root privileges |
2651 | 4541 AC_CHECK_LIB(kstat, kstat_open) |
4542 AC_CHECK_HEADERS(kstat.h) | |
4543 | |
4544 dnl Another way to get the load average | |
4545 AC_CHECK_LIB(kvm, kvm_read) | |
4546 fi | |
4547 | |
4548 dnl If netdb.h does not declare h_errno, we must declare it by hand. | |
4549 AC_MSG_CHECKING(whether netdb declares h_errno) | |
3312 | 4550 AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <netdb.h>], |
4551 [return h_errno;])], | |
2651 | 4552 [AC_MSG_RESULT(yes) |
4553 AC_DEFINE(HAVE_H_ERRNO)], | |
4554 [AC_MSG_RESULT(no)]) | |
4555 | |
4556 AC_MSG_CHECKING(for sigsetjmp) | |
3312 | 4557 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <setjmp.h>], |
4558 [sigjmp_buf bar; sigsetjmp (bar, 0);])], | |
2651 | 4559 [AC_MSG_RESULT(yes) |
4560 AC_DEFINE(HAVE_SIGSETJMP)], | |
4561 [AC_MSG_RESULT(no)]) | |
4562 | |
4563 AC_MSG_CHECKING(whether localtime caches TZ) | |
4564 AC_CACHE_VAL(emacs_cv_localtime_cache, | |
4565 [if test "$ac_cv_func_tzset" = "yes"; then | |
4566 AC_RUN_IFELSE([AC_LANG_SOURCE([#include <time.h> | |
4567 #if STDC_HEADERS | |
4568 # include <stdlib.h> | |
4569 #endif | |
4570 extern char **environ; | |
4571 unset_TZ () | |
4572 { | |
4573 char **from, **to; | |
4574 for (to = from = environ; (*to = *from); from++) | |
4575 if (! (to[[0]][[0]] == 'T' && to[[0]][[1]] == 'Z' && to[[0]][[2]] == '=')) | |
4576 to++; | |
4577 } | |
4578 char TZ_GMT0[[]] = "TZ=GMT0"; | |
4579 char TZ_PST8[[]] = "TZ=PST8"; | |
4580 main() | |
4581 { | |
4582 time_t now = time ((time_t *) 0); | |
4583 int hour_GMT0, hour_unset; | |
4584 if (putenv (TZ_GMT0) != 0) | |
4585 exit (1); | |
4586 hour_GMT0 = localtime (&now)->tm_hour; | |
4587 unset_TZ (); | |
4588 hour_unset = localtime (&now)->tm_hour; | |
4589 if (putenv (TZ_PST8) != 0) | |
4590 exit (1); | |
4591 if (localtime (&now)->tm_hour == hour_GMT0) | |
4592 exit (1); | |
4593 unset_TZ (); | |
4594 if (localtime (&now)->tm_hour != hour_unset) | |
4595 exit (1); | |
4596 exit (0); | |
4597 }])], emacs_cv_localtime_cache=no, emacs_cv_localtime_cache=yes, | |
4598 [# If we have tzset, assume the worst when cross-compiling. | |
4599 emacs_cv_localtime_cache=yes]) | |
4600 else | |
4601 # If we lack tzset, report that localtime does not cache TZ, | |
4602 # since we can't invalidate the cache if we don't have tzset. | |
4603 emacs_cv_localtime_cache=no | |
4604 fi],[:])dnl | |
4605 AC_MSG_RESULT($emacs_cv_localtime_cache) | |
4606 if test $emacs_cv_localtime_cache = yes; then | |
4607 AC_DEFINE(LOCALTIME_CACHE) | |
4608 fi | |
4609 | |
4610 if test "$HAVE_TIMEVAL" = "yes"; then | |
4611 AC_MSG_CHECKING(whether gettimeofday accepts one or two arguments) | |
3312 | 4612 AC_LINK_IFELSE([AC_LANG_PROGRAM([ |
2651 | 4613 #ifdef TIME_WITH_SYS_TIME |
4614 #include <sys/time.h> | |
4615 #include <time.h> | |
4616 #else | |
4617 #ifdef HAVE_SYS_TIME_H | |
4618 #include <sys/time.h> | |
4619 #else | |
4620 #include <time.h> | |
4621 #endif | |
4622 #endif | |
4623 ], | |
4624 [ | |
4625 struct timeval time; | |
4626 gettimeofday (&time, 0); | |
3312 | 4627 ])], |
2651 | 4628 [AC_MSG_RESULT(two)], |
4629 [AC_MSG_RESULT(one) | |
4630 AC_DEFINE(GETTIMEOFDAY_ONE_ARGUMENT)]) | |
4631 fi | |
4632 | |
4633 | |
4634 AC_C_INLINE | |
4635 test "$ac_cv_c_inline" != "no" -a "$GCC" = "yes" && XE_ADD_OBJS(inline.o) | |
4636 | |
4637 dnl check for the typeof extension | |
4638 AC_MSG_CHECKING(for typeof) | |
3312 | 4639 AC_COMPILE_IFELSE([AC_LANG_SOURCE([int i; __typeof__(i) j;])], |
4640 typeofname="__typeof__", | |
4641 [AC_COMPILE_IFELSE([AC_LANG_SOURCE([int i; typeof(i) j;])], | |
4642 typeofname="typeof", | |
2651 | 4643 typeofname=no)]) |
4644 AC_MSG_RESULT($typeofname) | |
4645 if test "$typeofname" != "no"; then | |
4646 AC_DEFINE_UNQUOTED(TYPEOF, $typeofname) | |
4647 fi | |
4648 | |
4649 dnl HP-UX has a working alloca in libPW. | |
4650 dnl case "${GCC}${opsys}" in hpux* ) | |
4651 dnl AC_CHECK_FUNC(alloca, [:], [AC_CHECK_LIB(PW, alloca)]) | |
4652 dnl esac | |
4653 | |
4654 dnl AC_FUNC_ALLOCA doesn't know about DEC C's #pragma intrinsic(alloca) | |
4655 if test "$__DECC" != "yes"; then | |
4656 AC_FUNC_ALLOCA | |
4657 test -n "$ALLOCA" && XE_ADD_OBJS($ALLOCA) | |
4658 fi | |
4659 | |
4660 AC_MSG_CHECKING(for working alloca in function calls) | |
4661 AC_RUN_IFELSE([AC_LANG_SOURCE([ | |
4662 #if defined (__CYGWIN__) | |
4663 #include <alloca.h> | |
4664 #elif defined (__GNUC__) | |
4665 #define alloca __builtin_alloca | |
4666 #elif defined (__DECC) | |
4667 #include <alloca.h> | |
4668 #pragma intrinsic(alloca) | |
4669 #elif defined (HAVE_ALLOCA_H) | |
4670 #include <alloca.h> | |
4671 #elif defined (_AIX) | |
4672 #pragma alloca | |
4673 #elif ! defined (alloca) | |
4674 #ifdef C_ALLOCA | |
4675 #define alloca xemacs_c_alloca | |
4676 #else | |
4677 void *alloca (); | |
4678 #endif /* C_ALLOCA */ | |
4679 #endif /* !defined (alloca) */ | |
4680 | |
4681 void | |
4682 f1 (double a, void *ptr, int b) | |
4683 { | |
4684 unsigned char *ptr2 = (unsigned char *) ptr; | |
4685 if (ptr2[[0]] != 0xBF || ptr2[[1]] != 0xBF || ptr2[[3000]] != 0xBF) | |
4686 exit (1); | |
4687 if (a != 3.1415 || b != -5490) | |
4688 exit (1); | |
4689 } | |
4690 | |
4691 int | |
4692 f2 (short c, void *ptr, long e) | |
4693 { | |
4694 unsigned char *ptr2 = (unsigned char *) ptr; | |
4695 if (ptr2[[0]] != 0xFB || ptr2[[1]] != 0xFB || ptr2[[1000]] != 0xFB) | |
4696 exit (1); | |
4697 if (c != 665 || e != 776776776) | |
4698 exit (1); | |
4699 f1 (3.1415, memset (alloca (3001), 0xBF, 3001), -5490); | |
4700 return 42; | |
4701 } | |
4702 | |
4703 int | |
4588
6a6689b96f00
Adopt Martin's suggestion of "char **argv" throughout configure.ac.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4543
diff
changeset
|
4704 main (int argc, char **argv) |
2651 | 4705 { |
4706 if (f2 (665, memset (alloca (1001), 0xFB, 1001), 776776776) != 42) | |
4707 return 1; | |
4708 return 0; | |
4709 } | |
4710 ])], working_alloca_in_function_calls=yes, working_alloca_in_function_calls=no) | |
4711 AC_MSG_RESULT($working_alloca_in_function_calls) | |
4712 test "$working_alloca_in_function_calls" != "yes" && \ | |
4713 AC_DEFINE(BROKEN_ALLOCA_IN_FUNCTION_CALLS) | |
4714 | |
4715 AC_MSG_CHECKING([for working scanf]) | |
4716 AC_RUN_IFELSE([AC_LANG_SOURCE([ | |
4717 int | |
4718 main (int argc, char **argv) | |
4719 { | |
4720 int ret, cp1, cp2, endcount; | |
4721 char *p = "0x7d 0x000E "; | |
4722 ret = sscanf (p, "%i %i%n", &cp1, &cp2, &endcount); | |
4723 /* endcount should be 13 but it's 11 in Cygwin newlib after 6/04; | |
4724 this breaks unicode.c */ | |
4725 return endcount != 13; | |
4726 } | |
4727 ])], working_scanf=yes, working_scanf=no) | |
4728 AC_MSG_RESULT($working_scanf) | |
4729 test "$working_scanf" != "yes" && \ | |
4730 AC_DEFINE(CYGWIN_SCANF_BUG) | |
4731 | |
4732 dnl Check whether strcoll exists and works correctly. (This does more | |
4733 dnl than just check for its existence.) If so, it defines HAVE_STRCOLL. | |
4734 AC_FUNC_STRCOLL | |
4735 | |
4736 dnl If `getpgrp' takes no argument (the POSIX.1 version), define | |
4737 dnl `GETPGRP_VOID'. Otherwise, it is the BSD version, which takes a | |
4738 dnl process ID as an argument. | |
4739 AC_CHECK_FUNCS(getpgrp) | |
4740 AC_FUNC_GETPGRP | |
4741 | |
4742 dnl We used to call AC_FUNC_MMAP here | |
4743 dnl Instead we now use following, suggested by Neal Becker | |
4744 AC_MSG_CHECKING(for working mmap) | |
4745 AC_RUN_IFELSE([AC_LANG_SOURCE([#include <stdio.h> | |
4746 #include <unistd.h> | |
4747 #include <fcntl.h> | |
4748 #include <sys/mman.h> | |
4749 | |
4750 #ifndef MAP_VARIABLE | |
4751 #define MAP_VARIABLE 0 | |
4752 #endif | |
4753 | |
4754 #ifndef MAP_FAILED | |
4755 #define MAP_FAILED -1 | |
4756 #endif | |
4757 | |
4588
6a6689b96f00
Adopt Martin's suggestion of "char **argv" throughout configure.ac.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4543
diff
changeset
|
4758 int main (int argc, char **argv) |
2651 | 4759 { |
4760 int fd = -1; | |
4761 caddr_t p; | |
4762 #ifndef MAP_ANONYMOUS | |
4763 fd = open ("/dev/zero", O_RDWR); | |
4764 if (fd < 0) | |
4765 return 1; | |
4766 #define MAP_ANONYMOUS 0 | |
4767 #endif | |
4768 if (mmap(0, 1024, PROT_READ | PROT_WRITE, | |
4769 MAP_PRIVATE | MAP_VARIABLE | MAP_ANONYMOUS, | |
4770 fd, 0) != (void *) MAP_FAILED) | |
4771 return 0; | |
4772 perror ("conftest: mmap failed"); | |
4773 return 1; | |
4759
aa5ed11f473b
Remove support for obsolete systems. See xemacs-patches message with ID
Jerry James <james@xemacs.org>
parents:
4738
diff
changeset
|
4774 }])], have_mmap=yes, have_mmap=no) |
2651 | 4775 AC_MSG_RESULT($have_mmap) |
4776 test "$have_mmap" = "yes" && AC_DEFINE(HAVE_MMAP) | |
4777 | |
4778 dnl By default we switch off rel-alloc on cygwin as it generally causes us grief | |
4779 case "$opsys" in cygwin*) | |
4780 test "$with_rel_alloc" = "default" && with_rel_alloc=no ;; | |
4781 esac | |
4782 dnl rel_alloc requires either GNU malloc or system malloc with mmap | |
4783 dnl We only turn rel_alloc on by default if mmap is available. | |
4784 test "$GNU_MALLOC" != "yes" -a "$have_mmap" != "yes" && with_rel_alloc=no | |
4785 if test "$with_rel_alloc $have_mmap" = "default yes"; then | |
4786 if test "$doug_lea_malloc" = "yes"; then | |
4787 dnl Check if malloc() calls mmap(), making rel_alloc pointless. | |
4788 AC_MSG_CHECKING(for M_MMAP_THRESHOLD) | |
3312 | 4789 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include <malloc.h>],[ |
2651 | 4790 #ifndef M_MMAP_THRESHOLD |
4791 #error No M_MMAP_THRESHOLD :-( | |
4792 !@+$%^&*_)(_ - unlikely to compile... | |
4793 #endif | |
3312 | 4794 ])], [with_rel_alloc=no; AC_MSG_RESULT(yes);], |
4795 [with_rel_alloc=yes; AC_MSG_RESULT(no);]) | |
2651 | 4796 else |
4797 with_rel_alloc=yes | |
4798 fi | |
4799 fi | |
4800 test "$with_rel_alloc" = "yes" && AC_DEFINE(REL_ALLOC) | |
4801 | |
4802 dnl Check for terminal I/O variants | |
4803 dnl TERMIOS systems may have termio.h, but not vice-versa, I think. | |
4804 AC_CHECK_HEADER(termios.h, | |
4805 AC_DEFINE(HAVE_TERMIOS) | |
4806 AC_DEFINE(SIGNALS_VIA_CHARACTERS) | |
4807 AC_DEFINE(NO_TERMIO), | |
4808 [AC_CHECK_HEADER(termio.h, [AC_DEFINE(HAVE_TERMIO)])]) | |
4809 | |
4810 | |
4811 dnl Check for Internet sockets. | |
4812 AC_CHECK_FUNC(socket, | |
4813 [AC_CHECK_HEADER(netinet/in.h, | |
4814 [AC_CHECK_HEADER(arpa/inet.h, [ | |
4815 AC_DEFINE(HAVE_SOCKETS) | |
3312 | 4816 AC_MSG_CHECKING([for sun_len member in struct sockaddr_un]) |
4817 AC_LINK_IFELSE([AC_LANG_PROGRAM([ | |
2651 | 4818 #include <sys/types.h> |
4819 #include <sys/socket.h> | |
4820 #include <sys/un.h> | |
4821 ], | |
3312 | 4822 [static struct sockaddr_un x; x.sun_len = 1;])], |
2651 | 4823 [AC_MSG_RESULT(yes); AC_DEFINE(HAVE_SOCKADDR_SUN_LEN)], |
4824 [AC_MSG_RESULT(no)]) | |
3312 | 4825 AC_MSG_CHECKING([for ip_mreq struct in netinet/in.h]) |
4826 AC_LINK_IFELSE([AC_LANG_PROGRAM([ | |
2651 | 4827 #include <sys/types.h> |
4828 #include <netinet/in.h> | |
4829 ], | |
3312 | 4830 [static struct ip_mreq x;])], |
2651 | 4831 [AC_MSG_RESULT(yes); AC_DEFINE(HAVE_MULTICAST)], |
4832 [AC_MSG_RESULT(no)])])])]) | |
4833 | |
4834 dnl Check for SYS V IPC. (Inferior to sockets.) | |
4835 AC_CHECK_FUNC(msgget, | |
4836 [AC_CHECK_HEADER(sys/ipc.h, | |
4837 [AC_CHECK_HEADER(sys/msg.h, | |
4838 [AC_DEFINE(HAVE_SYSVIPC)])])]) | |
4839 | |
4840 dnl Check for directory variants | |
4841 AC_CHECK_HEADER(dirent.h, [AC_DEFINE(SYSV_SYSTEM_DIR)], | |
4842 [AC_CHECK_HEADER(sys/dir.h, , [AC_DEFINE(NONSYSTEM_DIR_LIBRARY)])]) | |
4843 | |
4844 dnl Check for nlist.h | |
4845 AC_CHECK_HEADER(nlist.h, AC_DEFINE(NLIST_STRUCT), ) | |
4846 | |
4847 dnl Check for sound of various sorts. | |
3312 | 4848 AC_MSG_CHECKING([for sound support]) |
4849 AC_MSG_RESULT() | |
2651 | 4850 |
4851 dnl Autodetect native sound | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4852 test -n "$with_native_sound_lib" && with_sound_native=yes |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4853 |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4854 if test "$with_sound_native" != "no"; then |
2651 | 4855 dnl Maybe sound is already on include path... |
4856 if test -n "$with_native_sound_lib"; then | |
4857 AC_CHECK_HEADER(multimedia/audio_device.h, | |
4858 [sound_found=yes sound_cflags="" | |
4859 XE_ADD_OBJS(sunplay.o)]) | |
4860 fi | |
4861 | |
4862 dnl Autodetect Sun native sound from SUNWaudmo package | |
4863 if test -z "$sound_found" -a -d "/usr/demo/SOUND"; then | |
4864 if test -d "/usr/demo/SOUND/include/multimedia"; then | |
4865 sun_sound_cflags="-I/usr/demo/SOUND/include" | |
4866 elif test -d "/usr/demo/SOUND/multimedia"; then | |
4867 sun_sound_cflags="-I/usr/demo/SOUND" | |
4868 fi | |
4869 | |
4870 if test -n "$with_native_sound_lib"; then | |
4871 sun_sound_lib="$with_native_sound_lib" | |
4872 elif test -r "/usr/demo/SOUND/lib/libaudio.a"; then | |
4873 sun_sound_lib="/usr/demo/SOUND/lib/libaudio.a" | |
4874 elif test -r "/usr/demo/SOUND/libaudio.a"; then | |
4875 sun_sound_lib="/usr/demo/SOUND/libaudio.a" | |
4876 fi | |
4877 | |
4878 if test -n "$sun_sound_cflags" -a -n "$sun_sound_lib"; then | |
4879 with_native_sound_lib="$sun_sound_lib" | |
4880 sound_cflags="$sun_sound_cflags" | |
4881 sound_found=yes | |
4882 XE_ADD_OBJS(sunplay.o) | |
4883 fi | |
4884 fi | |
4885 | |
4886 dnl Check for SGI and HP native sound libs | |
4887 if test -z "$sound_found"; then | |
4888 case "$ac_cv_build" in | |
4889 *-sgi-* ) | |
4890 if test -z "$with_native_sound_lib"; then | |
4891 AC_CHECK_LIB(audio, ALopenport, with_native_sound_lib="-laudio") | |
4892 fi | |
4893 if test -n "$with_native_sound_lib"; then | |
4894 sound_found=yes sound_cflags="" | |
4895 XE_ADD_OBJS(sgiplay.o) | |
4896 fi ;; | |
4897 hppa*-hp-hpux* ) | |
4898 if test -z "$with_native_sound_lib"; then | |
4899 AC_CHECK_LIB(Alib, AOpenAudio, with_native_sound_lib="-lAlib") | |
4900 fi | |
4901 if test -n "$with_native_sound_lib"; then | |
4902 sound_found=yes | |
4903 XE_ADD_OBJS(hpplay.o) | |
4904 if test "$GCC" = "yes" # Kludge city | |
4905 then sound_cflags="-Dconst= -Dvolatile= -I/usr/audio/examples" | |
4906 else sound_cflags="+e -I/usr/audio/examples" | |
4907 fi | |
4908 fi ;; | |
4909 esac | |
4910 fi | |
4911 | |
3060 | 4912 dnl Win32 uses native sound |
2651 | 4913 if test -z "$sound_found"; then |
3060 | 4914 case "$opsys" in cygwin* | mingw* ) |
2651 | 4915 sound_found=yes |
4916 with_native_sound_lib= | |
4917 XE_ADD_OBJS(ntplay.o) | |
3060 | 4918 ;; |
4919 esac | |
2651 | 4920 fi |
4921 | |
4922 dnl Check for Linux/BSD native sound (also on recent Cygwins) | |
4923 if test -z "$sound_found"; then | |
4924 for dir in "machine" "sys" "linux"; do | |
4925 AC_CHECK_HEADER([${dir}/soundcard.h], [ | |
4926 sound_found=yes | |
2663 | 4927 case "${ac_cv_build}" in |
2651 | 4928 *netbsd* ) |
4929 # #### this is probably not the right way to do this | |
4930 # we should port to native NetBSD stuff | |
2663 | 4931 |
4932 dnl Aidan says: We have other things to be doing. If some | |
4933 dnl energetic NetBSD partisan volunteers, then yeah, cool, | |
4934 dnl but as it is, this works, and is unlikely to stop | |
4935 dnl working any time soon. | |
4936 | |
2651 | 4937 AC_CHECK_LIB(ossaudio, _oss_ioctl, |
2663 | 4938 [with_native_sound_lib=-lossaudio |
2651 | 4939 AC_MSG_WARN([Using NetBSD-deprecated -lossaudio])], |
4940 [sound_found=no]) | |
4941 ;; | |
4942 dnl Aidan sez: OpenBSD as well can use Linux's sound API, and needs | |
4943 dnl the same library. Add here! | |
4944 esac | |
4945 break]) | |
4946 done | |
4947 | |
4948 if test "$sound_found" = "yes"; then | |
4949 need_miscplay=yes | |
4950 XE_ADD_OBJS(linuxplay.o) | |
4951 AC_DEFINE_UNQUOTED(SOUNDCARD_H_FILE, ["${dir}/soundcard.h"]) | |
4952 fi | |
4953 fi | |
4954 | |
4955 if test "$sound_found" = "yes"; then | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4956 with_sound_native=yes |
2651 | 4957 else |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4958 if test "$with_sound_native" = "yes" ; then |
2651 | 4959 AC_MSG_WARN([No native libraries found. Disabling native sound support.]) |
4960 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4961 with_sound_native=no |
2651 | 4962 fi |
4963 fi | |
4964 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4965 if test "$with_sound_native" = "yes"; then |
2651 | 4966 AC_DEFINE(HAVE_NATIVE_SOUND) |
4967 test -n "$with_native_sound_lib" && XE_PREPEND($with_native_sound_lib, LIBS) | |
4968 fi | |
4969 | |
3308 | 4970 dnl ALSA sound support |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4971 if test "$with_sound_alsa" != "no"; then |
3309 | 4972 AC_CHECK_HEADER([alsa/input.h], [ |
3308 | 4973 AC_CHECK_LIB(asound, snd_pcm_open, have_alsa_sound=yes)]) |
4974 if test "$have_alsa_sound" = "yes"; then | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4975 with_sound_alsa=yes |
3308 | 4976 AC_DEFINE(HAVE_ALSA_SOUND) |
4977 XE_ADD_OBJS(alsaplay.o) | |
4978 XE_PREPEND(-lasound, LIBS) | |
4979 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4980 test "$with_sound_alsa" = "yes" && \ |
3308 | 4981 XE_DIE("Required ALSA sound support cannot be provided.") |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4982 with_sound_alsa=no |
3308 | 4983 fi |
4984 fi | |
4985 | |
2651 | 4986 dnl NAS Sound support |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4987 if test "$with_sound_nas" != "no"; then |
2651 | 4988 AC_CHECK_HEADER(audio/audiolib.h, [ |
4989 AC_CHECK_LIB(audio, AuOpenServer, have_nas_sound=yes)]) | |
4990 if test "$have_nas_sound" = "yes"; then | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4991 with_sound_nas=yes |
2651 | 4992 AC_DEFINE(HAVE_NAS_SOUND) |
4993 XE_ADD_OBJS(nas.o) | |
4994 XE_PREPEND(-laudio, libs_x) | |
4995 dnl If the nas library does not contain the error jump point, | |
4996 dnl then we force safer behavior. | |
4997 AC_EGREP_HEADER(AuXtErrorJump,audio/Xtutil.h,,[old_nas=yes; AC_DEFINE(NAS_NO_ERROR_JUMP)]) | |
4998 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
4999 test "$with_sound_nas" = "yes" && \ |
2651 | 5000 XE_DIE("Required NAS sound support cannot be provided.") |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5001 with_sound_nas=no |
2651 | 5002 fi |
5003 fi | |
5004 | |
5005 dnl ESD Sound support | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5006 if test "$with_sound_esd" != "no"; then |
2651 | 5007 AC_CHECK_PROG(have_esd_config, esd-config, yes, no) |
5008 if test "$have_esd_config" = "yes"; then | |
5009 save_c_switch_site="$c_switch_site" save_LIBS="$LIBS" | |
5010 XE_APPEND(`esd-config --cflags`, c_switch_site) | |
5011 XE_PREPEND(`esd-config --libs`, LIBS) | |
5012 AC_CHECK_FUNC(esd_play_stream, | |
5013 have_esd_sound=yes, | |
5014 c_switch_site="$save_c_switch_site" LIBS="$save_LIBS") | |
5015 fi | |
5016 | |
5017 if test "$have_esd_sound" = "yes"; then | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5018 with_sound_esd=yes |
2651 | 5019 need_miscplay=yes |
5020 XE_ADD_OBJS(esd.o) | |
5021 AC_DEFINE(HAVE_ESD_SOUND) | |
5022 else | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5023 test "$with_sound_esd" = "yes" && \ |
2651 | 5024 XE_DIE("Required ESD sound support cannot be provided.") |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5025 with_sound_esd=no |
2651 | 5026 fi |
5027 fi | |
5028 | |
5029 test "$need_miscplay" = "yes" && XE_ADD_OBJS(miscplay.o) | |
5030 | |
5031 dnl --------------------- | |
5032 dnl TTY-dependent options | |
5033 dnl --------------------- | |
5034 | |
5035 test -z "$with_tty" && with_tty=yes | |
5036 | |
5037 if test "$with_tty" = "yes" ; then | |
3312 | 5038 AC_MSG_CHECKING([for TTY-related features]) |
5039 AC_MSG_RESULT() | |
2651 | 5040 AC_DEFINE(HAVE_TTY) |
5041 | |
5042 dnl Autodetect ncurses. | |
5043 if test -z "$with_ncurses"; then | |
5044 AC_CHECK_LIB(ncurses, tgetent, with_ncurses=yes, with_ncurses=no) | |
5045 fi | |
5046 if test "$with_ncurses" = "yes"; then | |
5047 AC_DEFINE(HAVE_NCURSES) | |
5048 AC_CHECK_HEADER(ncurses/curses.h, curses_h_file=ncurses/curses.h) | |
5049 AC_CHECK_HEADER(ncurses/term.h, term_h_file=ncurses/term.h) | |
5050 XE_ADD_OBJS(terminfo.o) | |
5051 XE_PREPEND(-lncurses, LIBS) | |
5052 | |
5053 if test "$ac_cv_header_ncurses_curses_h" != "yes" ; then | |
5054 dnl Try again, and check for the bogus ncurses/ include bug. | |
5055 dnl (i.e. ncurses/curses.h bogusly includes <unctrl.h> instead of | |
5056 dnl <ncurses/unctrl.h>) | |
5057 save_c_switch_site="$c_switch_site" | |
5058 c_switch_site="$c_switch_site -I/usr/include/ncurses" | |
5059 AC_CHECK_HEADER(ncurses/curses.h, curses_h_file=ncurses/curses.h) | |
5060 if test "$ac_cv_header_ncurses_curses_h" = "yes" | |
5061 then AC_MSG_WARN([Your system has the bogus ncurses include bug.]) | |
5062 else c_switch_site="$save_c_switch_site" | |
5063 fi | |
5064 fi | |
5065 else dnl "$with_ncurses" = "no" | |
5066 dnl Autodetect terminfo/-lcurses/-ltermlib/-ltermcap | |
5067 if test "$have_terminfo" = "yes"; then | |
5068 XE_ADD_OBJS(terminfo.o) | |
5069 if test -n "$libs_termcap"; then | |
5070 XE_PREPEND($libs_termcap, LIBS) | |
5071 else | |
5072 for lib in curses termlib termcap; do | |
5073 AC_CHECK_LIB($lib, tgetent, XE_PREPEND(-l${lib}, LIBS); break) | |
5074 done | |
5075 fi | |
5076 else dnl "$have_terminfo" = "no" && "with_ncurses" = "no" | |
5077 XE_ADD_OBJS(tparam.o) | |
5078 dnl The HP-UX curses library seems to have a badly broken version of select(2) | |
5079 dnl that makes "poll: interrupted system call" messages to appear and | |
5080 dnl Emacs subprocesses to hang (e.g. TeX compilation w/ AUCTeX) */ | |
5081 case "$opsys" in *-hp-hpux* ) libs_termcap="-ltermcap" ;; esac | |
5082 if test -n "$libs_termcap"; then | |
5083 XE_PREPEND($libs_termcap, LIBS) | |
5084 else | |
5085 AC_CHECK_LIB(curses, tgetent, XE_PREPEND(-lcurses, LIBS), | |
5086 AC_CHECK_LIB(termcap, tgetent, XE_PREPEND(-ltermcap, LIBS), | |
5087 XE_ADD_OBJS(termcap.o))) | |
5088 fi | |
5089 fi | |
5090 fi | |
5091 AC_DEFINE_UNQUOTED(CURSES_H_FILE, "${curses_h_file-curses.h}") | |
5092 AC_DEFINE_UNQUOTED(TERM_H_FILE, "${term_h_file-term.h}") | |
5093 | |
5094 dnl General Purpose Mouse (libgpm) support | |
5095 if test "$with_gpm" != "no"; then | |
5096 AC_CHECK_HEADER(gpm.h, [ | |
5097 AC_CHECK_LIB(gpm, Gpm_Open, have_gpm=yes)]) | |
5098 if test "$have_gpm" = "yes"; then | |
5099 with_gpm=yes | |
5100 AC_DEFINE(HAVE_GPM) | |
5101 XE_PREPEND(-lgpm, LIBS) | |
5102 elif test "$with_gpm" = "yes"; then | |
5103 XE_DIE(["GPM requested, but gpm.h or libgpm seems to be missing."]) | |
5104 else | |
5105 with_gpm=no | |
5106 fi | |
5107 fi | |
5108 | |
5109 else dnl "$with_tty" = "no" | |
5110 for feature in ncurses gpm; do | |
5111 if eval "test -n \"\$with_${feature}\" -a \"\$with_${feature}\" != no" ; then | |
5112 AC_MSG_WARN([--with-${feature} ignored: Not valid without TTY support]) | |
5113 fi | |
5114 eval "with_${feature}=no" | |
5115 done | |
5116 fi dnl with_tty | |
5117 | |
5118 dnl Database support | |
5119 dnl We do not necessarily have to have libdb/lib(g)dbm for DB/(G)DBM support. | |
5120 dnl On FreeBSD, both DB and DBM are part of libc. | |
5121 dnl By default, we check for DBM support in libgdbm, then libc, then libdbm. | |
5122 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5123 test "$with_database_gdbm $with_database_dbm $with_database_berkdb" \ |
3312 | 5124 != "no no no" && AC_MSG_CHECKING([for database support]) && \ |
5125 AC_MSG_RESULT() | |
2651 | 5126 |
5127 dnl Check for ndbm.h, required for either kind of DBM support. | |
4699
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4661
diff
changeset
|
5128 dnl #### Should we check for gdbm.h, too? (Seen on MacPorts.) |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5129 if test "$with_database_gdbm $with_database_dbm" != "no no"; then |
4699
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4661
diff
changeset
|
5130 ndbm_h_file="" |
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4661
diff
changeset
|
5131 AC_CHECK_HEADERS([ndbm.h gdbm/ndbm.h],[ndbm_h_file=$ac_header; break;],[],[]) |
4762
53f27fcd3cd9
Make configure --with-database={dbm|gdbm} work again.
Mike Alexander <mta@umich.edu>
parents:
4759
diff
changeset
|
5132 if test "x$ndbm_h_file" = "x"; then |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5133 test "$with_database_gdbm" = "yes" -o \ |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5134 "$with_database_dbm" = "yes" && \ |
2651 | 5135 XE_DIE("Required DBM support cannot be provided.") |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5136 with_database_gdbm=no with_database_dbm=no] |
4699
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4661
diff
changeset
|
5137 fi |
2651 | 5138 fi |
5139 | |
5140 dnl Check for DBM support in libgdbm. | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5141 if test "$with_database_gdbm" != "no"; then |
2651 | 5142 AC_CHECK_LIB(gdbm, dbm_open, [ |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5143 with_database_gdbm=yes with_database_dbm=no libdbm=-lgdbm], [ |
4401
01970033faa6
Configure fixes from Hans de Graaff, as used in Gentoo.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4350
diff
changeset
|
5144 AC_CHECK_LIB(gdbm_compat, dbm_open, [ |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5145 with_database_gdbm=yes with_database_dbm=no libdbm="-lgdbm_compat -lgdbm"], [ |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5146 if test "$with_database_gdbm" = "yes"; then |
2651 | 5147 XE_DIE("Required GNU DBM support cannot be provided.") |
5148 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5149 with_database_gdbm=no], -lgdbm) |
4401
01970033faa6
Configure fixes from Hans de Graaff, as used in Gentoo.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4350
diff
changeset
|
5150 ]) |
2651 | 5151 fi |
5152 | |
5153 dnl Check for DBM support in libc and libdbm. | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5154 if test "$with_database_dbm" != "no"; then |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5155 AC_CHECK_FUNC(dbm_open, [with_database_dbm=yes libdbm=], [ |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5156 AC_CHECK_LIB(dbm, dbm_open, [with_database_dbm=yes libdbm=-ldbm], [ |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5157 test "$with_database_dbm" = "yes" && \ |
2651 | 5158 XE_DIE("Required DBM support cannot be provided.") |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5159 with_database_dbm=no])]) |
2651 | 5160 fi |
5161 | |
5162 dnl Tell make about the DBM support we detected. | |
5163 test -n "$libdbm" && XE_PREPEND("$libdbm", LIBS) | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5164 if test "$with_database_gdbm" = "yes" -o \ |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5165 "$with_database_dbm" = "yes"; then |
4699
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4661
diff
changeset
|
5166 AC_DEFINE_UNQUOTED(NDBM_H_FILE,"$ndbm_h_file") |
2651 | 5167 AC_DEFINE(HAVE_DBM) |
4991
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5168 dnl gdbm's ndbm.h has old-style prototypes with missing arguments. |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5169 dnl These just don't cut it for c++. So if we're using c++, then |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5170 dnl test whether we can make a dbm call, using dbm_close(DBM *). |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5171 if test "$XEMACS_CC_GPP" = "yes"; then |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5172 AC_MSG_RESULT() |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5173 AC_LANG_PUSH(C++) |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5174 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([#include "$ndbm_h_file"], |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5175 [dbm_close((DBM *) 0);])], |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5176 [AC_MSG_CHECKING(whether ndbm.h is compatible with g++) |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5177 AC_MSG_RESULT(yes) |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5178 AC_DEFINE(TRUST_NDBM_H_PROTOTYPES)], |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5179 [AC_MSG_CHECKING(whether ndbm.h is compatible with g++) |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5180 AC_MSG_RESULT(no)]) |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5181 AC_LANG_POP() |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5182 else |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5183 AC_DEFINE(TRUST_NDBM_H_PROTOTYPES) |
97c45e3ad810
implement configure test for whether ndbm.h prototypes are broken
Ben Wing <ben@xemacs.org>
parents:
4969
diff
changeset
|
5184 fi |
4699
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4661
diff
changeset
|
5185 $as_unset ndbm_h_file |
0e1461b592ce
Check for gdbm/ndbm.h, too.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4661
diff
changeset
|
5186 fi |
2651 | 5187 |
3739 | 5188 dnl Check for u_int*_t typedefs. |
5189 AC_CHECK_TYPES([u_int8_t, u_int16_t, u_int32_t]) | |
5190 | |
2651 | 5191 dnl Check for Berkeley DB. |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5192 if test "$with_database_berkdb" != "no"; then |
2651 | 5193 AC_MSG_CHECKING(for Berkeley db.h) |
5194 for header in "db/db.h" "db.h"; do | |
3312 | 5195 AC_COMPILE_IFELSE([AC_LANG_SOURCE([ |
2651 | 5196 #include <stdlib.h> |
5197 #if !(defined __GLIBC__ && __GLIBC_MINOR__ >= 1) | |
5198 #ifdef HAVE_INTTYPES_H | |
5199 #define __BIT_TYPES_DEFINED__ | |
5200 #include <inttypes.h> | |
3739 | 5201 #if !HAVE_U_INT8_T |
2651 | 5202 typedef uint8_t u_int8_t; |
3739 | 5203 #endif |
5204 #if !HAVE_U_INT16_T | |
2651 | 5205 typedef uint16_t u_int16_t; |
3739 | 5206 #endif |
5207 #if !HAVE_U_INT32_T | |
2651 | 5208 typedef uint32_t u_int32_t; |
3739 | 5209 #endif |
2651 | 5210 #ifdef WE_DONT_NEED_QUADS |
3739 | 5211 #if !HAVE_U_INT64_T |
2651 | 5212 typedef uint64_t u_int64_t; |
5213 #endif | |
5214 #endif | |
5215 #endif | |
3739 | 5216 #endif |
2651 | 5217 #include <$header> |
3312 | 5218 ])], db_h_file="$header"; break) |
2651 | 5219 done |
5220 if test -z "$db_h_file" | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5221 then AC_MSG_RESULT(no); with_database_berkdb=no |
2651 | 5222 else AC_MSG_RESULT($db_h_file) |
5223 fi | |
5224 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5225 if test "$with_database_berkdb" != "no"; then |
2651 | 5226 AC_MSG_CHECKING(for Berkeley DB version) |
5227 AC_EGREP_CPP(yes, | |
5228 [#include <$db_h_file> | |
5229 #if DB_VERSION_MAJOR > 1 | |
5230 yes | |
5231 #endif | |
5232 ], [AC_EGREP_CPP(yes, | |
5233 [#include <$db_h_file> | |
5234 #if DB_VERSION_MAJOR > 2 | |
5235 yes | |
5236 #endif | |
5237 ], [AC_EGREP_CPP(yes, | |
5238 [#include <$db_h_file> | |
5239 #if DB_VERSION_MAJOR > 3 | |
5240 yes | |
5241 #endif | |
5242 ], [AC_MSG_RESULT(4); dbfunc=db_create; dbver=4],[ | |
5243 AC_MSG_RESULT(3); dbfunc=db_create; dbver=3])],[ | |
5244 AC_MSG_RESULT(2); dbfunc=db_open; dbver=2])],[ | |
5245 AC_MSG_RESULT(1); dbfunc=dbopen; dbver=1]) | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5246 AC_CHECK_FUNC($dbfunc, with_database_berkdb=yes need_libdb=no, [ |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5247 AC_CHECK_LIB(db, $dbfunc, with_database_berkdb=yes need_libdb=yes)]) |
2651 | 5248 fi |
5249 | |
5250 dnl Berk db 4.1 decorates public functions with version information | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5251 if test "$with_database_berkdb" = "yes" -a "$dbver" = "4"; then |
2651 | 5252 rm -f $tempcname |
5253 echo "#include <$db_h_file>" > $tempcname | |
5254 echo "configure___ dbfunc=db_create" >> $tempcname | |
5255 define(TAB, [ ])dnl | |
5256 eval `$CPP -Isrc $tempcname \ | |
5257 | sed -n -e "s/[[ TAB]]*=[[ TAB\"]]*/='/" -e "s/[[ TAB\"]]*\$/'/" -e "s/^configure___//p"` | |
5258 rm -f $tempcname | |
5259 AC_MSG_WARN("db_create is really $dbfunc") | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5260 AC_CHECK_LIB(db, $dbfunc, with_database_berkdb=yes need_libdb=yes) |
2651 | 5261 fi |
5262 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5263 if test "$with_database_berkdb" = "yes"; then |
2651 | 5264 AC_DEFINE_UNQUOTED(DB_H_FILE, "$db_h_file") |
5265 AC_DEFINE(HAVE_BERKELEY_DB) | |
5266 test "$need_libdb" = "yes" && XE_PREPEND(-ldb, LIBS) | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5267 else with_database_berkdb=no |
2651 | 5268 fi |
5269 fi | |
5270 | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5271 if test "$with_database_gdbm $with_database_dbm $with_database_berkdb" \ |
2651 | 5272 != "no no no"; then |
5273 AC_DEFINE(HAVE_DATABASE) | |
5274 fi | |
5275 | |
5276 dnl Socks support | |
5277 if test "$with_socks" = "yes"; then | |
5278 AC_CHECK_LIB(socks, SOCKSinit) | |
5279 test -n "$ac_cv_lib_socks_SOCKSinit" && AC_DEFINE(HAVE_SOCKS) | |
5280 fi | |
5281 | |
5282 dnl Usage tracking (undocumented and likely unused option) | |
5283 if test "$usage_tracking" = "yes"; then | |
5284 AC_DEFINE(USAGE_TRACKING) | |
5285 XE_PREPEND(-Bstatic -lut -Bdynamic, LIBS) | |
5286 fi | |
5287 | |
5288 dnl Enhanced number support | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5289 if test "$with_bignum" = "gmp"; then |
2651 | 5290 AC_CHECK_HEADER(gmp.h, [ |
5291 AC_CHECK_LIB(gmp, __gmpz_init, have_mpz_init=yes)]) | |
5292 if test "$have_mpz_init" = "yes"; then | |
5293 AC_DEFINE(WITH_NUMBER_TYPES) | |
5294 AC_DEFINE(WITH_GMP) | |
5295 XE_PREPEND(-lgmp, LIBS) | |
5296 else | |
5297 XE_DIE("Required GMP numeric support cannot be provided.") | |
5298 fi | |
5739
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5299 elif test "$with_bignum" = "mpir"; then |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5300 AC_CHECK_HEADER(mpir.h, [ |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5301 AC_CHECK_LIB(mpir, __gmpz_init, have_mpz_init=yes)]) |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5302 if test "$have_mpz_init" = "yes"; then |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5303 AC_DEFINE(WITH_NUMBER_TYPES) |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5304 AC_DEFINE(WITH_MPIR) |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5305 XE_PREPEND(-lmpir, LIBS) |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5306 else |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5307 XE_DIE("Required MPIR numeric support cannot be provided.") |
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5308 fi |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5309 elif test "$with_bignum" = "mp"; then |
2651 | 5310 for library in "" "-lcrypto"; do |
5311 AC_CHECK_HEADER(mp.h, [ | |
5312 AC_CHECK_LIB(mp, mp_mfree, have_mp_mfree=yes; break, [ | |
5313 AC_CHECK_LIB(mp, mfree, have_mfree=yes; break, , $library)], | |
5314 $library)]) | |
5315 done | |
5316 if test "$have_mp_mfree" = "yes"; then | |
5317 AC_DEFINE(MP_PREFIX) | |
5318 XE_APPEND(-lmp, LIBS) | |
5319 if test "$library" != ""; then | |
5320 XE_APPEND($library, LIBS) | |
5321 fi | |
5322 AC_CHECK_FUNC(mp_move, [AC_DEFINE(HAVE_MP_MOVE)]) | |
5323 elif test "$have_mfree" = "yes"; then | |
5324 XE_APPEND(-lmp, LIBS) | |
5325 if test "$library" != ""; then | |
5326 XE_APPEND($library, LIBS) | |
5327 fi | |
5328 AC_CHECK_FUNC(move, [AC_DEFINE(HAVE_MP_MOVE)]) | |
5329 else | |
5330 XE_DIE("Required MP numeric support cannot be provided.") | |
5331 fi | |
5736
3192994c49ca
Convert C (un)signed long long values to bignums properly.
Jerry James <james@xemacs.org>
parents:
5727
diff
changeset
|
5332 AC_CHECK_FUNC(mp_set_memory_functions, |
3192994c49ca
Convert C (un)signed long long values to bignums properly.
Jerry James <james@xemacs.org>
parents:
5727
diff
changeset
|
5333 [AC_DEFINE(HAVE_MP_SET_MEMORY_FUNCTIONS)], |
3192994c49ca
Convert C (un)signed long long values to bignums properly.
Jerry James <james@xemacs.org>
parents:
5727
diff
changeset
|
5334 [AC_CHECK_FUNC(__gmp_set_memory_functions, |
3192994c49ca
Convert C (un)signed long long values to bignums properly.
Jerry James <james@xemacs.org>
parents:
5727
diff
changeset
|
5335 [AC_DEFINE(HAVE_MP_SET_MEMORY_FUNCTIONS)])]) |
2651 | 5336 AC_DEFINE(WITH_NUMBER_TYPES) |
5337 AC_DEFINE(WITH_MP) | |
5338 fi | |
5339 | |
5340 dnl Unfortunately, just because we can link doesn't mean we can run. | |
5341 dnl One of the above link tests may have succeeded but caused resulting | |
5342 dnl executables to fail to run. Also any tests using AC_RUN_IFELSE will | |
5343 dnl have reported incorrect results. | |
4537
7ca6d57ce12d
Clarify syntax in configure.ac following Vladimir Ivanovic's change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4536
diff
changeset
|
5344 AC_RUN_IFELSE([AC_LANG_SOURCE([int main(int c,char **v){return 0;}])],[:],[ |
2651 | 5345 echo "" |
5346 echo "*** PANIC *** The C compiler can no longer build working executables." | |
5347 echo "*** PANIC *** Please examine the tail of config.log for runtime errors." | |
5348 echo "*** PANIC *** The most likely reason for this problem is that configure" | |
5349 echo "*** PANIC *** links with shared libraries, but those libraries cannot be" | |
5350 echo "*** PANIC *** found at run time." | |
5351 echo "*** PANIC ***" | |
5352 echo "*** PANIC *** On a Linux system, edit /etc/ld.so.conf and re-run ldconfig." | |
5353 echo "*** PANIC *** On other systems, try telling configure where to find the" | |
5354 echo "*** PANIC *** shared libraries using the --with-site-runtime-libraries option" | |
5355 echo "*** PANIC ***" | |
5356 echo "*** PANIC *** Another way to shoot yourself in the foot is to specify" | |
5357 echo "*** PANIC *** --with-FEATURE when FEATURE is not actually installed" | |
5358 echo "*** PANIC *** on your system. Don't do that." | |
5359 exit 1]) | |
5360 | |
5361 dnl Process support | |
5362 if test "$win32_processes" != "yes"; then | |
5363 AC_DEFINE(HAVE_UNIX_PROCESSES) | |
5364 fi | |
5365 | |
5366 dnl -------------------------------- | |
5367 dnl Compute SUBST-itutable variables | |
5368 dnl -------------------------------- | |
5369 | |
5370 dnl We ignore (C|LD)_SWITCH_X_(MACHINE|SYSTEM) | |
5371 dnl Use XE_SPACE instead of plain assignment statements to remove extraneous blanks | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5372 if test "$with_modules" = "yes"; then |
2651 | 5373 ld_libs_module= |
5374 else | |
2973 | 5375 XE_SPACE(ld_libs_module, $ldap_libs $postgresql_libs $canna_libs) |
2651 | 5376 fi |
5377 | |
5378 XE_SPACE(CFLAGS, $CFLAGS) | |
5379 XE_SPACE(extra_objs, $extra_objs) | |
5380 XE_SPACE(c_switch_general, -DHAVE_CONFIG_H $c_switch_site $c_switch_machine $c_switch_system) | |
5381 XE_SPACE(c_switch_window_system, $c_switch_x_site $c_switch_gtk $X_CFLAGS) | |
5382 XE_SPACE(c_switch_all, $c_switch_general $c_switch_window_system) | |
5383 XE_SPACE(ld_switch_general, $ld_switch_site $ld_switch_machine $ld_switch_system $ld_switch_run) | |
5384 XE_SPACE(ld_switch_window_system, $ld_switch_x_site) | |
5385 XE_SPACE(ld_switch_all, $ld_switch_general $ld_switch_window_system) | |
5386 XE_SPACE(ld_libs_general, $LIBS $libs_machine $libs_system $libs_standard) | |
5387 XE_SPACE(ld_libs_window_system, $X_EXTRA_LIBS $libs_x $libs_gtk $X_PRE_LIBS) | |
5388 XE_SPACE(ld_libs_all, $ld_libs_window_system $ld_libs_general $ld_libs_module) | |
5389 | |
5390 dnl For no-module builds, make the src dir last | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5391 if test "$with_modules" = "no"; then |
2651 | 5392 XE_APPEND(src, MAKE_SUBDIR) |
5393 fi | |
5394 | |
5395 dnl Compute lists of Makefiles and subdirs | |
5396 AC_SUBST(SRC_SUBDIR_DEPS) | |
4939
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4932
diff
changeset
|
5397 internal_makefile_list="Makefile.in src/.gdbinit.in" |
2651 | 5398 SUBDIR_MAKEFILES='' |
5399 test -d lock || mkdir lock | |
5400 for dir in $MAKE_SUBDIR; do | |
5401 case "$dir" in */* ) dnl Implement mkdir -p | |
5402 ( for d in `echo $dir | sed 's:/: :g'` ; do | |
5403 test -d "$d" || mkdir "$d"; cd "$d" | |
5404 done ) ;; | |
5405 * ) test -d "$dir" || mkdir "$dir" ;; | |
5406 esac | |
5407 XE_SPACE(SUBDIR_MAKEFILES, $SUBDIR_MAKEFILES $dir/Makefile $dir/GNUmakefile) | |
5408 XE_SPACE(internal_makefile_list, $internal_makefile_list $dir/Makefile.in) | |
5409 done | |
5410 AC_SUBST(INSTALL_ARCH_DEP_SUBDIR) | |
5411 AC_SUBST(MAKE_SUBDIR) | |
5412 AC_SUBST(SUBDIR_MAKEFILES) | |
5413 | |
5414 dnl Make s&m symlinks in the src directory, for config.h. | |
5415 for dir in src/s src/m; do | |
5416 if test ! -d "$dir" ; then | |
5417 echo Making symbolic link to "$srcdir/$dir" | |
5418 ${LN_S} "$srcdir/$dir" "$dir" | |
5419 fi | |
5420 done | |
5421 | |
5422 dnl Also make modules/common link if needed for the module Makefiles. | |
5725
1af0602ff9a2
Fix the module build by completing removal of need_modules_common, forgotten
Jerry James <james@xemacs.org>
parents:
5724
diff
changeset
|
5423 if test "$with_modules" = "yes"; then |
2651 | 5424 for dir in modules/common; do |
5425 if test ! -d "$dir" ; then | |
5426 echo Making symbolic link to "$srcdir/$dir" | |
5427 ${LN_S} "$srcdir/$dir" "$dir" | |
5428 fi | |
5429 done | |
5430 fi | |
5431 | |
5432 if test "$verbose" = "yes"; then | |
5433 echo "" | |
5434 PRINT_VAR(extra_objs | |
5435 c_switch_general c_switch_window_system c_switch_all | |
5436 ld_switch_general ld_switch_window_system ld_switch_all | |
5437 ld_libs_general ld_libs_window_system ld_libs_all) | |
5438 echo "" | |
5439 fi | |
5440 | |
5441 dnl ---------------------------------------------- | |
5442 dnl Create some auxiliary files for developers. | |
5443 dnl ---------------------------------------------- | |
5444 | |
3418 | 5445 dnl Unlike TAGS, debugger init files depend on config.h. |
5446 dnl Regenerate them locally on every configure. | |
4939
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4932
diff
changeset
|
5447 dnl .gdbinit is now handled like xemacs.def or other src files, and |
349f01075eb7
build fixes for gdbinit and config-dependent elc files
Ben Wing <ben@xemacs.org>
parents:
4932
diff
changeset
|
5448 dnl its source is in src/.gdbinit.in.in. |
2651 | 5449 |
5450 dnl Create a useful TAGS file | |
5451 if test -f "$srcdir/TAGS" -a ! -f "TAGS"; then | |
5452 test "$verbose" = "yes" && echo "creating TAGS" | |
5453 echo " | |
5454 $srcdir/TAGS,include" > "TAGS" | |
5455 fi | |
5456 | |
5457 dnl Create top level .sbinit for Sun compilers | |
5458 if test "$__SUNPRO_C" = "yes"; then | |
5459 test "$verbose" = "yes" && echo "creating .sbinit" | |
5460 ( echo "# For use with Sun WorkShop's Source browser." | |
5461 echo "# See sbquery(1) and sbinit(4) for more information" | |
5462 for dir in $MAKE_SUBDIR; do echo "import $dir"; done | |
5463 ) > .sbinit | |
5464 fi | |
5465 | |
5466 dnl There are no more compile tests; remove the core they created. | |
5467 rm -f core | |
5468 | |
5469 dnl ---------------------------------------------- | |
5470 dnl Substitute into Makefile, config.h and paths.h | |
5471 dnl ---------------------------------------------- | |
5472 | |
5473 dnl what sort of things to edit into Makefile, config.h and paths.h | |
5474 dnl configuration here uncanonicalized to avoid exceeding size limits. | |
5475 | |
5476 AC_SUBST(PROGNAME) | |
5477 AC_SUBST(version) | |
3972 | 5478 AC_SUBST(verbose_version) |
2651 | 5479 AC_SUBST(inststaticdir) |
5480 AC_SUBST(instvardir) | |
5481 AC_SUBST(srcdir) | |
5482 AC_SUBST(bindir) | |
4118 | 5483 AC_SUBST(datarootdir) |
2651 | 5484 AC_SUBST(datadir) |
5485 AC_SUBST(statedir) | |
5486 AC_SUBST(libdir) | |
5487 AC_SUBST(mandir) | |
5488 AC_SUBST(extra_includes) | |
5489 | |
5490 AC_SUBST(prefix) | |
5491 AC_SUBST(PREFIX_USER_DEFINED) | |
4660
32be564c53dd
More accurate tests for explicitly-set paths.
Mike Sperber <sperber@deinprogramm.de>
parents:
4656
diff
changeset
|
5492 XE_EXPAND_VARIABLE(prefix,PREFIX) |
4661
24224362882c
Expand @PREFIX@ in paths.h.
Mike Sperber <sperber@deinprogramm.de>
parents:
4660
diff
changeset
|
5493 AC_SUBST(PREFIX) |
2651 | 5494 |
5495 AC_SUBST(exec_prefix) | |
5496 AC_SUBST(EXEC_PREFIX_USER_DEFINED) | |
4660
32be564c53dd
More accurate tests for explicitly-set paths.
Mike Sperber <sperber@deinprogramm.de>
parents:
4656
diff
changeset
|
5497 XE_EXPAND_VARIABLE(exec_prefix,EXEC_PREFIX) |
2651 | 5498 AC_SUBST(EXEC_PREFIX) |
5499 | |
5500 AC_SUBST(infodir) | |
5501 AC_SUBST(INFODIR_USER_DEFINED) | |
3729 | 5502 XE_EXPAND_VARIABLE(infodir,INFODIR) |
2651 | 5503 AC_SUBST(INFODIR) |
5504 | |
5505 AC_SUBST(infopath,$with_infopath) | |
5506 AC_SUBST(INFOPATH_USER_DEFINED) | |
3729 | 5507 XE_EXPAND_VARIABLE(with_info_path,INFOPATH) |
4455
49f8ed034500
Fix path-configuration glitches:
Mike Sperber <sperber@deinprogramm.de>
parents:
4450
diff
changeset
|
5508 AC_SUBST(INFOPATH) |
2651 | 5509 |
3179 | 5510 test -n "$with_user_packages" && with_early_packages=$with_user_packages |
5511 AC_SUBST(early_packages,$with_early_packages) | |
5512 AC_SUBST(EARLY_PACKAGE_DIRECTORIES_USER_DEFINED) | |
3729 | 5513 XE_EXPAND_VARIABLE(with_early_packages,EARLY_PACKAGE_DIRECTORIES) |
3179 | 5514 AC_SUBST(EARLY_PACKAGE_DIRECTORIES) |
5515 | |
5516 test -n "$with_system_packages" && with_late_packages=$with_system_packages | |
5517 AC_SUBST(late_packages,$with_late_packages) | |
5518 AC_SUBST(LATE_PACKAGE_DIRECTORIES_USER_DEFINED) | |
3729 | 5519 XE_EXPAND_VARIABLE(with_late_packages,LATE_PACKAGE_DIRECTORIES) |
3179 | 5520 AC_SUBST(LATE_PACKAGE_DIRECTORIES) |
5521 | |
5522 test -n "$with_legacy_packages" && with_last_packages=$with_legacy_packages | |
5523 AC_SUBST(last_packages,$with_last_packages) | |
5524 AC_SUBST(LAST_PACKAGE_DIRECTORIES_USER_DEFINED) | |
3729 | 5525 XE_EXPAND_VARIABLE(with_last_packages,LAST_PACKAGE_DIRECTORIES) |
3179 | 5526 AC_SUBST(LAST_PACKAGE_DIRECTORIES) |
2651 | 5527 |
5528 AC_SUBST(package_path,$with_package_path) | |
5529 AC_SUBST(PACKAGE_PATH_USER_DEFINED) | |
3729 | 5530 XE_EXPAND_VARIABLE(with_package_path,PACKAGE_PATH) |
2651 | 5531 AC_SUBST(PACKAGE_PATH) |
5532 | |
5533 AC_SUBST(lispdir, $with_lispdir) | |
5534 AC_SUBST(LISPDIR_USER_DEFINED) | |
3729 | 5535 XE_EXPAND_VARIABLE(with_lispdir,LISPDIR) |
2651 | 5536 AC_SUBST(LISPDIR) |
5537 | |
5538 AC_SUBST(moduledir,$with_moduledir) | |
5539 AC_SUBST(MODULEDIR_USER_DEFINED) | |
3729 | 5540 XE_EXPAND_VARIABLE(with_moduledir,MODULEDIR) |
2651 | 5541 AC_SUBST(MODULEDIR) |
5542 | |
5543 AC_SUBST(sitelispdir,$with_sitelispdir) | |
5544 AC_SUBST(SITELISPDIR_USER_DEFINED) | |
3729 | 5545 XE_EXPAND_VARIABLE(sitelispdir,SITELISPDIR) |
2651 | 5546 AC_SUBST(SITELISPDIR) |
5547 | |
5548 AC_SUBST(sitemoduledir) | |
5549 AC_SUBST(SITEMODULEDIR_USER_DEFINED) | |
3729 | 5550 XE_EXPAND_VARIABLE(sitemoduledir,SITEMODULEDIR) |
2651 | 5551 AC_SUBST(SITEMODULEDIR) |
5552 | |
5553 AC_SUBST(etcdir,$with_etcdir) | |
5554 AC_SUBST(ETCDIR_USER_DEFINED) | |
3729 | 5555 XE_EXPAND_VARIABLE(with_etcdir,ETCDIR) |
2651 | 5556 AC_SUBST(ETCDIR) |
5557 | |
5558 AC_SUBST(archlibdir,$with_archlibdir) | |
5559 AC_SUBST(ARCHLIBDIR_USER_DEFINED) | |
5560 ARCHLIBDIR=$with_archlibdir | |
3729 | 5561 XE_EXPAND_VARIABLE(with_archlibdir,ARCHLIBDIR) |
2651 | 5562 AC_SUBST(ARCHLIBDIR) |
5563 | |
5564 AC_SUBST(docdir,$with_docdir) | |
5565 AC_SUBST(DOCDIR_USER_DEFINED) | |
3729 | 5566 XE_EXPAND_VARIABLE(with_docdir,DOCDIR) |
2651 | 5567 AC_SUBST(DOCDIR) |
5568 | |
5569 AC_SUBST(docdir) | |
5570 AC_SUBST(bitmapdir) | |
5571 AC_SUBST(extra_objs) | |
5572 | |
5573 dnl The following flags combine all the information from: | |
5574 dnl - command line options (user always gets priority) | |
5575 dnl - user environment variables | |
5576 dnl - determined by configure | |
5577 dnl - the s&m header files (required for ellcc) | |
5578 AC_SUBST(machfile) | |
5579 AC_SUBST(opsysfile) | |
5580 AC_SUBST(c_switch_general) | |
5581 AC_SUBST(c_switch_window_system) | |
5582 AC_SUBST(c_switch_all) | |
5583 AC_SUBST(ld_switch_general) | |
5584 AC_SUBST(ld_switch_window_system) | |
5585 AC_SUBST(ld_switch_all) | |
5586 AC_SUBST(ld_libs_general) | |
5587 AC_SUBST(ld_libs_window_system) | |
5588 AC_SUBST(ld_libs_all) | |
5589 AC_SUBST(CFLAGS) | |
5590 AC_SUBST(CPPFLAGS) | |
5591 AC_SUBST(LDFLAGS) | |
5744
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
5592 AC_SUBST(MAKEINFO) |
9c17f7be0b92
Require makeinfo 4.12 or later to build the info files. See xemacs-beta
Jerry James <james@xemacs.org>
parents:
5739
diff
changeset
|
5593 RECURSIVE_MAKE_ARGS="\$(MFLAGS) CC='\$(CC)' CFLAGS='\$(CFLAGS)' LDFLAGS='\$(LDFLAGS)' CPPFLAGS='\$(CPPFLAGS)' MAKEINFO='\$(MAKEINFO)'" |
2651 | 5594 AC_SUBST(RECURSIVE_MAKE_ARGS) |
5595 | |
5596 AC_SUBST(native_sound_lib,$with_native_sound_lib) | |
5597 AC_SUBST(sound_cflags) | |
5598 AC_SUBST(RANLIB) | |
5599 | |
5600 AC_SUBST(XEMACS_CC) | |
5601 AC_SUBST(XE_CFLAGS) | |
5602 | |
5603 dnl The default is yes | |
5604 if test "$with_prefix" = "yes"; then | |
5605 AC_DEFINE(PREFIX_USER_DEFINED) | |
5606 fi | |
5607 | |
5608 dnl The default is no | |
5609 if test "$with_site_lisp" = "no"; then | |
5610 AC_DEFINE(INHIBIT_SITE_LISP) | |
5611 fi | |
5612 dnl The default is yes | |
5613 if test "$with_site_modules" = "no"; then | |
5614 AC_DEFINE(INHIBIT_SITE_MODULES) | |
5615 fi | |
5616 | |
5617 XE_SPACE(ac_configure_args, $ac_configure_args) | |
3765 | 5618 dnl Put back the leading space to work around problems with |
5619 dnl 'config.status --recheck' under autoconf 2.60 and 2.61. | |
5620 ac_configure_args=" $ac_configure_args" | |
2651 | 5621 AC_DEFINE_UNQUOTED(EMACS_CONFIGURATION, "$ac_cv_build") |
5622 AC_DEFINE_UNQUOTED(EMACS_CONFIG_OPTIONS, "$ac_configure_args") | |
5623 | |
5624 dnl Following are deprecated | |
5625 | |
5626 null_string="" | |
5627 AC_DEFINE_UNQUOTED(LD_SWITCH_X_SITE, $null_string) | |
5628 AC_DEFINE_UNQUOTED(LD_SWITCH_X_SITE_AUX, $null_string) | |
5629 AC_DEFINE_UNQUOTED(C_SWITCH_X_SITE, $null_string) | |
5630 AC_DEFINE_UNQUOTED(LD_SWITCH_SITE, $null_string) | |
5631 AC_DEFINE_UNQUOTED(C_SWITCH_SITE, $null_string) | |
5632 | |
5633 dnl Note: as a general rule, *only* define things here that are not | |
5634 dnl autodetected. For things that are autodetected, define them | |
5635 dnl at the point where the autodetection occurs or would occur, | |
5636 dnl so that the user gets immediate feedback on the results of the | |
5637 dnl autodetection. | |
5638 | |
4735
80d74fed5399
Remove "old" GNU malloc in src/malloc.c, and all references to it. Drop the
Jerry James <james@xemacs.org>
parents:
4708
diff
changeset
|
5639 if test "$with_system_malloc" = "yes"; then AC_DEFINE(USE_SYSTEM_MALLOC) |
2651 | 5640 elif test "$with_debug_malloc" = "yes"; then AC_DEFINE(USE_DEBUG_MALLOC) |
5641 AC_DEFINE(USE_SYSTEM_MALLOC) | |
5642 fi | |
4932 | 5643 test "$GCC" = "yes" && AC_DEFINE(USE_GCC) |
5644 test "$XEMACS_CC_GPP" = "yes" && AC_DEFINE(USE_GPLUSPLUS) | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5645 test "$with_external_widget" = "yes" && AC_DEFINE(EXTERNAL_WIDGET) |
4932 | 5646 test "$with_kkcc" = "yes" && AC_DEFINE(USE_KKCC) |
5647 test "$with_newgc" = "yes" && AC_DEFINE(NEW_GC) | |
5648 test "$have_vdb_posix" = "yes" && AC_DEFINE(VDB_POSIX) | |
5649 test "$have_vdb_fake" = "yes" && AC_DEFINE(VDB_FAKE) | |
5650 test "$with_quick_build" = "yes" && AC_DEFINE(QUICK_BUILD) | |
5651 test "$with_purify" = "yes" && AC_DEFINE(PURIFY) | |
5652 test "$with_quantify" = "yes" && AC_DEFINE(QUANTIFY) | |
5653 test "$with_valgrind" = "yes" && AC_DEFINE(USE_VALGRIND) | |
5654 test "$with_pop" = "yes" && AC_DEFINE(MAIL_USE_POP) | |
5655 test "$with_kerberos" = "yes" && AC_DEFINE(KERBEROS) | |
5656 test "$with_hesiod" = "yes" && AC_DEFINE(HESIOD) | |
5657 test "$with_union_type" = "yes" && AC_DEFINE(USE_UNION_TYPE) | |
5658 test "$with_pdump" = "yes" && AC_DEFINE(PDUMP) | |
5659 test "$with_dump_in_exec" = "yes" && AC_DEFINE(DUMP_IN_EXEC) | |
5660 test "$with_ipv6_cname" = "yes" && AC_DEFINE(IPV6_CANONICALIZE) | |
2651 | 5661 |
5662 | |
5663 | |
5664 dnl ------------------------------------------------------------------------- | |
5665 dnl ------------------------------- | |
5666 dnl Report on what we decided to do | |
5667 dnl ------------------------------- | |
5668 | |
5669 dnl #### We should tag this as the _build_ environment. | |
5670 dnl Before doing that, though, must check if tools care about line 1. | |
5671 | |
5765
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5672 if test ! -z ${emacs_beta_version} ; then |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5673 if test -z "${emacs_is_beta}" ; then |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5674 xemacs_betaname=".${emacs_beta_version}" |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5675 else |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5676 xemacs_betaname="-b${emacs_beta_version}" |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5677 fi |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5678 else |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5679 xemacs_betaname="" |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5680 fi |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5681 |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5682 echo "" |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5683 : > Installation |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5684 |
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5685 dnl Start stdout redirection to '| tee -a Installation' |
2651 | 5686 ( |
5687 dnl /etc/osversion is on SONY NEWS-OS | |
5688 if test -f /etc/osversion; then dnl SONY NEWS-OS | |
5689 echo "osversion: `cat /etc/osversion`" | |
5690 else | |
5691 echo "uname -a: `uname -a`" | |
5692 fi | |
5693 echo "" | |
5694 echo "$progname $ac_configure_args" | |
5765
e88d026f3917
Include uname and configure arguments in stdout.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5761
diff
changeset
|
5695 |
2651 | 5696 echo " |
5697 | |
2938 | 5698 XEmacs ${emacs_major_version}.${emacs_minor_version}${xemacs_betaname} \"$xemacs_codename\" $xemacs_extra_name configured for \`$ac_cv_build'." |
2651 | 5699 |
5700 echo " | |
5701 Compilation Environment and Installation Defaults:" | |
5702 echo " Source code location: $srcdir" | |
5703 echo " Installation prefix: $prefix" | |
5704 if test -n "$with_site_includes"; then | |
5705 echo " Additional header files: $with_site_includes" | |
5706 fi | |
5707 if test -n "$with_site_libraries"; then | |
5708 echo " Additional libraries: $with_site_libraries" | |
5709 fi | |
5710 if test -n "$with_site_prefixes"; then | |
5711 echo " Additional prefixes: $with_site_prefixes" | |
5712 fi | |
5713 if test -n "$runpath"; then | |
5714 echo " Runtime library search path: $runpath" | |
5715 fi | |
5716 | |
5717 if test -n "$opsysfile" | |
5718 then echo " Operating system description file: \`$opsysfile'" | |
5719 else echo " Not using any operating system description file" | |
5720 fi | |
5721 if test -n "$machfile" | |
5722 then echo " Machine description file: \`$machfile'" | |
5723 else echo " Not using any machine description file" | |
5724 fi | |
5725 | |
5726 echo " Compiler version: $compiler_version" | |
5727 if test -n "$gcc_compiler_specs"; then | |
5728 echo " - GCC specs file: $gcc_compiler_specs" | |
5729 fi | |
5730 echo " - Compiler command: $XEMACS_CC $XE_CFLAGS" | |
5731 if test "$CC" != "$XEMACS_CC"; then | |
5732 echo " Compiler version for lib-src: (detection code unimplemented)" | |
5733 echo " - Compiler command for lib-src: $CC $CFLAGS" | |
5734 if test "$xemacs_cc_cc_mismatch" = "yes"; then | |
5735 echo " WARNING: CC and XEMACS_CC mismatched; check CFLAGS carefully." | |
5736 fi | |
5737 fi | |
5738 echo " libc version: $libc_version" | |
5739 echo " Relocating allocator for buffers: $with_rel_alloc" | |
5740 echo " GNU version of malloc: ${GNU_MALLOC}${GNU_MALLOC_reason}" | |
5741 case "$ld_switch_site" in | |
5742 *nocombreloc*) echo " Linking with \`-z nocombreloc'. | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5743 - Consider configuring with --with-pdump." ;; |
2651 | 5744 esac |
5745 | |
5676
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5746 define(COLON_TO_SPACE_WARN, |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5747 [case "$[$1]" in *:* [)] dnl |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5748 case "$opsys" in *cygwin* [)] |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5749 echo " WARNING: Paths containing spaces will be misinterpreted." ;; |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5750 esac |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5751 [$1]="`echo '' $[$1] | sed -e 's/^ //' -e 's/:/ /g'`";; esac])dnl |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5752 |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5753 echo " |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5754 Package Search (a 'root' contains '{xemacs,mule,site}-packages'):" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5755 |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5756 if test -n "$with_early_packages"; then |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5757 COLON_TO_SPACE_WARN(with_early_packages) |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5758 echo " User package roots: $with_early_packages" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5759 else |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5760 echo " User package roots: ~/.xemacs" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5761 fi |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5762 |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5763 dnl Unlike the others, with_late_packages gets a non-null default. |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5764 XE_EXPAND_VARIABLE(with_late_packages,with_late_packages_expanded) |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5765 COLON_TO_SPACE_WARN(with_late_packages_expanded) |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5766 echo " System package roots: $with_late_packages_expanded" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5767 for path in $with_late_packages_expanded; do |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5768 if test ! -d $path; then |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5769 echo " WARNING: $path was specified, but doesn't exist." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5770 echo " WARNING: XEmacs functionality will be noticably limited until" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5771 echo " WARNING: some packages are installed." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5772 elif test ! -d "$path/xemacs-packages" \ |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5773 -a ! -d "$path/mule-packages" \ |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5774 -a ! -d "$path/site-packages"; then |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5775 echo " WARNING: No packages found in $path." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5776 echo " WARNING: XEmacs functionality will be noticably limited until" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5777 echo " WARNING: some packages are installed." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5778 fi |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5779 done |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5780 dnl #### Shouldn't need this. |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5781 if test -z "$with_late_packages"; then |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5782 echo " XEmacs BUG: with_late_packages is unset. Please report this!" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5783 fi |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5784 |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5785 if test -n "$with_last_packages"; then |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5786 COLON_TO_SPACE_WARN(with_last_packages) |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5787 echo " Legacy package roots: $with_last_packages" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5788 for path in $with_last_packages; do |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5789 if test ! -d $path; then |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5790 echo " WARNING: $path was specified, but doesn't exist." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5791 echo " WARNING: If you don't need this setting, it is recommended" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5792 echo " WARNING: that you not use it." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5793 elif test ! -d "$path/xemacs-packages" \ |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5794 -a ! -d "$path/mule-packages" \ |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5795 -a ! -d "$path/site-packages"; then |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5796 echo " WARNING: No packages found in $path." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5797 echo " WARNING: If you don't need this setting, it is recommended" |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5798 echo " WARNING: that you not use it." |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5799 fi |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5800 done |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5801 fi |
dede3f658f8e
Sanity check package roots in configure.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
5669
diff
changeset
|
5802 |
2651 | 5803 echo " |
5804 Window System:" | |
5805 if test "$with_msw" = "yes"; then | |
5806 echo " Compiling in support for the Microsoft window system." | |
5807 fi | |
5808 if test "$with_x11" = "yes"; then | |
5809 echo " Compiling in support for the X window system:" | |
5810 echo " - X Windows headers location: $x_includes" | |
5811 echo " - X Windows libraries location: $x_libraries" | |
5812 if test "$with_xauth" != yes; then | |
5813 echo " - Xau (X authority) not available." | |
5814 fi | |
5815 if test "$with_wmcommand" != no; then | |
5816 echo " - Handling WM_COMMAND properly." | |
5817 fi | |
3354 | 5818 if test "$with_fontconfig" = "yes"; then |
5819 echo " - Using fontconfig to manage fonts." | |
5820 fi | |
3166 | 5821 if test "$with_xft_emacs" = "yes"; then |
3094 | 5822 echo " - Compiling in support for Xft antialiased fonts (EXPERIMENTAL)." |
5823 fi | |
2651 | 5824 fi |
3019 | 5825 if test "$need_motif" = "yes" ; then |
5826 echo " Compiling in support for Motif." | |
5827 if test "$have_lesstif" = "yes"; then | |
5828 echo " - Using LessTif implementation." | |
5829 fi | |
5830 echo " *WARNING* Many versions of Motif are buggy, requiring workarounds." | |
5831 echo " You are likely to experience slow redisplay." | |
5832 echo " You may need to install vendor patches to Motif." | |
5833 echo " See PROBLEMS for more information." | |
5834 fi | |
2651 | 5835 if test "$need_athena" = "yes"; then |
5836 echo " Compiling in support for the Athena widget set:" | |
5837 echo " - Athena headers location: $athena_h_path" | |
5838 echo " - Athena library to link: $athena_lib" | |
5839 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5840 case "$with_menubars" in |
2651 | 5841 gtk ) echo " Using GTK menubars." ;; |
5842 lucid ) echo " Using Lucid menubars." ;; | |
5843 motif ) echo " Using Motif menubars." | |
5844 echo " *WARNING* The Motif menubar implementation is currently buggy." | |
5845 echo " We recommend using the Lucid menubar instead." | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5846 echo " Re-run configure with --with-menubars='lucid'." ;; |
2651 | 5847 msw ) echo " Using MS-Windows menubars." ;; |
5848 esac | |
3094 | 5849 if test "$with_xft_menubars" = "yes"; then |
5850 echo " - Using Xft to render antialiased fonts in menubars." | |
4961
b90f8cf474e0
Change Xft warning in configure.ac to make filtering it more safe
Ben Wing <ben@xemacs.org>
parents:
4944
diff
changeset
|
5851 echo " WARNING: This Xft feature will be replaced with a face." |
3094 | 5852 fi |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5853 case "$with_scrollbars" in |
2651 | 5854 gtk ) echo " Using GTK scrollbars." ;; |
5855 lucid ) echo " Using Lucid scrollbars." ;; | |
5856 motif ) echo " Using Motif scrollbars." ;; | |
5857 athena ) echo " Using Athena scrollbars." ;; | |
5858 msw ) echo " Using MS-Windows scrollbars." ;; | |
5859 esac | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5860 case "$with_dialogs" in |
2651 | 5861 gtk ) echo " Using GTK dialog boxes." ;; |
5862 motif ) echo " Using Motif dialog boxes." | |
5863 if test "$unexec" = "unexaix.o"; then if test "`uname -v`" = 4 -a "`uname -r`" -ge 3; then | |
5864 echo " *WARNING* The Motif dialog boxes cause problems on AIX 4.3 and higher." | |
5865 echo " We recommend using the Athena dialog boxes instead." | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5866 echo " Install libXaw and re-run configure with --with-dialogs='athena'." |
2651 | 5867 echo " Read the PROBLEMS file for more information." |
5868 fi; fi ;; | |
5869 athena ) echo " Using Athena dialog boxes." ;; | |
5870 msw ) echo " Using MS-Windows dialog boxes." ;; | |
5871 esac | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5872 case "$with_widgets" in |
2651 | 5873 gtk ) echo " Using GTK native widgets." ;; |
5874 motif ) echo " Using Motif native widgets." ;; | |
5875 athena ) echo " Using Athena native widgets." ;; | |
5876 msw ) echo " Using MS-Windows native widgets." ;; | |
5877 esac | |
3094 | 5878 if test "$with_xft_tabs" = "yes"; then |
5879 echo " - Using Xft to render antialiased fonts in tab controls." | |
4961
b90f8cf474e0
Change Xft warning in configure.ac to make filtering it more safe
Ben Wing <ben@xemacs.org>
parents:
4944
diff
changeset
|
5880 echo " WARNING: This Xft feature will be replaced with a face." |
3094 | 5881 fi |
4497
f863b2ee146f
Rename xft_gauge to xft_gauges.
Mats Lidell <matsl@xemacs.org>
parents:
4496
diff
changeset
|
5882 if test "$with_xft_gauges" = "yes"; then |
3094 | 5883 echo " - Using Xft to render antialiased fonts in progress bars." |
4961
b90f8cf474e0
Change Xft warning in configure.ac to make filtering it more safe
Ben Wing <ben@xemacs.org>
parents:
4944
diff
changeset
|
5884 echo " WARNING: This Xft feature will be replaced with a face." |
b90f8cf474e0
Change Xft warning in configure.ac to make filtering it more safe
Ben Wing <ben@xemacs.org>
parents:
4944
diff
changeset
|
5885 echo " WARNING: This Xft feature not yet implemented; setting ignored." |
3094 | 5886 fi |
2651 | 5887 if test "$with_dragndrop" = yes; then |
5888 echo " Compiling in support for Drag'n'Drop (EXPERIMENTAL)." | |
5889 echo " - Drag'n'Drop prototype: $dragndrop_proto." | |
5890 fi | |
5891 | |
5892 echo " | |
5893 TTY:" | |
5894 test "$with_ncurses" = yes && echo " Compiling in support for ncurses." | |
5895 test "$with_gpm" = yes && echo " Compiling in support for GPM (General Purpose Mouse)." | |
5896 | |
5897 echo " | |
5898 Images:" | |
4708
1cecc3e9f0a0
Use giflib or libungif to provide GIF support, instead of using internal
Jerry James <james@xemacs.org>
parents:
4699
diff
changeset
|
5899 test "$with_gif" = yes && echo " Compiling in support for GIF images." |
2651 | 5900 if test "$with_xpm" = yes; then |
5901 echo " Compiling in support for XPM images." | |
5902 elif test "$with_x11" = yes; then | |
5903 echo " WARNING: -----------------------------------------------------------" | |
5904 echo " WARNING: Compiling without XPM image support." | |
5905 if test "$xpm_problem" != ""; then | |
5906 echo " Reason: $xpm_problem" | |
5907 fi | |
5908 echo " WARNING: You should strongly consider installing XPM." | |
5909 echo " WARNING: Otherwise toolbars and other graphics will look suboptimal." | |
5910 echo " WARNING: (a copy may be found in ftp://ftp.xemacs.org/pub/xemacs/aux)" | |
5911 echo " WARNING: -----------------------------------------------------------" | |
5912 fi | |
5913 if test "$with_png" = yes; then | |
5914 echo " Compiling in support for PNG images." | |
5915 elif test "$window_system" != "none"; then | |
5916 echo " WARNING: -----------------------------------------------------------" | |
5917 echo " WARNING: Compiling without PNG image support." | |
5918 if test "$png_problem" != ""; then | |
5919 echo " Reason: $png_problem" | |
5920 fi | |
5921 echo " WARNING: You should strongly consider installing the PNG libraries." | |
5922 echo " WARNING: Otherwise certain images and glyphs may not display." | |
5923 echo " WARNING: (a copy may be found in ftp://ftp.xemacs.org/pub/xemacs/aux)" | |
5924 echo " WARNING: -----------------------------------------------------------" | |
5925 fi | |
5926 test "$with_jpeg" = yes && echo " Compiling in support for JPEG images." | |
5927 test "$with_tiff" = yes && echo " Compiling in support for TIFF images." | |
5928 test "$with_xface" = yes && echo " Compiling in support for X-Face message headers." | |
5929 | |
5930 echo " | |
5931 Sound:" | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5932 test "$with_sound_native" = yes && echo " Compiling in support for sound (native)." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5933 test "$with_sound_alsa" = yes && echo " Compiling in support for ALSA (Advanced Linux Sound Architecture)." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5934 test "$with_sound_nas" = yes && echo " Compiling in support for NAS (network audio system)." |
2651 | 5935 test "$old_nas" = yes && echo " - NAS library lacks error trapping; will play synchronously." |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5936 test "$with_sound_esd" = yes && echo " Compiling in support for ESD (Enlightened Sound Daemon)." |
2651 | 5937 |
5938 echo " | |
5939 Databases:" | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5940 test "$with_database_berkdb" = yes && echo " Compiling in support for Berkeley database." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5941 test "$with_database_dbm" = yes && echo " Compiling in support for DBM." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5942 test "$with_database_gdbm" = yes && echo " Compiling in support for GNU DBM." |
2651 | 5943 test "$with_ldap" = yes && echo " Compiling in support for LDAP." |
5944 if test "$with_postgresql" = yes; then | |
5945 echo " Compiling in support for PostgreSQL." | |
5946 echo " - Using PostgreSQL header file: $libpq_fe_h_file" | |
5947 test "$with_postgresqlv7" = yes && echo " - Using PostgreSQL V7 bindings." | |
5948 fi | |
5949 | |
5950 echo " | |
5951 Internationalization:" | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5952 test "$with_mule" = yes && echo " Compiling in support for Mule (multi-lingual Emacs)." |
2651 | 5953 test "$with_xim" != no && echo " Compiling in support for XIM (X11R5+ I18N input method)." |
5954 test "$with_xim" = motif && echo " - Using Motif to provide XIM support." | |
5955 test "$with_xim" = xlib && echo " - Using raw Xlib to provide XIM support." | |
5956 test "$with_xfs" = yes && echo " - Using XFontSet to provide bilingual menubar." | |
3830 | 5957 test "$have_canna" = yes && echo " Compiling in support for Canna on Mule." |
2651 | 5958 if test "$with_wnn" = yes; then |
5959 echo " Compiling in support for the WNN input method on Mule." | |
5960 test "$with_wnn6" = yes && echo " - Using WNN version 6." | |
5961 fi | |
5962 | |
5963 echo " | |
5964 Mail:" | |
5965 test "$with_pop" = yes && echo " Compiling in support for POP mail retrieval." | |
5966 test "$with_kerberos" = yes && echo " Compiling in support for Kerberos POP authentication." | |
5967 test "$with_hesiod" = yes && echo " Compiling in support for Hesiod POP server access." | |
5968 test -n "$with_mail_locking" && echo " Compiling in support for \"$with_mail_locking\" mail spool file locking method." | |
5969 | |
5970 echo " | |
5971 Other Features:" | |
5972 test "$with_ipv6_cname" = no && echo " Inhibiting IPv6 canonicalization at startup." | |
5973 test "$with_tooltalk" = yes && echo " Compiling in support for ToolTalk." | |
5974 test "$with_workshop" = yes && echo " Compiling in support for Sun WorkShop." | |
5975 test "$with_socks" = yes && echo " Compiling in support for SOCKS." | |
5976 test "$with_dnet" = yes && echo " Compiling in support for DNET." | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5977 test "$with_modules" = "yes" && echo " Compiling in support for dynamic shared object modules." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5978 test "$with_bignum" = "gmp" && echo " Compiling in support for more number types using the GNU MP library." |
5739
a2912073be85
Support bignums with MPIR. Add documentation on the bignum, ratio,
Jerry James <james@xemacs.org>
parents:
5736
diff
changeset
|
5979 test "$with_bignum" = "mpir" && echo " Compiling in support for more number types using the MPIR library." |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5980 test "$with_bignum" = "mp" && echo " Compiling in support for more number types using the BSD MP library." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5981 if test "$with_union_type" = yes ; then |
2651 | 5982 echo " Using the union type for Lisp_Objects." |
5983 echo " WARNING: ---------------------------------------------------------" | |
5984 echo " WARNING: This tends to trigger compiler bugs, especially when" | |
5985 echo " WARNING: combined with MULE and ERROR_CHECKING. Crashes have" | |
5986 echo " WARNING: been seen with various versions of GCC (up to about 2.95)," | |
5987 echo " WARNING: and recently with Visual C++ as well (mid-2003)." | |
5988 echo " WARNING: More recent versions may be safer, or not." | |
5989 echo " WARNING: ---------------------------------------------------------" | |
5990 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5991 if test "$with_kkcc" = yes ; then |
3263 | 5992 echo " Using the new GC mark algorithms (KKCC)." |
2790 | 5993 echo " WARNING: ---------------------------------------------------------" |
5994 echo " WARNING: The new algorithms are experimental. They are enabled by" | |
5995 echo " WARNING: default for this release. Use \`--disable-kkcc' to" | |
5996 echo " WARNING: turn it off." | |
5997 echo " WARNING: ---------------------------------------------------------" | |
5998 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
5999 test "$with_newgc" = yes && echo " Using the new incremental garbage collector and the new allocator." |
3092 | 6000 if test "$have_vdb_posix" = yes ; then |
6001 if test "$have_vdb_sigaction" = yes ; then | |
6002 echo " Using POSIX sigaction() to install fault handler." | |
6003 else | |
6004 echo " Using POSIX signal() to install vdb fault handler." | |
6005 fi | |
6006 fi | |
6007 if test "$have_vdb_win32" = yes ; then | |
6008 echo " Using special WIN32 vdb fault handler." | |
6009 fi | |
6010 if test "$have_vdb_mach" = yes ; then | |
6011 echo " Using mach exception mechanism as vdb fault handler." | |
6012 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
6013 if test "$have_vdb_fake" = yes && test "$with_vdb" == fake; then |
3092 | 6014 echo " Virtual dirty bit write barrier manually disabled." |
6015 fi | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
6016 test "$with_pdump" = yes && echo " Using the new portable dumper." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
6017 test "$with_dump_in_exec" = yes && echo " Dumping into executable." |
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
6018 test "$with_debug" = yes && echo " Compiling in support for extra debugging code." |
2651 | 6019 test "$usage_tracking" = yes && echo " Compiling in support for active usage tracking (Sun internal)." |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
6020 if test "$with_error_checking_extents $with_error_checking_types $with_error_checking_text $with_error_checking_gc $with_error_checking_malloc $with_error_checking_glyphs $with_error_checking_byte_code $with_error_checking_display $with_error_checking_structures" \ |
2651 | 6021 != "no no no no no no no no no"; then |
6022 echo " Compiling in support for runtime error checking." | |
6023 echo " WARNING: ---------------------------------------------------------" | |
6024 echo " WARNING: XEmacs will run noticeably more slowly as a result." | |
6025 echo " WARNING: Error checking is on by default for XEmacs beta releases." | |
6026 echo " WARNING: ---------------------------------------------------------" | |
6027 fi | |
4803
5d120deb60ca
Enable rudimentary support for valgrind, including functions that tell valgrind
Jerry James <james@xemacs.org>
parents:
4790
diff
changeset
|
6028 test "$with_valgrind" = yes && echo " Compiling in support for memory debugging with Valgrind." |
2651 | 6029 echo "" |
6030 ) | tee -a Installation | |
6031 dnl echo "The above configure report is appended to \"Installation\" file." | |
6032 echo "" | |
6033 | |
6034 dnl ----------------------------------- | |
6035 dnl Now generate config.h and Makefiles | |
6036 dnl ----------------------------------- | |
6037 AC_CONFIG_HEADER(src/config.h lwlib/config.h) | |
6038 | |
6039 dnl This has to be called in order for this variable to get into config.status | |
6040 AC_SUBST(internal_makefile_list) | |
6041 # Remove any trailing slashes in these variables. | |
6042 test -n "$prefix" && | |
6043 prefix=`echo '' "$prefix" | sed -e 's:^ ::' -e 's,\([[^/]]\)/*$,\1,'` | |
6044 test -n "$exec_prefix" && | |
6045 exec_prefix=`echo '' "$exec_prefix" | sed -e 's:^ ::' -e 's,\([[^/]]\)/*$,\1,'` | |
6046 | |
6047 dnl Build Makefile.in's from Makefile.in.in's | |
6048 dnl except ./Makefile from $srcdir/Makefile.in | |
6049 dnl src/Makefile.in will have src/depend appended to it; | |
6050 dnl module Makefiles will have the common text in | |
6051 dnl modules/common/Makefile.common appended. | |
6052 | |
3481 | 6053 dnl this actually should be conditional on having perl (ie, effectively |
6054 dnl unconditional on sane systems) | |
6055 if test -r $srcdir/src/depend; then :; | |
6056 else | |
6057 echo "creating $srcdir/src/depend" | |
6058 perl $srcdir/src/make-src-depend > $srcdir/src/depend | |
6059 fi | |
6060 | |
2651 | 6061 for file in $internal_makefile_list; do |
6062 case $file in | |
6063 src/Makefile.in ) file="src/Makefile.in:src/Makefile.in.in:src/depend" ;; | |
6064 modules/* ) file="${file}:${file}.in:modules/common/Makefile.common" ;; | |
6065 esac | |
6066 AC_CONFIG_FILES($file) | |
6067 done | |
6068 AC_CONFIG_FILES(src/paths.h src/xemacs.def.in lib-src/config.values) | |
4842
1d775c6304d1
Use with-FOO consistently instead of enable-FOO
Ben Wing <ben@xemacs.org>
parents:
4834
diff
changeset
|
6069 test "$with_modules" = "yes" && AC_CONFIG_FILES(lib-src/ellcc.h) |
2651 | 6070 |
6071 | |
6072 dnl Normally []'s are used for quoting but this will cause problems | |
6073 dnl since we use brackets in sed. When not inside of a macro definition, | |
6074 dnl two brackets become one, but inside of a macro definition you need | |
6075 dnl more, or something -- I don't understand, but Martin probably does. | |
6076 dnl We put the brackets back later. | |
6077 dnl [ben] | |
3418 | 6078 dnl To insert comments that will remain in the generated file, we use the |
6079 dnl imake XCOMM convention. Lines beginning with "XCOMM " exactly (no | |
6080 dnl leading whitespace, one trailing ASCII space, case sensitive) will be | |
6081 dnl transformed to shell/make/gdb comments in the generated file. | |
6082 dnl [sjt] | |
2651 | 6083 |
6084 dnl MAKE_JUNK_C(filename): | |
6085 dnl Copy a .in file to junk.c in preparation for passing through the | |
6086 dnl C preprocessor. Delete comment lines, pass lines that will be | |
6087 dnl interpreted by cpp through directly, and put quotes around remaining | |
6088 dnl lines, to avoid problems from overly helpful preprocessors that | |
6089 dnl "helpfully" put extra quotes in various places for later use by the | |
6090 dnl compiler. Later, the quotes will be removed. | |
6091 | |
6092 m4_define([MAKE_JUNK_C], | |
6093 [ rm -f junk.c | |
6094 < $1 \ | |
6095 sed -e '/^# Generated/d' \ | |
6096 -e 's%/\*\*/#.*%%' \ | |
6097 -e 's/^ *# */#/' \ | |
6098 dnl Delete Makefile.in.in comment lines | |
6099 -e '/^##/d' \ | |
6100 dnl Pass through CPP directives unchanged | |
6101 -e '/^#/ { | |
6102 p | |
6103 d | |
6104 }' \ | |
6105 dnl Quote other lines to protect from CPP substitution | |
6106 -e '/./ { | |
6107 s/\([[\"]]\)/\\\1/g | |
6108 s/^/"/ | |
6109 s/$/"/ | |
6110 }' > junk.c; | |
6111 ])dnl MAKE_JUNK_C | |
6112 | |
6113 dnl CPP_MAKEFILE(CPPFLAGS,filename): | |
6114 dnl Pass junk.c through the preprocessor and put the result in FILENAME. | |
6115 | |
6116 m4_define([CPP_MAKEFILE], | |
6117 [echo creating $dir/$2 | |
6118 $CPP -I. -I${srcdir}/src $1 junk.c \ | |
6119 dnl Delete line directives inserted by $CPP | |
6120 | sed -e 's/^\#.*//' \ | |
6121 dnl Delete spurious blanks inserted by $CPP | |
6122 -e 's/^[[ TAB]][[ TAB]]*$//'\ | |
6123 -e 's/^ /TAB/' \ | |
6124 dnl Delete blank lines | |
6125 -e '/^[[ ]]*$/d' \ | |
6126 dnl Restore lines quoted above to original contents. | |
6127 -e '/^\"/ { | |
6128 s/\\\([[\"]]\)/\1/g | |
6129 s/^[[ TAB]]*\"// | |
6130 s/\"[[ TAB]]*$// | |
3418 | 6131 }' \ |
6132 dnl Convert comments -- must come after the unquoting operations | |
6133 -e 's/^XCOMM /\# /' > Makefile.new | |
2651 | 6134 chmod 444 Makefile.new |
6135 mv -f Makefile.new $2 | |
6136 ])dnl CPP_MAKEFILE | |
6137 | |
6138 AC_CONFIG_COMMANDS([default], | |
6139 [for dir in . $MAKE_SUBDIR; do | |
6140 ( | |
6141 cd $dir | |
6142 | |
6143 dnl Create a GNUmakefile and Makefile from Makefile.in. | |
6144 dnl Create xemacs.def from xemacs.def.in in the same fashion, | |
3418 | 6145 dnl if it exists (i.e. in the src/ directory). Ditto for the |
5598
bccc91a65536
Fix .gdbinit and .dbxrc when using the new garbage collector.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5585
diff
changeset
|
6146 dnl debugger init files (in the src/ and etc/ directories). |
bccc91a65536
Fix .gdbinit and .dbxrc when using the new garbage collector.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5585
diff
changeset
|
6147 if test -r "Makefile.in"; then |
bccc91a65536
Fix .gdbinit and .dbxrc when using the new garbage collector.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5585
diff
changeset
|
6148 MAKE_JUNK_C(Makefile.in) |
bccc91a65536
Fix .gdbinit and .dbxrc when using the new garbage collector.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5585
diff
changeset
|
6149 CPP_MAKEFILE(,Makefile) |
bccc91a65536
Fix .gdbinit and .dbxrc when using the new garbage collector.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5585
diff
changeset
|
6150 CPP_MAKEFILE(-DUSE_GNU_MAKE,GNUmakefile) |
bccc91a65536
Fix .gdbinit and .dbxrc when using the new garbage collector.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5585
diff
changeset
|
6151 fi |
3092 | 6152 if test -r ".gdbinit.in"; then |
6153 MAKE_JUNK_C(.gdbinit.in) | |
6154 CPP_MAKEFILE(,.gdbinit) | |
6155 fi | |
5601
3e5d5e8e4bb7
Move etc/dbxrc.in to src/.dbxrc.in.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5598
diff
changeset
|
6156 if test -r ".dbxrc.in"; then |
3e5d5e8e4bb7
Move etc/dbxrc.in to src/.dbxrc.in.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5598
diff
changeset
|
6157 MAKE_JUNK_C(.dbxrc.in) |
3e5d5e8e4bb7
Move etc/dbxrc.in to src/.dbxrc.in.
Marcus Crestani <crestani@informatik.uni-tuebingen.de>
parents:
5598
diff
changeset
|
6158 CPP_MAKEFILE(,.dbxrc) |
3092 | 6159 fi |
2651 | 6160 if test -r "xemacs.def.in"; then |
6161 dnl #### We should be using MAKE_JUNK_C instead of the next two lines. | |
6162 dnl #### But the comments in xemacs.def.in need to be converted from C-style | |
6163 dnl #### to lines beginning with ##. | |
6164 rm -f junk.c | |
6165 cp xemacs.def.in junk.c | |
6166 CPP_MAKEFILE(,xemacs.def) | |
6167 fi | |
6168 rm -f junk.c | |
6169 ) | |
6170 done | |
6171 | |
6172 dnl Append AC_DEFINE information to lib-src/config.values | |
6173 dnl (AC_SUBST information is already there (see config.values.sh). | |
6174 sed < config.status >> lib-src/config.values \ | |
6175 -e '/{ac_dA}.*{ac_dB}.*{ac_dC}.*{ac_dD}$/!d' \ | |
6176 -e 's/\${ac_dA}\(.*\)\${ac_dB}.*\${ac_dC}\(.*\)\${ac_dD}/\1 \2/' \ | |
6177 -e 's/^\([[^ ]]*\) $/\1 ""/' \ | |
6178 -e 's/ 1$/ t/' | |
6179 | |
6180 ], | |
6181 [CPP="$CPP" | |
6182 MAKE_SUBDIR="$MAKE_SUBDIR" | |
6183 ])dnl | |
6184 | |
6185 AC_OUTPUT()dnl | |
6186 |