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