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