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