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