]> git.saurik.com Git - wxWidgets.git/blame - aclocal.m4
Fixes after removal of palmos/gccpriv.h.
[wxWidgets.git] / aclocal.m4
CommitLineData
2a879853 1# aclocal.m4 generated automatically by aclocal 1.6.3 -*- Autoconf -*-
8168de4c 2
2a879853 3# Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002
fe0895cf
VS
4# Free Software Foundation, Inc.
5# This file is free software; the Free Software Foundation
6# gives unlimited permission to copy and/or distribute it,
7# with or without modifications, as long as this notice is preserved.
8168de4c 8
fe0895cf
VS
9# This program is distributed in the hope that it will be useful,
10# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
11# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
12# PARTICULAR PURPOSE.
8168de4c 13
b040e242
VS
14dnl ---------------------------------------------------------------------------
15dnl
16dnl Macros for configure.in for wxWindows by Robert Roebling, Phil Blecker,
17dnl Vadim Zeitlin and Ron Lee
18dnl
19dnl This script is under the wxWindows licence.
20dnl
af8ebe8a 21dnl Version: $Id$
b040e242
VS
22dnl ---------------------------------------------------------------------------
23
24dnl ===========================================================================
25dnl macros to find the a file in the list of include/lib paths
26dnl ===========================================================================
27
28dnl ---------------------------------------------------------------------------
29dnl call WX_PATH_FIND_INCLUDES(search path, header name), sets ac_find_includes
30dnl to the full name of the file that was found or leaves it empty if not found
31dnl ---------------------------------------------------------------------------
32AC_DEFUN([WX_PATH_FIND_INCLUDES],
33[
34ac_find_includes=
2b5f62a0 35for ac_dir in $1 /usr/include;
b040e242
VS
36 do
37 if test -f "$ac_dir/$2"; then
38 ac_find_includes=$ac_dir
39 break
40 fi
41 done
42])
43
44dnl ---------------------------------------------------------------------------
45dnl call WX_PATH_FIND_LIBRARIES(search path, header name), sets ac_find_libraries
46dnl to the full name of the file that was found or leaves it empty if not found
47dnl ---------------------------------------------------------------------------
48AC_DEFUN([WX_PATH_FIND_LIBRARIES],
49[
50ac_find_libraries=
2b5f62a0 51for ac_dir in $1 /usr/lib;
b040e242
VS
52 do
53 for ac_extension in a so sl dylib; do
54 if test -f "$ac_dir/lib$2.$ac_extension"; then
55 ac_find_libraries=$ac_dir
56 break 2
57 fi
58 done
59 done
60])
61
62dnl ---------------------------------------------------------------------------
63dnl Path to include, already defined
64dnl ---------------------------------------------------------------------------
65AC_DEFUN([WX_INCLUDE_PATH_EXIST],
66[
2b5f62a0
VZ
67 dnl never add -I/usr/include to the CPPFLAGS
68 if test "x$1" = "x/usr/include"; then
b040e242
VS
69 ac_path_to_include=""
70 else
2b5f62a0
VZ
71 echo "$2" | grep "\-I$1" > /dev/null
72 result=$?
73 if test $result = 0; then
74 ac_path_to_include=""
75 else
76 ac_path_to_include=" -I$1"
77 fi
b040e242
VS
78 fi
79])
80
81dnl ---------------------------------------------------------------------------
82dnl Path to link, already defined
83dnl ---------------------------------------------------------------------------
84AC_DEFUN([WX_LINK_PATH_EXIST],
85[
86 echo "$2" | grep "\-L$1" > /dev/null
87 result=$?
88 if test $result = 0; then
89 ac_path_to_link=""
90 else
91 ac_path_to_link=" -L$1"
92 fi
93])
94
95dnl ===========================================================================
96dnl C++ features test
97dnl ===========================================================================
98
99dnl ---------------------------------------------------------------------------
100dnl WX_CPP_NEW_HEADERS checks whether the compiler has "new" <iostream> header
101dnl or only the old <iostream.h> one - it may be generally assumed that if
102dnl <iostream> exists, the other "new" headers (without .h) exist too.
103dnl
c2218763 104dnl call WX_CPP_NEW_HEADERS(actiof-if-true, action-if-false)
b040e242
VS
105dnl ---------------------------------------------------------------------------
106
107AC_DEFUN([WX_CPP_NEW_HEADERS],
108[
b040e242
VS
109 AC_LANG_SAVE
110 AC_LANG_CPLUSPLUS
111
112 AC_CHECK_HEADERS(iostream)
113
114 if test "$ac_cv_header_iostream" = "yes" ; then
115 ifelse([$1], , :, [$1])
116 else
117 ifelse([$2], , :, [$2])
118 fi
119
120 AC_LANG_RESTORE
b040e242
VS
121])
122
123dnl ---------------------------------------------------------------------------
124dnl WX_CPP_BOOL checks whether the C++ compiler has a built in bool type
125dnl
126dnl call WX_CPP_BOOL - will define HAVE_BOOL if the compiler supports bool
127dnl ---------------------------------------------------------------------------
128
129AC_DEFUN([WX_CPP_BOOL],
130[
131 AC_CACHE_CHECK([if C++ compiler supports bool], wx_cv_cpp_bool,
132 [
133 AC_LANG_SAVE
134 AC_LANG_CPLUSPLUS
135
136 AC_TRY_COMPILE(
137 [
138 ],
139 [
140 bool b = true;
141
142 return 0;
143 ],
144 [
145 wx_cv_cpp_bool=yes
146 ],
147 [
148 wx_cv_cpp_bool=no
149 ]
150 )
151
152 AC_LANG_RESTORE
153 ])
154
155 if test "$wx_cv_cpp_bool" = "yes"; then
156 AC_DEFINE(HAVE_BOOL)
157 fi
158])
159
986ecc86
VZ
160dnl ---------------------------------------------------------------------------
161dnl WX_CPP_EXPLICIT checks whether the C++ compiler support the explicit
162dnl keyword and defines HAVE_EXPLICIT if this is the case
163dnl ---------------------------------------------------------------------------
164
165AC_DEFUN([WX_CPP_EXPLICIT],
166[
167 AC_CACHE_CHECK([if C++ compiler supports the explicit keyword],
168 wx_cv_explicit,
169 [
170 AC_LANG_SAVE
171 AC_LANG_CPLUSPLUS
172
173 dnl do the test in 2 steps: first check that the compiler knows about the
174 dnl explicit keyword at all and then verify that it really honours it
175 AC_TRY_COMPILE(
176 [
177 class Foo { public: explicit Foo(int) {} };
178 ],
179 [
180 return 0;
181 ],
182 [
183 AC_TRY_COMPILE(
184 [
185 class Foo { public: explicit Foo(int) {} };
186 static void TakeFoo(const Foo& foo) { }
187 ],
188 [
189 TakeFoo(17);
190 return 0;
191 ],
192 wx_cv_explicit=no,
193 wx_cv_explicit=yes
194 )
195 ],
196 wx_cv_explicit=no
197 )
198
199 AC_LANG_RESTORE
200 ])
201
202 if test "$wx_cv_explicit" = "yes"; then
203 AC_DEFINE(HAVE_EXPLICIT)
204 fi
205])
206
b040e242
VS
207dnl ---------------------------------------------------------------------------
208dnl a slightly better AC_C_BIGENDIAN macro which allows cross-compiling
209dnl ---------------------------------------------------------------------------
210
211AC_DEFUN([WX_C_BIGENDIAN],
212[AC_CACHE_CHECK([whether byte ordering is bigendian], ac_cv_c_bigendian,
213[ac_cv_c_bigendian=unknown
214# See if sys/param.h defines the BYTE_ORDER macro.
215AC_TRY_COMPILE([#include <sys/types.h>
216#include <sys/param.h>], [
217#if !BYTE_ORDER || !BIG_ENDIAN || !LITTLE_ENDIAN
218 bogus endian macros
219#endif], [# It does; now see whether it defined to BIG_ENDIAN or not.
220AC_TRY_COMPILE([#include <sys/types.h>
221#include <sys/param.h>], [
222#if BYTE_ORDER != BIG_ENDIAN
223 not big endian
224#endif], ac_cv_c_bigendian=yes, ac_cv_c_bigendian=no)])
225if test $ac_cv_c_bigendian = unknown; then
226AC_TRY_RUN([main () {
227 /* Are we little or big endian? From Harbison&Steele. */
228 union
229 {
230 long l;
231 char c[sizeof (long)];
232 } u;
233 u.l = 1;
234 exit (u.c[sizeof (long) - 1] == 1);
235}], [ac_cv_c_bigendian=no], [ac_cv_c_bigendian=yes], [ac_cv_c_bigendian=unknown])
236fi])
237if test $ac_cv_c_bigendian = unknown; then
238 AC_MSG_WARN([Assuming little-endian target machine - this may be overriden by adding the line "ac_cv_c_bigendian=${ac_cv_c_bigendian='yes'}" to config.cache file])
239fi
240if test $ac_cv_c_bigendian = yes; then
241 AC_DEFINE(WORDS_BIGENDIAN)
242fi
243])
244
245dnl ---------------------------------------------------------------------------
246dnl override AC_ARG_ENABLE/WITH to cache the results in .cache file
247dnl ---------------------------------------------------------------------------
248
249AC_DEFUN([WX_ARG_CACHE_INIT],
250 [
251 wx_arg_cache_file="configarg.cache"
252 echo "loading argument cache $wx_arg_cache_file"
253 rm -f ${wx_arg_cache_file}.tmp
254 touch ${wx_arg_cache_file}.tmp
255 touch ${wx_arg_cache_file}
256 ])
257
258AC_DEFUN([WX_ARG_CACHE_FLUSH],
259 [
260 echo "saving argument cache $wx_arg_cache_file"
261 mv ${wx_arg_cache_file}.tmp ${wx_arg_cache_file}
262 ])
263
264dnl this macro checks for a three-valued command line --with argument:
265dnl possible arguments are 'yes', 'no', 'sys', or 'builtin'
266dnl usage: WX_ARG_SYS_WITH(option, helpmessage, variable-name)
267AC_DEFUN([WX_ARG_SYS_WITH],
268 [
269 AC_MSG_CHECKING([for --with-$1])
270 no_cache=0
271 AC_ARG_WITH($1, [$2],
272 [
273 if test "$withval" = yes; then
274 ac_cv_use_$1='$3=yes'
275 elif test "$withval" = no; then
276 ac_cv_use_$1='$3=no'
277 elif test "$withval" = sys; then
278 ac_cv_use_$1='$3=sys'
279 elif test "$withval" = builtin; then
280 ac_cv_use_$1='$3=builtin'
281 else
282 AC_MSG_ERROR([Invalid value for --with-$1: should be yes, no, sys, or builtin])
283 fi
284 ],
285 [
286 LINE=`grep "$3" ${wx_arg_cache_file}`
287 if test "x$LINE" != x ; then
288 eval "DEFAULT_$LINE"
289 else
290 no_cache=1
291 fi
292
293 ac_cv_use_$1='$3='$DEFAULT_$3
294 ])
295
296 eval "$ac_cv_use_$1"
297 if test "$no_cache" != 1; then
298 echo $ac_cv_use_$1 >> ${wx_arg_cache_file}.tmp
299 fi
300
301 if test "$$3" = yes; then
302 AC_MSG_RESULT(yes)
303 elif test "$$3" = no; then
304 AC_MSG_RESULT(no)
305 elif test "$$3" = sys; then
306 AC_MSG_RESULT([system version])
307 elif test "$$3" = builtin; then
308 AC_MSG_RESULT([builtin version])
309 else
310 AC_MSG_ERROR([Invalid value for --with-$1: should be yes, no, sys, or builtin])
311 fi
312 ])
313
314dnl this macro checks for a command line argument and caches the result
315dnl usage: WX_ARG_WITH(option, helpmessage, variable-name)
316AC_DEFUN([WX_ARG_WITH],
317 [
318 AC_MSG_CHECKING([for --with-$1])
319 no_cache=0
320 AC_ARG_WITH($1, [$2],
321 [
322 if test "$withval" = yes; then
323 ac_cv_use_$1='$3=yes'
324 else
325 ac_cv_use_$1='$3=no'
326 fi
327 ],
328 [
329 LINE=`grep "$3" ${wx_arg_cache_file}`
330 if test "x$LINE" != x ; then
331 eval "DEFAULT_$LINE"
332 else
333 no_cache=1
334 fi
335
336 ac_cv_use_$1='$3='$DEFAULT_$3
337 ])
338
339 eval "$ac_cv_use_$1"
340 if test "$no_cache" != 1; then
341 echo $ac_cv_use_$1 >> ${wx_arg_cache_file}.tmp
342 fi
343
344 if test "$$3" = yes; then
345 AC_MSG_RESULT(yes)
346 else
347 AC_MSG_RESULT(no)
348 fi
349 ])
350
351dnl like WX_ARG_WITH but uses AC_ARG_ENABLE instead of AC_ARG_WITH
5005acfe 352dnl usage: WX_ARG_ENABLE(option, helpmessage, variable-name, enablestring)
2b5f62a0
VZ
353dnl
354dnl enablestring is a hack and allows to show "checking for --disable-foo"
355dnl message when running configure instead of the default "checking for
356dnl --enable-foo" one whih is useful for the options enabled by default
b040e242
VS
357AC_DEFUN([WX_ARG_ENABLE],
358 [
5005acfe
VZ
359 enablestring=$4
360 AC_MSG_CHECKING([for --${enablestring:-enable}-$1])
b040e242
VS
361 no_cache=0
362 AC_ARG_ENABLE($1, [$2],
363 [
364 if test "$enableval" = yes; then
365 ac_cv_use_$1='$3=yes'
366 else
367 ac_cv_use_$1='$3=no'
368 fi
369 ],
370 [
371 LINE=`grep "$3" ${wx_arg_cache_file}`
372 if test "x$LINE" != x ; then
373 eval "DEFAULT_$LINE"
374 else
375 no_cache=1
376 fi
377
378 ac_cv_use_$1='$3='$DEFAULT_$3
379 ])
380
381 eval "$ac_cv_use_$1"
382 if test "$no_cache" != 1; then
383 echo $ac_cv_use_$1 >> ${wx_arg_cache_file}.tmp
384 fi
385
386 if test "$$3" = yes; then
387 AC_MSG_RESULT(yes)
388 else
389 AC_MSG_RESULT(no)
390 fi
391 ])
392
393
2b5f62a0
VZ
394dnl ===========================================================================
395dnl Linker features test
396dnl ===========================================================================
397
398dnl ---------------------------------------------------------------------------
399dnl WX_VERSIONED_SYMBOLS checks whether the linker can create versioned
400dnl symbols. If it can, sets LDFLAGS_VERSIONING to $CXX flags needed to use
401dnl version script file named versionfile
402dnl
403dnl call WX_VERSIONED_SYMBOLS(versionfile)
404dnl ---------------------------------------------------------------------------
405AC_DEFUN([WX_VERSIONED_SYMBOLS],
406[
407 found_versioning=no
408
b4eecb7e
VS
409 dnl FIXME - doesn't work, Solaris linker doesn't accept wildcards
410 dnl in the script.
411 dnl dnl Check for known non-gcc cases:
412 dnl case "${host}" in
413 dnl *-*-solaris2* )
414 dnl if test "x$GCC" != "xyes" ; then
415 dnl LDFLAGS_VERSIONING="-M $1"
416 dnl found_versioning=yes
417 dnl fi
418 dnl ;;
419 dnl esac
2b5f62a0
VZ
420
421 dnl Generic check for GCC or GCC-like behaviour (Intel C++, GCC):
422 if test $found_versioning = no ; then
423 AC_CACHE_CHECK([if the linker accepts --version-script], wx_cv_version_script,
424 [
425 echo "VER_1 { *; };" >conftest.sym
426 echo "int main() { return 0; }" >conftest.cpp
427
428 if AC_TRY_COMMAND([
429 $CXX -o conftest.output $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.cpp
430 -Wl,--version-script,conftest.sym >/dev/null 2>conftest.stderr]) ; then
431 if test -s conftest.stderr ; then
432 wx_cv_version_script=no
433 else
434 wx_cv_version_script=yes
435 fi
436 else
437 wx_cv_version_script=no
438 fi
439 rm -f conftest.output conftest.stderr conftest.sym conftest.cpp
440 ])
441 if test $wx_cv_version_script = yes ; then
442 LDFLAGS_VERSIONING="-Wl,--version-script,$1"
443 fi
444 fi
445])
446
b040e242
VS
447
448dnl ===========================================================================
449dnl "3rd party" macros included here because they are not widely available
450dnl ===========================================================================
451
b040e242
VS
452dnl ---------------------------------------------------------------------------
453dnl test for availability of iconv()
454dnl ---------------------------------------------------------------------------
455
b040e242
VS
456dnl From Bruno Haible.
457
458AC_DEFUN([AM_ICONV],
459[
460 dnl Some systems have iconv in libc, some have it in libiconv (OSF/1 and
461 dnl those with the standalone portable GNU libiconv installed).
462
463 AC_ARG_WITH([libiconv-prefix],
464[ --with-libiconv-prefix=DIR search for libiconv in DIR/include and DIR/lib], [
465 for dir in `echo "$withval" | tr : ' '`; do
466 if test -d $dir/include; then CPPFLAGS="$CPPFLAGS -I$dir/include"; fi
467 if test -d $dir/lib; then LDFLAGS="$LDFLAGS -L$dir/lib"; fi
468 done
469 ])
470
471 AC_CACHE_CHECK(for iconv, am_cv_func_iconv, [
472 am_cv_func_iconv="no, consider installing GNU libiconv"
473 am_cv_lib_iconv=no
474 AC_TRY_LINK([#include <stdlib.h>
475#include <iconv.h>],
476 [iconv_t cd = iconv_open("","");
477 iconv(cd,NULL,NULL,NULL,NULL);
478 iconv_close(cd);],
479 am_cv_func_iconv=yes)
480 if test "$am_cv_func_iconv" != yes; then
481 am_save_LIBS="$LIBS"
482 LIBS="$LIBS -liconv"
483 AC_TRY_LINK([#include <stdlib.h>
484#include <iconv.h>],
485 [iconv_t cd = iconv_open("","");
486 iconv(cd,NULL,NULL,NULL,NULL);
487 iconv_close(cd);],
488 am_cv_lib_iconv=yes
489 am_cv_func_iconv=yes)
490 LIBS="$am_save_LIBS"
491 fi
492 ])
493 if test "$am_cv_func_iconv" = yes; then
494 AC_DEFINE(HAVE_ICONV, 1, [Define if you have the iconv() function.])
b7043674 495 AC_CACHE_CHECK([if iconv needs const], wx_cv_func_iconv_const,
b040e242
VS
496 AC_TRY_COMPILE([
497#include <stdlib.h>
498#include <iconv.h>
499extern
500#ifdef __cplusplus
501"C"
502#endif
503#if defined(__STDC__) || defined(__cplusplus)
504size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);
505#else
506size_t iconv();
507#endif
b7043674
VZ
508 ],
509 [],
510 wx_cv_func_iconv_const="no",
511 wx_cv_func_iconv_const="yes"
512 )
513 )
514
515 iconv_const=
1c405bb5 516 if test "x$wx_cv_func_iconv_const" = "xyes"; then
b7043674
VZ
517 iconv_const="const"
518 fi
519
520 AC_DEFINE_UNQUOTED(ICONV_CONST, $iconv_const,
b040e242
VS
521 [Define as const if the declaration of iconv() needs const.])
522 fi
523 LIBICONV=
524 if test "$am_cv_lib_iconv" = yes; then
525 LIBICONV="-liconv"
526 fi
527 AC_SUBST(LIBICONV)
528])
529
90dd450c
VZ
530dnl ---------------------------------------------------------------------------
531dnl AC_SYS_LARGEFILE (partly based on the code from autoconf 2.5x)
532dnl ---------------------------------------------------------------------------
533
534dnl WX_SYS_LARGEFILE_TEST
535dnl
536dnl NB: original autoconf test was checking if compiler supported 6 bit off_t
537dnl arithmetic properly but this failed miserably with gcc under Linux
538dnl whereas the system still supports 64 bit files, so now simply check
539dnl that off_t is big enough
540define(WX_SYS_LARGEFILE_TEST,
541[typedef struct {
542 unsigned int field: sizeof(off_t) == 8;
543} wxlf;
544])
545
546
547dnl WX_SYS_LARGEFILE_MACRO_VALUE(C-MACRO, VALUE, CACHE-VAR)
548define(WX_SYS_LARGEFILE_MACRO_VALUE,
549[
550 AC_CACHE_CHECK([for $1 value needed for large files], [$3],
551 [
552 AC_TRY_COMPILE([#define $1 $2
553 #include <sys/types.h>],
554 WX_SYS_LARGEFILE_TEST,
555 [$3=$2],
556 [$3=no])
557 ]
558 )
559
560 if test "$$3" != no; then
5a5d3c08 561 wx_largefile=yes
90dd450c
VZ
562 AC_DEFINE_UNQUOTED([$1], [$$3])
563 fi
564])
565
566
567dnl AC_SYS_LARGEFILE
568dnl ----------------
569dnl By default, many hosts won't let programs access large files;
570dnl one must use special compiler options to get large-file access to work.
571dnl For more details about this brain damage please see:
572dnl http://www.sas.com/standards/large.file/x_open.20Mar96.html
573AC_DEFUN([AC_SYS_LARGEFILE],
574[AC_ARG_ENABLE(largefile,
575 [ --disable-largefile omit support for large files])
576if test "$enable_largefile" != no; then
577 dnl _FILE_OFFSET_BITS==64 is needed for Linux, Solaris, ...
578 dnl _LARGE_FILES -- for AIX
5a5d3c08 579 wx_largefile=no
90dd450c
VZ
580 WX_SYS_LARGEFILE_MACRO_VALUE(_FILE_OFFSET_BITS, 64, ac_cv_sys_file_offset_bits)
581 if test "x$wx_largefile" != "xyes"; then
582 WX_SYS_LARGEFILE_MACRO_VALUE(_LARGE_FILES, 1, ac_cv_sys_large_files)
583 fi
584
5a5d3c08 585 AC_MSG_CHECKING(if large file support is available)
90dd450c
VZ
586 if test "x$wx_largefile" = "xyes"; then
587 AC_DEFINE(HAVE_LARGEFILE_SUPPORT)
588 fi
5a5d3c08 589 AC_MSG_RESULT($wx_largefile)
90dd450c
VZ
590fi
591])
b040e242 592
521196a2
MB
593
594dnl Available from the GNU Autoconf Macro Archive at:
595dnl http://www.gnu.org/software/ac-archive/htmldoc/ac_cxx_const_cast.html
596dnl
597AC_DEFUN([AC_CXX_CONST_CAST],
598[AC_CACHE_CHECK(whether the compiler supports const_cast<>,
599ac_cv_cxx_const_cast,
600[AC_LANG_SAVE
601 AC_LANG_CPLUSPLUS
602 AC_TRY_COMPILE(,[int x = 0;const int& y = x;int& z = const_cast<int&>(y);return z;],
603 ac_cv_cxx_const_cast=yes, ac_cv_cxx_const_cast=no)
604 AC_LANG_RESTORE
605])
606if test "$ac_cv_cxx_const_cast" = yes; then
607 AC_DEFINE(HAVE_CONST_CAST,,[define if the compiler supports const_cast<>])
608fi
609])
610
7714864e
RL
611dnl http://www.gnu.org/software/ac-archive/htmldoc/ac_cxx_reinterpret_cast.html
612AC_DEFUN([AC_CXX_REINTERPRET_CAST],
613[AC_CACHE_CHECK(whether the compiler supports reinterpret_cast<>,
614ac_cv_cxx_reinterpret_cast,
615[AC_LANG_SAVE
616 AC_LANG_CPLUSPLUS
617 AC_TRY_COMPILE([#include <typeinfo>
618class Base { public : Base () {} virtual void f () = 0;};
619class Derived : public Base { public : Derived () {} virtual void f () {} };
620class Unrelated { public : Unrelated () {} };
621int g (Unrelated&) { return 0; }],[
622Derived d;Base& b=d;Unrelated& e=reinterpret_cast<Unrelated&>(b);return g(e);],
623 ac_cv_cxx_reinterpret_cast=yes, ac_cv_cxx_reinterpret_cast=no)
624 AC_LANG_RESTORE
625])
626if test "$ac_cv_cxx_reinterpret_cast" = yes; then
627 AC_DEFINE(HAVE_REINTERPRET_CAST,,
628 [define if the compiler supports reinterpret_cast<>])
629fi
630])
631
ecfd48ca
VZ
632dnl and http://www.gnu.org/software/ac-archive/htmldoc/ac_cxx_static_cast.html
633AC_DEFUN([AC_CXX_STATIC_CAST],
634[AC_CACHE_CHECK(whether the compiler supports static_cast<>,
635ac_cv_cxx_static_cast,
636[AC_LANG_SAVE
637 AC_LANG_CPLUSPLUS
638 AC_TRY_COMPILE([#include <typeinfo>
639class Base { public : Base () {} virtual void f () = 0; };
640class Derived : public Base { public : Derived () {} virtual void f () {} };
641int g (Derived&) { return 0; }],[
642Derived d; Base& b = d; Derived& s = static_cast<Derived&> (b); return g (s);],
643 ac_cv_cxx_static_cast=yes, ac_cv_cxx_static_cast=no)
644 AC_LANG_RESTORE
645])
646if test "$ac_cv_cxx_static_cast" = yes; then
647 AC_DEFINE(HAVE_STATIC_CAST,, [define if the compiler supports static_cast<>])
648fi
649])
650
9e691f46
VZ
651# Configure paths for GTK+
652# Owen Taylor 1997-2001
b040e242
VS
653
654dnl AM_PATH_GTK_2_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]])
9e691f46
VZ
655dnl Test for GTK+, and define GTK_CFLAGS and GTK_LIBS, if gthread is specified in MODULES,
656dnl pass to pkg-config
3f345b47 657dnl
c2218763 658AC_DEFUN([AM_PATH_GTK_2_0],
9e691f46
VZ
659[dnl
660dnl Get the cflags and libraries from pkg-config
3f345b47 661dnl
9e691f46
VZ
662AC_ARG_ENABLE(gtktest, [ --disable-gtktest do not try to compile and run a test GTK+ program],
663 , enable_gtktest=yes)
3f345b47 664
9e691f46 665 pkg_config_args=gtk+-2.0
3f345b47
VZ
666 for module in . $4
667 do
668 case "$module" in
9e691f46
VZ
669 gthread)
670 pkg_config_args="$pkg_config_args gthread-2.0"
3f345b47
VZ
671 ;;
672 esac
673 done
674
9e691f46
VZ
675 no_gtk=""
676
677 AC_PATH_PROG(PKG_CONFIG, pkg-config, no)
678
679 if test x$PKG_CONFIG != xno ; then
680 if pkg-config --atleast-pkgconfig-version 0.7 ; then
681 :
682 else
c2218763 683 echo "*** pkg-config too old; version 0.7 or better required."
9e691f46
VZ
684 no_gtk=yes
685 PKG_CONFIG=no
686 fi
687 else
688 no_gtk=yes
8168de4c 689 fi
9e691f46
VZ
690
691 min_gtk_version=ifelse([$1], ,2.0.0,$1)
692 AC_MSG_CHECKING(for GTK+ - version >= $min_gtk_version)
693
694 if test x$PKG_CONFIG != xno ; then
695 ## don't try to run the test against uninstalled libtool libs
696 if $PKG_CONFIG --uninstalled $pkg_config_args; then
697 echo "Will use uninstalled version of GTK+ found in PKG_CONFIG_PATH"
698 enable_gtktest=no
699 fi
700
701 if $PKG_CONFIG --atleast-version $min_gtk_version $pkg_config_args; then
702 :
703 else
704 no_gtk=yes
705 fi
8168de4c
VZ
706 fi
707
9e691f46
VZ
708 if test x"$no_gtk" = x ; then
709 GTK_CFLAGS=`$PKG_CONFIG $pkg_config_args --cflags`
710 GTK_LIBS=`$PKG_CONFIG $pkg_config_args --libs`
711 gtk_config_major_version=`$PKG_CONFIG --modversion gtk+-2.0 | \
3f345b47 712 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
9e691f46 713 gtk_config_minor_version=`$PKG_CONFIG --modversion gtk+-2.0 | \
3f345b47 714 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
9e691f46 715 gtk_config_micro_version=`$PKG_CONFIG --modversion gtk+-2.0 | \
3f345b47
VZ
716 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
717 if test "x$enable_gtktest" = "xyes" ; then
718 ac_save_CFLAGS="$CFLAGS"
719 ac_save_LIBS="$LIBS"
720 CFLAGS="$CFLAGS $GTK_CFLAGS"
721 LIBS="$GTK_LIBS $LIBS"
8168de4c 722dnl
9e691f46
VZ
723dnl Now check if the installed GTK+ is sufficiently new. (Also sanity
724dnl checks the results of pkg-config to some extent)
8168de4c 725dnl
3f345b47
VZ
726 rm -f conf.gtktest
727 AC_TRY_RUN([
8168de4c 728#include <gtk/gtk.h>
8168de4c
VZ
729#include <stdio.h>
730#include <stdlib.h>
731
9e691f46 732int
8168de4c
VZ
733main ()
734{
735 int major, minor, micro;
3f345b47 736 char *tmp_version;
8168de4c 737
3f345b47 738 system ("touch conf.gtktest");
8168de4c 739
3f345b47
VZ
740 /* HP/UX 9 (%@#!) writes to sscanf strings */
741 tmp_version = g_strdup("$min_gtk_version");
742 if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
743 printf("%s, bad version string\n", "$min_gtk_version");
8168de4c
VZ
744 exit(1);
745 }
746
3f345b47
VZ
747 if ((gtk_major_version != $gtk_config_major_version) ||
748 (gtk_minor_version != $gtk_config_minor_version) ||
749 (gtk_micro_version != $gtk_config_micro_version))
750 {
9e691f46 751 printf("\n*** 'pkg-config --modversion gtk+-2.0' returned %d.%d.%d, but GTK+ (%d.%d.%d)\n",
3f345b47
VZ
752 $gtk_config_major_version, $gtk_config_minor_version, $gtk_config_micro_version,
753 gtk_major_version, gtk_minor_version, gtk_micro_version);
9e691f46 754 printf ("*** was found! If pkg-config was correct, then it is best\n");
3f345b47
VZ
755 printf ("*** to remove the old version of GTK+. You may also be able to fix the error\n");
756 printf("*** by modifying your LD_LIBRARY_PATH enviroment variable, or by editing\n");
757 printf("*** /etc/ld.so.conf. Make sure you have run ldconfig if that is\n");
758 printf("*** required on your system.\n");
9e691f46
VZ
759 printf("*** If pkg-config was wrong, set the environment variable PKG_CONFIG_PATH\n");
760 printf("*** to point to the correct configuration files\n");
761 }
3f345b47 762 else if ((gtk_major_version != GTK_MAJOR_VERSION) ||
9e691f46 763 (gtk_minor_version != GTK_MINOR_VERSION) ||
3f345b47
VZ
764 (gtk_micro_version != GTK_MICRO_VERSION))
765 {
766 printf("*** GTK+ header files (version %d.%d.%d) do not match\n",
9e691f46 767 GTK_MAJOR_VERSION, GTK_MINOR_VERSION, GTK_MICRO_VERSION);
3f345b47 768 printf("*** library (version %d.%d.%d)\n",
9e691f46 769 gtk_major_version, gtk_minor_version, gtk_micro_version);
3f345b47 770 }
3f345b47
VZ
771 else
772 {
773 if ((gtk_major_version > major) ||
774 ((gtk_major_version == major) && (gtk_minor_version > minor)) ||
775 ((gtk_major_version == major) && (gtk_minor_version == minor) && (gtk_micro_version >= micro)))
776 {
777 return 0;
778 }
779 else
780 {
781 printf("\n*** An old version of GTK+ (%d.%d.%d) was found.\n",
782 gtk_major_version, gtk_minor_version, gtk_micro_version);
783 printf("*** You need a version of GTK+ newer than %d.%d.%d. The latest version of\n",
9e691f46 784 major, minor, micro);
3f345b47
VZ
785 printf("*** GTK+ is always available from ftp://ftp.gtk.org.\n");
786 printf("***\n");
787 printf("*** If you have already installed a sufficiently new version, this error\n");
9e691f46 788 printf("*** probably means that the wrong copy of the pkg-config shell script is\n");
3f345b47 789 printf("*** being found. The easiest way to fix this is to remove the old version\n");
9e691f46
VZ
790 printf("*** of GTK+, but you can also set the PKG_CONFIG environment to point to the\n");
791 printf("*** correct copy of pkg-config. (In this case, you will have to\n");
3f345b47
VZ
792 printf("*** modify your LD_LIBRARY_PATH enviroment variable, or edit /etc/ld.so.conf\n");
793 printf("*** so that the correct libraries are found at run-time))\n");
794 }
795 }
796 return 1;
8168de4c
VZ
797}
798],, no_gtk=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
3f345b47
VZ
799 CFLAGS="$ac_save_CFLAGS"
800 LIBS="$ac_save_LIBS"
801 fi
8168de4c
VZ
802 fi
803 if test "x$no_gtk" = x ; then
b040e242 804 AC_MSG_RESULT(yes (version $gtk_config_major_version.$gtk_config_minor_version.$gtk_config_micro_version))
9e691f46 805 ifelse([$2], , :, [$2])
8168de4c
VZ
806 else
807 AC_MSG_RESULT(no)
9e691f46
VZ
808 if test "$PKG_CONFIG" = "no" ; then
809 echo "*** A new enough version of pkg-config was not found."
810 echo "*** See http://pkgconfig.sourceforge.net"
3f345b47
VZ
811 else
812 if test -f conf.gtktest ; then
813 :
814 else
9e691f46 815 echo "*** Could not run GTK+ test program, checking why..."
579d8138
VS
816 ac_save_CFLAGS="$CFLAGS"
817 ac_save_LIBS="$LIBS"
3f345b47
VZ
818 CFLAGS="$CFLAGS $GTK_CFLAGS"
819 LIBS="$LIBS $GTK_LIBS"
820 AC_TRY_LINK([
821#include <gtk/gtk.h>
822#include <stdio.h>
823], [ return ((gtk_major_version) || (gtk_minor_version) || (gtk_micro_version)); ],
824 [ echo "*** The test program compiled, but did not run. This usually means"
9e691f46
VZ
825 echo "*** that the run-time linker is not finding GTK+ or finding the wrong"
826 echo "*** version of GTK+. If it is not finding GTK+, you'll need to set your"
3f345b47
VZ
827 echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
828 echo "*** to the installed location Also, make sure you have run ldconfig if that"
829 echo "*** is required on your system"
9e691f46 830 echo "***"
3f345b47 831 echo "*** If you have an old version installed, it is best to remove it, although"
9e691f46 832 echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH" ],
3f345b47 833 [ echo "*** The test program failed to compile or link. See the file config.log for the"
579d8138 834 echo "*** exact error that occured. This usually means GTK+ is incorrectly installed."])
3f345b47
VZ
835 CFLAGS="$ac_save_CFLAGS"
836 LIBS="$ac_save_LIBS"
837 fi
838 fi
8168de4c
VZ
839 GTK_CFLAGS=""
840 GTK_LIBS=""
841 ifelse([$3], , :, [$3])
842 fi
843 AC_SUBST(GTK_CFLAGS)
844 AC_SUBST(GTK_LIBS)
3f345b47 845 rm -f conf.gtktest
8168de4c
VZ
846])
847
b040e242
VS
848# Configure paths for GTK+
849# Owen Taylor 97-11-3
850
851dnl AM_PATH_GTK([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]])
ecc7ceee
OK
852dnl Test for GTK, and define GTK_CFLAGS and GTK_LIBS
853dnl
b040e242
VS
854AC_DEFUN(AM_PATH_GTK,
855[dnl
856dnl Get the cflags and libraries from the gtk-config script
ecc7ceee
OK
857dnl
858AC_ARG_WITH(gtk-prefix,[ --with-gtk-prefix=PFX Prefix where GTK is installed (optional)],
859 gtk_config_prefix="$withval", gtk_config_prefix="")
860AC_ARG_WITH(gtk-exec-prefix,[ --with-gtk-exec-prefix=PFX Exec prefix where GTK is installed (optional)],
861 gtk_config_exec_prefix="$withval", gtk_config_exec_prefix="")
862AC_ARG_ENABLE(gtktest, [ --disable-gtktest Do not try to compile and run a test GTK program],
b040e242 863 , enable_gtktest=yes)
ecc7ceee
OK
864
865 for module in . $4
866 do
867 case "$module" in
b040e242 868 gthread)
ecc7ceee
OK
869 gtk_config_args="$gtk_config_args gthread"
870 ;;
871 esac
872 done
873
874 if test x$gtk_config_exec_prefix != x ; then
875 gtk_config_args="$gtk_config_args --exec-prefix=$gtk_config_exec_prefix"
b040e242
VS
876 if test x${GTK_CONFIG+set} != xset ; then
877 GTK_CONFIG=$gtk_config_exec_prefix/bin/gtk-config
ecc7ceee
OK
878 fi
879 fi
880 if test x$gtk_config_prefix != x ; then
881 gtk_config_args="$gtk_config_args --prefix=$gtk_config_prefix"
b040e242
VS
882 if test x${GTK_CONFIG+set} != xset ; then
883 GTK_CONFIG=$gtk_config_prefix/bin/gtk-config
ecc7ceee
OK
884 fi
885 fi
886
b040e242
VS
887 AC_PATH_PROG(GTK_CONFIG, gtk-config, no)
888 min_gtk_version=ifelse([$1], ,0.99.7,$1)
ecc7ceee
OK
889 AC_MSG_CHECKING(for GTK - version >= $min_gtk_version)
890 no_gtk=""
b040e242 891 if test "$GTK_CONFIG" = "no" ; then
ecc7ceee
OK
892 no_gtk=yes
893 else
b040e242
VS
894 GTK_CFLAGS=`$GTK_CONFIG $gtk_config_args --cflags`
895 GTK_LIBS=`$GTK_CONFIG $gtk_config_args --libs`
896 gtk_config_major_version=`$GTK_CONFIG $gtk_config_args --version | \
ecc7ceee 897 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
b040e242 898 gtk_config_minor_version=`$GTK_CONFIG $gtk_config_args --version | \
ecc7ceee 899 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
b040e242 900 gtk_config_micro_version=`$GTK_CONFIG $gtk_config_args --version | \
ecc7ceee
OK
901 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
902 if test "x$enable_gtktest" = "xyes" ; then
903 ac_save_CFLAGS="$CFLAGS"
904 ac_save_LIBS="$LIBS"
905 CFLAGS="$CFLAGS $GTK_CFLAGS"
906 LIBS="$GTK_LIBS $LIBS"
907dnl
908dnl Now check if the installed GTK is sufficiently new. (Also sanity
b040e242 909dnl checks the results of gtk-config to some extent
ecc7ceee
OK
910dnl
911 rm -f conf.gtktest
912 AC_TRY_RUN([
913#include <gtk/gtk.h>
914#include <stdio.h>
915#include <stdlib.h>
916
b040e242 917int
ecc7ceee
OK
918main ()
919{
920 int major, minor, micro;
921 char *tmp_version;
922
923 system ("touch conf.gtktest");
924
925 /* HP/UX 9 (%@#!) writes to sscanf strings */
926 tmp_version = g_strdup("$min_gtk_version");
927 if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
928 printf("%s, bad version string\n", "$min_gtk_version");
929 exit(1);
930 }
931
932 if ((gtk_major_version != $gtk_config_major_version) ||
933 (gtk_minor_version != $gtk_config_minor_version) ||
934 (gtk_micro_version != $gtk_config_micro_version))
935 {
b040e242 936 printf("\n*** 'gtk-config --version' returned %d.%d.%d, but GTK+ (%d.%d.%d)\n",
ecc7ceee
OK
937 $gtk_config_major_version, $gtk_config_minor_version, $gtk_config_micro_version,
938 gtk_major_version, gtk_minor_version, gtk_micro_version);
b040e242 939 printf ("*** was found! If gtk-config was correct, then it is best\n");
ecc7ceee
OK
940 printf ("*** to remove the old version of GTK+. You may also be able to fix the error\n");
941 printf("*** by modifying your LD_LIBRARY_PATH enviroment variable, or by editing\n");
942 printf("*** /etc/ld.so.conf. Make sure you have run ldconfig if that is\n");
943 printf("*** required on your system.\n");
b040e242
VS
944 printf("*** If gtk-config was wrong, set the environment variable GTK_CONFIG\n");
945 printf("*** to point to the correct copy of gtk-config, and remove the file config.cache\n");
ecc7ceee 946 printf("*** before re-running configure\n");
b040e242 947 }
ecc7ceee
OK
948#if defined (GTK_MAJOR_VERSION) && defined (GTK_MINOR_VERSION) && defined (GTK_MICRO_VERSION)
949 else if ((gtk_major_version != GTK_MAJOR_VERSION) ||
b040e242 950 (gtk_minor_version != GTK_MINOR_VERSION) ||
ecc7ceee
OK
951 (gtk_micro_version != GTK_MICRO_VERSION))
952 {
953 printf("*** GTK+ header files (version %d.%d.%d) do not match\n",
b040e242 954 GTK_MAJOR_VERSION, GTK_MINOR_VERSION, GTK_MICRO_VERSION);
ecc7ceee 955 printf("*** library (version %d.%d.%d)\n",
b040e242 956 gtk_major_version, gtk_minor_version, gtk_micro_version);
ecc7ceee
OK
957 }
958#endif /* defined (GTK_MAJOR_VERSION) ... */
959 else
960 {
961 if ((gtk_major_version > major) ||
962 ((gtk_major_version == major) && (gtk_minor_version > minor)) ||
963 ((gtk_major_version == major) && (gtk_minor_version == minor) && (gtk_micro_version >= micro)))
964 {
965 return 0;
966 }
967 else
968 {
969 printf("\n*** An old version of GTK+ (%d.%d.%d) was found.\n",
970 gtk_major_version, gtk_minor_version, gtk_micro_version);
971 printf("*** You need a version of GTK+ newer than %d.%d.%d. The latest version of\n",
b040e242 972 major, minor, micro);
ecc7ceee
OK
973 printf("*** GTK+ is always available from ftp://ftp.gtk.org.\n");
974 printf("***\n");
975 printf("*** If you have already installed a sufficiently new version, this error\n");
b040e242 976 printf("*** probably means that the wrong copy of the gtk-config shell script is\n");
ecc7ceee 977 printf("*** being found. The easiest way to fix this is to remove the old version\n");
b040e242
VS
978 printf("*** of GTK+, but you can also set the GTK_CONFIG environment to point to the\n");
979 printf("*** correct copy of gtk-config. (In this case, you will have to\n");
ecc7ceee
OK
980 printf("*** modify your LD_LIBRARY_PATH enviroment variable, or edit /etc/ld.so.conf\n");
981 printf("*** so that the correct libraries are found at run-time))\n");
982 }
983 }
984 return 1;
985}
986],, no_gtk=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
987 CFLAGS="$ac_save_CFLAGS"
988 LIBS="$ac_save_LIBS"
989 fi
990 fi
991 if test "x$no_gtk" = x ; then
b040e242
VS
992 AC_MSG_RESULT(yes)
993 ifelse([$2], , :, [$2])
ecc7ceee
OK
994 else
995 AC_MSG_RESULT(no)
b040e242
VS
996 if test "$GTK_CONFIG" = "no" ; then
997 echo "*** The gtk-config script installed by GTK could not be found"
ecc7ceee 998 echo "*** If GTK was installed in PREFIX, make sure PREFIX/bin is in"
b040e242
VS
999 echo "*** your path, or set the GTK_CONFIG environment variable to the"
1000 echo "*** full path to gtk-config."
ecc7ceee
OK
1001 else
1002 if test -f conf.gtktest ; then
1003 :
1004 else
1005 echo "*** Could not run GTK test program, checking why..."
1006 CFLAGS="$CFLAGS $GTK_CFLAGS"
1007 LIBS="$LIBS $GTK_LIBS"
1008 AC_TRY_LINK([
1009#include <gtk/gtk.h>
1010#include <stdio.h>
1011], [ return ((gtk_major_version) || (gtk_minor_version) || (gtk_micro_version)); ],
1012 [ echo "*** The test program compiled, but did not run. This usually means"
1013 echo "*** that the run-time linker is not finding GTK or finding the wrong"
1014 echo "*** version of GTK. If it is not finding GTK, you'll need to set your"
1015 echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
1016 echo "*** to the installed location Also, make sure you have run ldconfig if that"
1017 echo "*** is required on your system"
b040e242 1018 echo "***"
ecc7ceee
OK
1019 echo "*** If you have an old version installed, it is best to remove it, although"
1020 echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"
1021 echo "***"
1022 echo "*** If you have a RedHat 5.0 system, you should remove the GTK package that"
1023 echo "*** came with the system with the command"
1024 echo "***"
1025 echo "*** rpm --erase --nodeps gtk gtk-devel" ],
1026 [ echo "*** The test program failed to compile or link. See the file config.log for the"
1027 echo "*** exact error that occured. This usually means GTK was incorrectly installed"
1028 echo "*** or that you have moved GTK since it was installed. In the latter case, you"
b040e242 1029 echo "*** may want to edit the gtk-config script: $GTK_CONFIG" ])
ecc7ceee
OK
1030 CFLAGS="$ac_save_CFLAGS"
1031 LIBS="$ac_save_LIBS"
1032 fi
1033 fi
1034 GTK_CFLAGS=""
1035 GTK_LIBS=""
1036 ifelse([$3], , :, [$3])
1037 fi
1038 AC_SUBST(GTK_CFLAGS)
1039 AC_SUBST(GTK_LIBS)
1040 rm -f conf.gtktest
1041])
8168de4c 1042
2b5f62a0
VZ
1043
1044dnl PKG_CHECK_MODULES(GSTUFF, gtk+-2.0 >= 1.3 glib = 1.3.4, action-if, action-not)
1045dnl defines GSTUFF_LIBS, GSTUFF_CFLAGS, see pkg-config man page
1046dnl also defines GSTUFF_PKG_ERRORS on error
1047AC_DEFUN(PKG_CHECK_MODULES, [
1048 succeeded=no
1049
1050 if test -z "$PKG_CONFIG"; then
1051 AC_PATH_PROG(PKG_CONFIG, pkg-config, no)
1052 fi
1053
1054 if test "$PKG_CONFIG" = "no" ; then
1055 echo "*** The pkg-config script could not be found. Make sure it is"
1056 echo "*** in your path, or set the PKG_CONFIG environment variable"
1057 echo "*** to the full path to pkg-config."
1058 echo "*** Or see http://www.freedesktop.org/software/pkgconfig to get pkg-config."
1059 else
1060 PKG_CONFIG_MIN_VERSION=0.9.0
1061 if $PKG_CONFIG --atleast-pkgconfig-version $PKG_CONFIG_MIN_VERSION; then
1062 AC_MSG_CHECKING(for $2)
1063
1064 if $PKG_CONFIG --exists "$2" ; then
1065 AC_MSG_RESULT(yes)
1066 succeeded=yes
1067
1068 AC_MSG_CHECKING($1_CFLAGS)
1069 $1_CFLAGS=`$PKG_CONFIG --cflags "$2"`
1070 AC_MSG_RESULT($$1_CFLAGS)
1071
1072 AC_MSG_CHECKING($1_LIBS)
1073 $1_LIBS=`$PKG_CONFIG --libs "$2"`
1074 AC_MSG_RESULT($$1_LIBS)
1075 else
1076 $1_CFLAGS=""
1077 $1_LIBS=""
1078 ## If we have a custom action on failure, don't print errors, but
1079 ## do set a variable so people can do so.
1080 $1_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "$2"`
1081 ifelse([$4], ,echo $$1_PKG_ERRORS,)
1082 fi
1083
1084 AC_SUBST($1_CFLAGS)
1085 AC_SUBST($1_LIBS)
1086 else
1087 echo "*** Your version of pkg-config is too old. You need version $PKG_CONFIG_MIN_VERSION or newer."
1088 echo "*** See http://www.freedesktop.org/software/pkgconfig"
1089 fi
1090 fi
1091
1092 if test $succeeded = yes; then
1093 ifelse([$3], , :, [$3])
1094 else
1095 ifelse([$4], , AC_MSG_ERROR([Library requirements ($2) not met; consider adjusting the PKG_CONFIG_PATH environment variable if your libraries are in a nonstandard prefix so pkg-config can find them.]), [$4])
1096 fi
1097])
1098
1099
1100
f93ca9fd
VS
1101# Configure paths for SDL
1102# Sam Lantinga 9/21/99
1103# stolen from Manish Singh
1104# stolen back from Frank Belew
1105# stolen from Manish Singh
1106# Shamelessly stolen from Owen Taylor
1107
1108dnl AM_PATH_SDL([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]])
1109dnl Test for SDL, and define SDL_CFLAGS and SDL_LIBS
1110dnl
670ec357 1111AC_DEFUN([AM_PATH_SDL],
f93ca9fd
VS
1112[dnl
1113dnl Get the cflags and libraries from the sdl-config script
1114dnl
1115AC_ARG_WITH(sdl-prefix,[ --with-sdl-prefix=PFX Prefix where SDL is installed (optional)],
1116 sdl_prefix="$withval", sdl_prefix="")
1117AC_ARG_WITH(sdl-exec-prefix,[ --with-sdl-exec-prefix=PFX Exec prefix where SDL is installed (optional)],
1118 sdl_exec_prefix="$withval", sdl_exec_prefix="")
1119AC_ARG_ENABLE(sdltest, [ --disable-sdltest Do not try to compile and run a test SDL program],
1120 , enable_sdltest=yes)
1121
1122 if test x$sdl_exec_prefix != x ; then
1123 sdl_args="$sdl_args --exec-prefix=$sdl_exec_prefix"
1124 if test x${SDL_CONFIG+set} != xset ; then
1125 SDL_CONFIG=$sdl_exec_prefix/bin/sdl-config
1126 fi
1127 fi
1128 if test x$sdl_prefix != x ; then
1129 sdl_args="$sdl_args --prefix=$sdl_prefix"
1130 if test x${SDL_CONFIG+set} != xset ; then
1131 SDL_CONFIG=$sdl_prefix/bin/sdl-config
1132 fi
1133 fi
1134
1135 AC_REQUIRE([AC_CANONICAL_TARGET])
1136 PATH="$prefix/bin:$prefix/usr/bin:$PATH"
1137 AC_PATH_PROG(SDL_CONFIG, sdl-config, no, [$PATH])
1138 min_sdl_version=ifelse([$1], ,0.11.0,$1)
1139 AC_MSG_CHECKING(for SDL - version >= $min_sdl_version)
1140 no_sdl=""
1141 if test "$SDL_CONFIG" = "no" ; then
1142 no_sdl=yes
1143 else
1144 SDL_CFLAGS=`$SDL_CONFIG $sdlconf_args --cflags`
1145 SDL_LIBS=`$SDL_CONFIG $sdlconf_args --libs`
1146
1147 sdl_major_version=`$SDL_CONFIG $sdl_args --version | \
1148 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
1149 sdl_minor_version=`$SDL_CONFIG $sdl_args --version | \
1150 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
1151 sdl_micro_version=`$SDL_CONFIG $sdl_config_args --version | \
1152 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
1153 if test "x$enable_sdltest" = "xyes" ; then
1154 ac_save_CFLAGS="$CFLAGS"
6ff53182 1155 ac_save_CXXFLAGS="$CXXFLAGS"
f93ca9fd
VS
1156 ac_save_LIBS="$LIBS"
1157 CFLAGS="$CFLAGS $SDL_CFLAGS"
6ff53182 1158 CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
f93ca9fd
VS
1159 LIBS="$LIBS $SDL_LIBS"
1160dnl
1161dnl Now check if the installed SDL is sufficiently new. (Also sanity
1162dnl checks the results of sdl-config to some extent
1163dnl
1164 rm -f conf.sdltest
1165 AC_TRY_RUN([
1166#include <stdio.h>
1167#include <stdlib.h>
1168#include <string.h>
1169#include "SDL.h"
1170
1171char*
1172my_strdup (char *str)
1173{
1174 char *new_str;
1175
1176 if (str)
1177 {
1178 new_str = (char *)malloc ((strlen (str) + 1) * sizeof(char));
1179 strcpy (new_str, str);
1180 }
1181 else
1182 new_str = NULL;
1183
1184 return new_str;
1185}
1186
1187int main (int argc, char *argv[])
1188{
1189 int major, minor, micro;
1190 char *tmp_version;
1191
1192 /* This hangs on some systems (?)
1193 system ("touch conf.sdltest");
1194 */
1195 { FILE *fp = fopen("conf.sdltest", "a"); if ( fp ) fclose(fp); }
1196
1197 /* HP/UX 9 (%@#!) writes to sscanf strings */
1198 tmp_version = my_strdup("$min_sdl_version");
1199 if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
1200 printf("%s, bad version string\n", "$min_sdl_version");
1201 exit(1);
1202 }
1203
1204 if (($sdl_major_version > major) ||
1205 (($sdl_major_version == major) && ($sdl_minor_version > minor)) ||
1206 (($sdl_major_version == major) && ($sdl_minor_version == minor) && ($sdl_micro_version >= micro)))
1207 {
1208 return 0;
1209 }
1210 else
1211 {
1212 printf("\n*** 'sdl-config --version' returned %d.%d.%d, but the minimum version\n", $sdl_major_version, $sdl_minor_version, $sdl_micro_version);
1213 printf("*** of SDL required is %d.%d.%d. If sdl-config is correct, then it is\n", major, minor, micro);
1214 printf("*** best to upgrade to the required version.\n");
1215 printf("*** If sdl-config was wrong, set the environment variable SDL_CONFIG\n");
1216 printf("*** to point to the correct copy of sdl-config, and remove the file\n");
1217 printf("*** config.cache before re-running configure\n");
1218 return 1;
1219 }
1220}
1221
1222],, no_sdl=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
1223 CFLAGS="$ac_save_CFLAGS"
6ff53182 1224 CXXFLAGS="$ac_save_CXXFLAGS"
f93ca9fd
VS
1225 LIBS="$ac_save_LIBS"
1226 fi
1227 fi
1228 if test "x$no_sdl" = x ; then
1229 AC_MSG_RESULT(yes)
1230 ifelse([$2], , :, [$2])
1231 else
1232 AC_MSG_RESULT(no)
1233 if test "$SDL_CONFIG" = "no" ; then
1234 echo "*** The sdl-config script installed by SDL could not be found"
1235 echo "*** If SDL was installed in PREFIX, make sure PREFIX/bin is in"
1236 echo "*** your path, or set the SDL_CONFIG environment variable to the"
1237 echo "*** full path to sdl-config."
1238 else
1239 if test -f conf.sdltest ; then
1240 :
1241 else
1242 echo "*** Could not run SDL test program, checking why..."
1243 CFLAGS="$CFLAGS $SDL_CFLAGS"
6ff53182 1244 CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
f93ca9fd
VS
1245 LIBS="$LIBS $SDL_LIBS"
1246 AC_TRY_LINK([
1247#include <stdio.h>
1248#include "SDL.h"
1249
1250int main(int argc, char *argv[])
1251{ return 0; }
1252#undef main
1253#define main K_and_R_C_main
1254], [ return 0; ],
1255 [ echo "*** The test program compiled, but did not run. This usually means"
1256 echo "*** that the run-time linker is not finding SDL or finding the wrong"
1257 echo "*** version of SDL. If it is not finding SDL, you'll need to set your"
1258 echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
1259 echo "*** to the installed location Also, make sure you have run ldconfig if that"
1260 echo "*** is required on your system"
1261 echo "***"
1262 echo "*** If you have an old version installed, it is best to remove it, although"
1263 echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"],
1264 [ echo "*** The test program failed to compile or link. See the file config.log for the"
1265 echo "*** exact error that occured. This usually means SDL was incorrectly installed"
1266 echo "*** or that you have moved SDL since it was installed. In the latter case, you"
1267 echo "*** may want to edit the sdl-config script: $SDL_CONFIG" ])
1268 CFLAGS="$ac_save_CFLAGS"
6ff53182 1269 CXXFLAGS="$ac_save_CXXFLAGS"
f93ca9fd
VS
1270 LIBS="$ac_save_LIBS"
1271 fi
1272 fi
1273 SDL_CFLAGS=""
1274 SDL_LIBS=""
1275 ifelse([$3], , :, [$3])
1276 fi
1277 AC_SUBST(SDL_CFLAGS)
1278 AC_SUBST(SDL_LIBS)
1279 rm -f conf.sdltest
1280])
1281
fe0895cf
VS
1282dnl ---------------------------------------------------------------------------
1283dnl Support macros for makefiles generated by BAKEFILE.
1284dnl ---------------------------------------------------------------------------
1285
1286dnl Lots of compiler & linker detection code contained here was taken from
1287dnl wxWindows configure.in script (see http://www.wxwindows.org)
1288
b1d22ded
DE
1289dnl Based on autoconf _AC_LANG_COMPILER_GNU
1290AC_DEFUN([_AC_BAKEFILE_LANG_COMPILER_MWERKS],
1291[AC_CACHE_CHECK([whether we are using the Metrowerks _AC_LANG compiler],
1292 [bakefile_cv_[]_AC_LANG_ABBREV[]_compiler_mwerks],
1293 [AC_TRY_COMPILE([],[#ifndef __MWERKS__
1294 choke me
1295#endif
1296],
1297 [bakefile_compiler_mwerks=yes],
1298 [bakefile_compiler_mwerks=no])
1299 bakefile_cv_[]_AC_LANG_ABBREV[]_compiler_mwerks=$bakefile_compiler_mwerks
1300 ])
1301])
1302
1303dnl Loosely based on autoconf AC_PROG_CC
1304dnl TODO: Maybe this should wrap the call to AC_PROG_CC and be used instead.
1305AC_DEFUN([AC_BAKEFILE_PROG_MWCC],
1306[AC_LANG_PUSH(C)
1307_AC_BAKEFILE_LANG_COMPILER_MWERKS
1308MWCC=`test $bakefile_compiler_mwerks = yes && echo yes`
1309AC_LANG_POP(C)
1310])
fe0895cf 1311
b1d22ded
DE
1312dnl Loosely based on autoconf AC_PROG_CXX
1313dnl TODO: Maybe this should wrap the call to AC_PROG_CXX and be used instead.
1314AC_DEFUN([AC_BAKEFILE_PROG_MWCXX],
1315[AC_LANG_PUSH(C++)
1316_AC_BAKEFILE_LANG_COMPILER_MWERKS
1317MWCXX=`test $bakefile_compiler_mwerks = yes && echo yes`
1318AC_LANG_POP(C++)
1319])
fe0895cf
VS
1320
1321dnl ---------------------------------------------------------------------------
1322dnl AC_BAKEFILE_GNUMAKE
1323dnl
1324dnl Detects GNU make
1325dnl ---------------------------------------------------------------------------
1326
af8ebe8a 1327AC_DEFUN([AC_BAKEFILE_GNUMAKE],
fe0895cf
VS
1328[
1329 dnl does make support "-include" (only GNU make does AFAIK)?
49b0a3aa 1330 AC_CACHE_CHECK([if make is GNU make], bakefile_cv_prog_makeisgnu,
fe0895cf
VS
1331 [
1332 if ( ${SHELL-sh} -c "${MAKE-make} --version" 2> /dev/null |
1333 egrep -s GNU > /dev/null); then
1334 bakefile_cv_prog_makeisgnu="yes"
1335 else
1336 bakefile_cv_prog_makeisgnu="no"
1337 fi
1338 ])
1339
1340 if test "x$bakefile_cv_prog_makeisgnu" = "xyes"; then
1341 IF_GNU_MAKE=""
1342 else
1343 IF_GNU_MAKE="#"
1344 fi
1345 AC_SUBST(IF_GNU_MAKE)
1346])
1347
1348dnl ---------------------------------------------------------------------------
1349dnl AC_BAKEFILE_PLATFORM
1350dnl
1351dnl Detects platform and sets PLATFORM_XXX variables accordingly
1352dnl ---------------------------------------------------------------------------
1353
af8ebe8a 1354AC_DEFUN([AC_BAKEFILE_PLATFORM],
fe0895cf
VS
1355[
1356 PLATFORM_UNIX=0
1357 PLATFORM_WIN32=0
1358 PLATFORM_MSDOS=0
1359 PLATFORM_MAC=0
6ff53182 1360 PLATFORM_MACOS=0
fe0895cf 1361 PLATFORM_MACOSX=0
96c1699d 1362 PLATFORM_OS2=0
6ff53182 1363 PLATFORM_BEOS=0
f93ca9fd
VS
1364
1365 if test "x$BAKEFILE_FORCE_PLATFORM" = "x"; then
1366 case "${BAKEFILE_HOST}" in
1367 *-*-cygwin* | *-*-mingw32* )
1368 PLATFORM_WIN32=1
1369 ;;
1370 *-pc-msdosdjgpp )
1371 PLATFORM_MSDOS=1
1372 ;;
1373 *-pc-os2_emx | *-pc-os2-emx )
1374 PLATFORM_OS2=1
1375 ;;
1376 powerpc-*-darwin* )
1377 PLATFORM_MAC=1
1378 PLATFORM_MACOSX=1
6ff53182
DE
1379 ;;
1380 *-*-beos* )
1381 PLATFORM_BEOS=1
1382 ;;
1383 powerpc-apple-macos* )
1384 PLATFORM_MAC=1
1385 PLATFORM_MACOS=1
f93ca9fd
VS
1386 ;;
1387 * )
1388 PLATFORM_UNIX=1
1389 ;;
1390 esac
1391 else
1392 case "$BAKEFILE_FORCE_PLATFORM" in
1393 win32 )
1394 PLATFORM_WIN32=1
1395 ;;
1396 msdos )
1397 PLATFORM_MSDOS=1
1398 ;;
1399 os2 )
1400 PLATFORM_OS2=1
1401 ;;
1402 darwin )
1403 PLATFORM_MAC=1
1404 PLATFORM_MACOSX=1
1405 ;;
1406 unix )
1407 PLATFORM_UNIX=1
1408 ;;
6ff53182
DE
1409 beos )
1410 PLATFORM_BEOS=1
1411 ;;
f93ca9fd
VS
1412 * )
1413 AC_MSG_ERROR([Unknown platform: $BAKEFILE_FORCE_PLATFORM])
1414 ;;
1415 esac
1416 fi
fe0895cf
VS
1417
1418 AC_SUBST(PLATFORM_UNIX)
1419 AC_SUBST(PLATFORM_WIN32)
1420 AC_SUBST(PLATFORM_MSDOS)
1421 AC_SUBST(PLATFORM_MAC)
6ff53182 1422 AC_SUBST(PLATFORM_MACOS)
fe0895cf 1423 AC_SUBST(PLATFORM_MACOSX)
96c1699d 1424 AC_SUBST(PLATFORM_OS2)
6ff53182 1425 AC_SUBST(PLATFORM_BEOS)
fe0895cf
VS
1426])
1427
1428
3fd9c298
DE
1429dnl ---------------------------------------------------------------------------
1430dnl AC_BAKEFILE_PLATFORM_SPECIFICS
1431dnl
1432dnl Sets misc platform-specific settings
1433dnl ---------------------------------------------------------------------------
1434
af8ebe8a 1435AC_DEFUN([AC_BAKEFILE_PLATFORM_SPECIFICS],
3fd9c298 1436[
af8ebe8a
VS
1437 AC_ARG_ENABLE([omf], AS_HELP_STRING([--enable-omf],
1438 [use OMF object format (OS/2)]),
3fd9c298
DE
1439 [bk_os2_use_omf="$enableval"])
1440
1441 case "${BAKEFILE_HOST}" in
1442 *-*-darwin* )
1443 dnl For Unix to MacOS X porting instructions, see:
1444 dnl http://fink.sourceforge.net/doc/porting/porting.html
1445 CFLAGS="$CFLAGS -fno-common"
1446 CXXFLAGS="$CXXFLAGS -fno-common"
1447 ;;
1448
1449 *-pc-os2_emx | *-pc-os2-emx )
1450 if test "x$bk_os2_use_omf" = "xyes" ; then
1451 AR=emxomfar
1452 RANLIB=:
1453 LDFLAGS="-Zomf $LDFLAGS"
1454 CFLAGS="-Zomf $CFLAGS"
1455 CXXFLAGS="-Zomf $CXXFLAGS"
1456 OS2_LIBEXT="lib"
1457 else
1458 OS2_LIBEXT="a"
1459 fi
1460 ;;
6ff53182
DE
1461
1462 i*86-*-beos* )
1463 LDFLAGS="-L/boot/develop/lib/x86 $LDFLAGS"
1464 ;;
3fd9c298
DE
1465 esac
1466])
fe0895cf
VS
1467
1468dnl ---------------------------------------------------------------------------
1469dnl AC_BAKEFILE_SUFFIXES
1470dnl
1471dnl Detects shared various suffixes for shared libraries, libraries, programs,
1472dnl plugins etc.
1473dnl ---------------------------------------------------------------------------
1474
af8ebe8a 1475AC_DEFUN([AC_BAKEFILE_SUFFIXES],
fe0895cf
VS
1476[
1477 SO_SUFFIX="so"
131f235d 1478 SO_SUFFIX_MODULE="so"
fe0895cf 1479 EXEEXT=""
3fd9c298
DE
1480 LIBPREFIX="lib"
1481 LIBEXT=".a"
1482 DLLPREFIX="lib"
1483 DLLPREFIX_MODULE=""
1484 DLLIMP_SUFFIX=""
fe0895cf 1485
f93ca9fd 1486 case "${BAKEFILE_HOST}" in
fe0895cf
VS
1487 *-hp-hpux* )
1488 SO_SUFFIX="sl"
131f235d 1489 SO_SUFFIX_MODULE="sl"
fe0895cf
VS
1490 ;;
1491 *-*-aix* )
1492 dnl quoting from
1493 dnl http://www-1.ibm.com/servers/esdd/articles/gnu.html:
1494 dnl Both archive libraries and shared libraries on AIX have an
1495 dnl .a extension. This will explain why you can't link with an
1496 dnl .so and why it works with the name changed to .a.
1497 SO_SUFFIX="a"
131f235d 1498 SO_SUFFIX_MODULE="a"
fe0895cf
VS
1499 ;;
1500 *-*-cygwin* | *-*-mingw32* )
1501 SO_SUFFIX="dll"
131f235d 1502 SO_SUFFIX_MODULE="dll"
3fd9c298 1503 DLLIMP_SUFFIX="dll.a"
fe0895cf
VS
1504 EXEEXT=".exe"
1505 DLLPREFIX=""
1506 ;;
4b1f6360
VS
1507 *-pc-msdosdjgpp )
1508 EXEEXT=".exe"
1509 DLLPREFIX=""
1510 ;;
1511 *-pc-os2_emx | *-pc-os2-emx )
11a20c3a
SN
1512 SO_SUFFIX="dll"
1513 SO_SUFFIX_MODULE="dll"
3fd9c298 1514 DLLIMP_SUFFIX=$OS2_LIBEXT
fe0895cf
VS
1515 EXEEXT=".exe"
1516 DLLPREFIX=""
4b1f6360 1517 LIBPREFIX=""
3fd9c298 1518 LIBEXT=".$OS2_LIBEXT"
fe0895cf
VS
1519 ;;
1520 powerpc-*-darwin* )
1521 SO_SUFFIX="dylib"
131f235d 1522 SO_SUFFIX_MODULE="bundle"
fe0895cf
VS
1523 ;;
1524 esac
1525
3fd9c298
DE
1526 if test "x$DLLIMP_SUFFIX" = "x" ; then
1527 DLLIMP_SUFFIX="$SO_SUFFIX"
1528 fi
1529
fe0895cf 1530 AC_SUBST(SO_SUFFIX)
131f235d 1531 AC_SUBST(SO_SUFFIX_MODULE)
3fd9c298 1532 AC_SUBST(DLLIMP_SUFFIX)
fe0895cf 1533 AC_SUBST(EXEEXT)
4b1f6360 1534 AC_SUBST(LIBPREFIX)
3fd9c298 1535 AC_SUBST(LIBEXT)
fe0895cf 1536 AC_SUBST(DLLPREFIX)
131f235d 1537 AC_SUBST(DLLPREFIX_MODULE)
fe0895cf
VS
1538])
1539
1540
1541dnl ---------------------------------------------------------------------------
1542dnl AC_BAKEFILE_SHARED_LD
1543dnl
1544dnl Detects command for making shared libraries, substitutes SHARED_LD_CC
1545dnl and SHARED_LD_CXX.
1546dnl ---------------------------------------------------------------------------
1547
af8ebe8a 1548AC_DEFUN([AC_BAKEFILE_SHARED_LD],
fe0895cf 1549[
fe0895cf 1550 dnl the extra compiler flags needed for compilation of shared library
6ff53182 1551 PIC_FLAG=""
fe0895cf
VS
1552 if test "x$GCC" = "xyes"; then
1553 dnl the switch for gcc is the same under all platforms
1554 PIC_FLAG="-fPIC"
1555 fi
6ff53182
DE
1556
1557 dnl Defaults for GCC and ELF .so shared libs:
1558 SHARED_LD_CC="\$(CC) -shared ${PIC_FLAG} -o"
1559 SHARED_LD_CXX="\$(CXX) -shared ${PIC_FLAG} -o"
fe0895cf 1560
f93ca9fd 1561 case "${BAKEFILE_HOST}" in
fe0895cf
VS
1562 *-hp-hpux* )
1563 dnl default settings are good for gcc but not for the native HP-UX
6ff53182 1564 if test "x$GCC" != "xyes"; then
fe0895cf
VS
1565 dnl no idea why it wants it, but it does
1566 LDFLAGS="$LDFLAGS -L/usr/lib"
1567
1568 SHARED_LD_CC="${CC} -b -o"
1569 SHARED_LD_CXX="${CXX} -b -o"
1570 PIC_FLAG="+Z"
1571 fi
1572 ;;
1573
1574 *-*-linux* )
1575 if test "x$GCC" != "xyes"; then
1576 AC_CACHE_CHECK([for Intel compiler], bakefile_cv_prog_icc,
1577 [
1578 AC_TRY_COMPILE([],
1579 [
1580 #ifndef __INTEL_COMPILER
1581 #error Not icc
1582 #endif
1583 ],
1584 bakefile_cv_prog_icc=yes,
1585 bakefile_cv_prog_icc=no
1586 )
1587 ])
1588 if test "$bakefile_cv_prog_icc" = "yes"; then
1589 PIC_FLAG="-KPIC"
1590 fi
1591 fi
1592 ;;
1593
1594 *-*-solaris2* )
1595 if test "x$GCC" != xyes ; then
1596 SHARED_LD_CC="${CC} -G -o"
1597 SHARED_LD_CXX="${CXX} -G -o"
1598 PIC_FLAG="-KPIC"
1599 fi
1600 ;;
1601
1602 *-*-darwin* )
fe0895cf
VS
1603 dnl Most apps benefit from being fully binded (its faster and static
1604 dnl variables initialized at startup work).
1605 dnl This can be done either with the exe linker flag -Wl,-bind_at_load
1606 dnl or with a double stage link in order to create a single module
1607 dnl "-init _wxWindowsDylibInit" not useful with lazy linking solved
1608
2a879853
VS
1609 dnl If using newer dev tools then there is a -single_module flag that
1610 dnl we can use to do this, otherwise we'll need to use a helper
1611 dnl script. Check the version of gcc to see which way we can go:
1612 AC_CACHE_CHECK([for gcc 3.1 or later], wx_cv_gcc31, [
1613 AC_TRY_COMPILE([],
1614 [
1615 #if (__GNUC__ < 3) || \
1616 ((__GNUC__ == 3) && (__GNUC_MINOR__ < 1))
1617 #error old gcc
1618 #endif
1619 ],
1620 [
1621 wx_cv_gcc31=yes
1622 ],
1623 [
1624 wx_cv_gcc31=no
1625 ]
1626 )
1627 ])
1628 if test "$wx_cv_gcc31" = "no"; then
3fd9c298 1629 AC_BAKEFILE_CREATE_FILE_SHARED_LD_SH
43948499
RD
1630 chmod +x shared-ld-sh
1631
2a879853 1632 dnl Use the shared-ld-sh helper script
7f523214
VS
1633 SHARED_LD_CC="`pwd`/shared-ld-sh -dynamiclib -headerpad_max_install_names -o"
1634 SHARED_LD_MODULE_CC="`pwd`/shared-ld-sh -bundle -headerpad_max_install_names -o"
2a879853
VS
1635 SHARED_LD_CXX="$SHARED_LD_CC"
1636 SHARED_LD_MODULE_CXX="$SHARED_LD_MODULE_CC"
1637 else
1638 dnl Use the -single_module flag and let the linker do it for us
7f523214
VS
1639 SHARED_LD_CC="\${CC} -dynamiclib -single_module -headerpad_max_install_names -o"
1640 SHARED_LD_MODULE_CC="\${CC} -bundle -single_module -headerpad_max_install_names -o"
1641 SHARED_LD_CXX="\${CXX} -dynamiclib -single_module -headerpad_max_install_names -o"
1642 SHARED_LD_MODULE_CXX="\${CXX} -bundle -single_module -headerpad_max_install_names -o"
2a879853
VS
1643 fi
1644
fe0895cf 1645 PIC_FLAG="-dynamic -fPIC"
fe0895cf
VS
1646 ;;
1647
1648 *-*-aix* )
1649 dnl default settings are ok for gcc
1650 if test "x$GCC" != "xyes"; then
1651 dnl the abs path below used to be hardcoded here so I guess it must
1652 dnl be some sort of standard location under AIX?
1653 AC_CHECK_PROG(AIX_CXX_LD, makeC++SharedLib,
1654 makeC++SharedLib, /usr/lpp/xlC/bin/makeC++SharedLib)
1655 dnl FIXME - what about makeCSharedLib?
1656 SHARED_LD_CC="$AIX_CC_LD -p 0 -o"
1657 SHARED_LD_CXX="$AIX_CXX_LD -p 0 -o"
1658 fi
1659 ;;
1660
1661 *-*-beos* )
1662 dnl can't use gcc under BeOS for shared library creation because it
1663 dnl complains about missing 'main'
6ff53182
DE
1664 SHARED_LD_CC="${LD} -nostart -o"
1665 SHARED_LD_CXX="${LD} -nostart -o"
fe0895cf
VS
1666 ;;
1667
1668 *-*-irix* )
1669 dnl default settings are ok for gcc
1670 if test "x$GCC" != "xyes"; then
1671 PIC_FLAG="-KPIC"
1672 fi
1673 ;;
1674
1675 *-*-cygwin* | *-*-mingw32* )
1676 PIC_FLAG=""
6ff53182
DE
1677 SHARED_LD_CC="\$(CC) -shared -o"
1678 SHARED_LD_CXX="\$(CXX) -shared -o"
fe0895cf 1679 ;;
3fd9c298 1680
11a20c3a 1681 *-pc-os2_emx | *-pc-os2-emx )
b1d22ded
DE
1682 SHARED_LD_CC="`pwd`/dllar.sh -libf INITINSTANCE -libf TERMINSTANCE -o"
1683 SHARED_LD_CXX="`pwd`/dllar.sh -libf INITINSTANCE -libf TERMINSTANCE -o"
11a20c3a 1684 PIC_FLAG=""
3fd9c298
DE
1685 AC_BAKEFILE_CREATE_FILE_DLLAR_SH
1686 chmod +x dllar.sh
11a20c3a
SN
1687 ;;
1688
6ff53182 1689 powerpc-apple-macos* | \
fe0895cf
VS
1690 *-*-freebsd* | *-*-openbsd* | *-*-netbsd* | \
1691 *-*-sunos4* | \
1692 *-*-osf* | \
1693 *-*-dgux5* | \
d5fc095c 1694 *-*-sysv5* )
fe0895cf
VS
1695 dnl defaults are ok
1696 ;;
1697
1698 *)
f93ca9fd 1699 AC_MSG_ERROR(unknown system type $BAKEFILE_HOST.)
fe0895cf
VS
1700 esac
1701
af8ebe8a
VS
1702 if test "x$PIC_FLAG" != "x" ; then
1703 PIC_FLAG="$PIC_FLAG -DPIC"
1704 fi
1705
131f235d
VS
1706 if test "x$SHARED_LD_MODULE_CC" = "x" ; then
1707 SHARED_LD_MODULE_CC="$SHARED_LD_CC"
1708 fi
1709 if test "x$SHARED_LD_MODULE_CXX" = "x" ; then
239394fb 1710 SHARED_LD_MODULE_CXX="$SHARED_LD_CXX"
131f235d
VS
1711 fi
1712
fe0895cf
VS
1713 AC_SUBST(SHARED_LD_CC)
1714 AC_SUBST(SHARED_LD_CXX)
131f235d
VS
1715 AC_SUBST(SHARED_LD_MODULE_CC)
1716 AC_SUBST(SHARED_LD_MODULE_CXX)
fe0895cf
VS
1717 AC_SUBST(PIC_FLAG)
1718])
1719
1720
1721dnl ---------------------------------------------------------------------------
1722dnl AC_BAKEFILE_SHARED_VERSIONS
1723dnl
1724dnl Detects linker options for attaching versions (sonames) to shared libs.
1725dnl ---------------------------------------------------------------------------
1726
af8ebe8a 1727AC_DEFUN([AC_BAKEFILE_SHARED_VERSIONS],
fe0895cf
VS
1728[
1729 USE_SOVERSION=0
1730 USE_SOVERLINUX=0
1731 USE_SOVERSOLARIS=0
1732 USE_SOSYMLINKS=0
1733 USE_MACVERSION=0
1734 SONAME_FLAG=
1735
f93ca9fd 1736 case "${BAKEFILE_HOST}" in
b1d22ded 1737 *-*-linux* | *-*-freebsd* )
5f652d0d
VS
1738 SONAME_FLAG="-Wl,-soname,"
1739 USE_SOVERSION=1
1740 USE_SOVERLINUX=1
1741 USE_SOSYMLINKS=1
1742 ;;
fe0895cf
VS
1743
1744 *-*-solaris2* )
1745 SONAME_FLAG="-h "
1746 USE_SOVERSION=1
1747 USE_SOVERSOLARIS=1
1748 USE_SOSYMLINKS=1
1749 ;;
1750
1751 *-*-darwin* )
1752 USE_MACVERSION=1
1753 USE_SOVERSION=1
1754 USE_SOSYMLINKS=1
1755 ;;
1756 esac
1757
1758 AC_SUBST(USE_SOVERSION)
1759 AC_SUBST(USE_SOVERLINUX)
1760 AC_SUBST(USE_SOVERSOLARIS)
1761 AC_SUBST(USE_MACVERSION)
1762 AC_SUBST(USE_SOSYMLINKS)
1763 AC_SUBST(SONAME_FLAG)
1764])
1765
1766
1767dnl ---------------------------------------------------------------------------
1768dnl AC_BAKEFILE_DEPS
1769dnl
1770dnl Detects available C/C++ dependency tracking options
1771dnl ---------------------------------------------------------------------------
1772
af8ebe8a 1773AC_DEFUN([AC_BAKEFILE_DEPS],
fe0895cf 1774[
49b0a3aa
VS
1775 AC_MSG_CHECKING([for dependency tracking method])
1776 DEPS_TRACKING=0
1777
fe0895cf 1778 if test "x$GCC" = "xyes"; then
49b0a3aa
VS
1779 DEPSMODE=gcc
1780 DEPS_TRACKING=1
f93ca9fd 1781 case "${BAKEFILE_HOST}" in
3e5c3c83
VS
1782 powerpc-*-darwin* )
1783 dnl -cpp-precomp (the default) conflicts with -MMD option
1784 dnl used by bk-deps (see also http://developer.apple.com/documentation/Darwin/Conceptual/PortingUnix/compiling/chapter_4_section_3.html)
1785 DEPSFLAG_GCC="-no-cpp-precomp -MMD"
1786 ;;
1787 * )
1788 DEPSFLAG_GCC="-MMD"
1789 ;;
1790 esac
49b0a3aa 1791 AC_MSG_RESULT([gcc])
b1d22ded
DE
1792 elif test "x$MWCC" = "xyes"; then
1793 DEPSMODE=mwcc
1794 DEPS_TRACKING=1
1795 DEPSFLAG_MWCC="-MM"
1796 AC_MSG_RESULT([mwcc])
49b0a3aa
VS
1797 else
1798 AC_MSG_RESULT([none])
1799 fi
1800
1801 if test $DEPS_TRACKING = 1 ; then
3fd9c298 1802 AC_BAKEFILE_CREATE_FILE_BK_DEPS
49b0a3aa 1803 chmod +x bk-deps
fe0895cf
VS
1804 fi
1805
49b0a3aa 1806 AC_SUBST(DEPS_TRACKING)
fe0895cf
VS
1807])
1808
1809dnl ---------------------------------------------------------------------------
1810dnl AC_BAKEFILE_CHECK_BASIC_STUFF
1811dnl
1812dnl Checks for presence of basic programs, such as C and C++ compiler, "ranlib"
1813dnl or "install"
1814dnl ---------------------------------------------------------------------------
1815
af8ebe8a 1816AC_DEFUN([AC_BAKEFILE_CHECK_BASIC_STUFF],
fe0895cf
VS
1817[
1818 AC_PROG_RANLIB
1819 AC_PROG_INSTALL
1820 AC_PROG_LN_S
1821
1822 AC_PROG_MAKE_SET
1823 AC_SUBST(MAKE_SET)
1824
874d12cf
VS
1825 AC_CHECK_TOOL(AR, ar, ar)
1826 AC_CHECK_TOOL(STRIP, strip, :)
1827 AC_CHECK_TOOL(NM, nm, :)
fe0895cf 1828
f93ca9fd 1829 case ${BAKEFILE_HOST} in
fe0895cf 1830 *-hp-hpux* )
6ff53182
DE
1831 dnl HP-UX install doesn't handle the "-d" switch so don't
1832 dnl use it there
af8ebe8a 1833 INSTALL_DIR="mkdir -p"
fe0895cf
VS
1834 ;;
1835 *) INSTALL_DIR="$INSTALL -d"
1836 ;;
1837 esac
1838 AC_SUBST(INSTALL_DIR)
6b9d41a5
VS
1839
1840 LDFLAGS_GUI=
f93ca9fd 1841 case ${BAKEFILE_HOST} in
6b9d41a5 1842 *-*-cygwin* | *-*-mingw32* )
3fd9c298 1843 LDFLAGS_GUI="-mwindows"
6b9d41a5
VS
1844 esac
1845 AC_SUBST(LDFLAGS_GUI)
fe0895cf
VS
1846])
1847
1848
1849dnl ---------------------------------------------------------------------------
1850dnl AC_BAKEFILE_RES_COMPILERS
1851dnl
1852dnl Checks for presence of resource compilers for win32 or mac
1853dnl ---------------------------------------------------------------------------
1854
af8ebe8a 1855AC_DEFUN([AC_BAKEFILE_RES_COMPILERS],
fe0895cf
VS
1856[
1857 RESCOMP=
1858 SETFILE=
1859
f93ca9fd 1860 case ${BAKEFILE_HOST} in
fe0895cf
VS
1861 *-*-cygwin* | *-*-mingw32* )
1862 dnl Check for win32 resources compiler:
1863 if test "$build" != "$host" ; then
1864 RESCOMP=$host_alias-windres
1865 else
1866 AC_CHECK_PROG(RESCOMP, windres, windres, windres)
1867 fi
1868 ;;
1869
6ff53182 1870 *-*-darwin* | powerpc-apple-macos* )
fe0895cf
VS
1871 AC_CHECK_PROG(RESCOMP, Rez, Rez, /Developer/Tools/Rez)
1872 AC_CHECK_PROG(SETFILE, SetFile, SetFile, /Developer/Tools/SetFile)
1873 ;;
1874 esac
1875
1876 AC_SUBST(RESCOMP)
1877 AC_SUBST(SETFILE)
1878])
1879
45842500
VS
1880dnl ---------------------------------------------------------------------------
1881dnl AC_BAKEFILE_PRECOMP_HEADERS
1882dnl
1883dnl Check for precompiled headers support (GCC >= 3.4)
1884dnl ---------------------------------------------------------------------------
1885
af8ebe8a 1886AC_DEFUN([AC_BAKEFILE_PRECOMP_HEADERS],
45842500
VS
1887[
1888
1889 AC_ARG_ENABLE([precomp-headers],
af8ebe8a
VS
1890 AS_HELP_STRING([--disable-precomp-headers],
1891 [don't use precompiled headers even if compiler can]),
45842500
VS
1892 [bk_use_pch="$enableval"])
1893
1894 GCC_PCH=0
1895
1896 if test "x$bk_use_pch" = "x" -o "x$bk_use_pch" = "xyes" ; then
1897 if test "x$GCC" = "xyes"; then
1898 dnl test if we have gcc-3.4:
1899 AC_MSG_CHECKING([if the compiler supports precompiled headers])
1900 AC_TRY_COMPILE([],
1901 [
e06468e8
VS
1902 #if !defined(__GNUC__) || !defined(__GNUC_MINOR__)
1903 #error "no pch support"
1904 #endif
1905 #if (__GNUC__ < 3)
1906 #error "no pch support"
1907 #endif
1908 #if (__GNUC__ == 3) && \
1909 ((!defined(__APPLE_CC__) && (__GNUC_MINOR__ < 4)) || \
1910 ( defined(__APPLE_CC__) && (__GNUC_MINOR__ < 3)))
1911 #error "no pch support"
45842500
VS
1912 #endif
1913 ],
1914 [
1915 AC_MSG_RESULT([yes])
45842500
VS
1916 GCC_PCH=1
1917 ],
1918 [
1919 AC_MSG_RESULT([no])
1920 ])
1921 if test $GCC_PCH = 1 ; then
6ff53182 1922 AC_BAKEFILE_CREATE_FILE_BK_MAKE_PCH
45842500
VS
1923 chmod +x bk-make-pch
1924 fi
1925 fi
1926 fi
1927
1928 AC_SUBST(GCC_PCH)
1929])
1930
1931
1932
fe0895cf
VS
1933dnl ---------------------------------------------------------------------------
1934dnl AC_BAKEFILE
1935dnl
1936dnl To be used in configure.in of any project using Bakefile-generated mks
f93ca9fd
VS
1937dnl
1938dnl Behaviour can be modified by setting following variables:
1939dnl BAKEFILE_CHECK_BASICS set to "no" if you don't want bakefile to
1940dnl to perform check for basic tools like ranlib
1941dnl BAKEFILE_HOST set this to override host detection, defaults
1942dnl to ${host}
1943dnl BAKEFILE_FORCE_PLATFORM set to override platform detection
fe0895cf
VS
1944dnl ---------------------------------------------------------------------------
1945
af8ebe8a 1946AC_DEFUN([AC_BAKEFILE],
fe0895cf 1947[
6ff53182
DE
1948 AC_PREREQ(2.58)
1949
f93ca9fd
VS
1950 if test "x$BAKEFILE_HOST" = "x"; then
1951 BAKEFILE_HOST="${host}"
1952 fi
1953
fe0895cf
VS
1954 if test "x$BAKEFILE_CHECK_BASICS" != "xno"; then
1955 AC_BAKEFILE_CHECK_BASIC_STUFF
1956 fi
1957 AC_BAKEFILE_GNUMAKE
1958 AC_BAKEFILE_PLATFORM
3fd9c298 1959 AC_BAKEFILE_PLATFORM_SPECIFICS
fe0895cf
VS
1960 AC_BAKEFILE_SUFFIXES
1961 AC_BAKEFILE_SHARED_LD
1962 AC_BAKEFILE_SHARED_VERSIONS
1963 AC_BAKEFILE_DEPS
1964 AC_BAKEFILE_RES_COMPILERS
1965
af8ebe8a
VS
1966 BAKEFILE_BAKEFILE_M4_VERSION="0.1.4"
1967
b1d22ded 1968 m4_include([autoconf_inc.m4])
af8ebe8a
VS
1969
1970 if test "$BAKEFILE_BAKEFILE_M4_VERSION" != "$BAKEFILE_AUTOCONF_INC_M4_VERSION" ; then
1971 AC_MSG_ERROR([Versions of Bakefile used to generate makefiles ($BAKEFILE_AUTOCONF_INC_M4_VERSION) and configure ($BAKEFILE_BAKEFILE_M4_VERSION) do not match.])
1972 fi
fe0895cf 1973])
3fd9c298
DE
1974
1975
1976dnl ---------------------------------------------------------------------------
1977dnl Embedded copies of helper scripts follow:
1978dnl ---------------------------------------------------------------------------
1979
af8ebe8a 1980AC_DEFUN([AC_BAKEFILE_CREATE_FILE_DLLAR_SH],
3fd9c298
DE
1981[
1982dnl ===================== dllar.sh begins here =====================
1983D='$'
1984cat <<EOF >dllar.sh
1985#!/bin/sh
1986#
1987# dllar - a tool to build both a .dll and an .a file
1988# from a set of object (.o) files for EMX/OS2.
1989#
1990# Written by Andrew Zabolotny, bit@freya.etu.ru
1991# Ported to Unix like shell by Stefan Neis, Stefan.Neis@t-online.de
1992#
1993# This script will accept a set of files on the command line.
1994# All the public symbols from the .o files will be exported into
1995# a .DEF file, then linker will be run (through gcc) against them to
1996# build a shared library consisting of all given .o files. All libraries
1997# (.a) will be first decompressed into component .o files then act as
1998# described above. You can optionally give a description (-d "description")
1999# which will be put into .DLL. To see the list of accepted options (as well
2000# as command-line format) simply run this program without options. The .DLL
2001# is built to be imported by name (there is no guarantee that new versions
2002# of the library you build will have same ordinals for same symbols).
2003#
2004# dllar is free software; you can redistribute it and/or modify
2005# it under the terms of the GNU General Public License as published by
2006# the Free Software Foundation; either version 2, or (at your option)
2007# any later version.
2008#
2009# dllar is distributed in the hope that it will be useful,
2010# but WITHOUT ANY WARRANTY; without even the implied warranty of
2011# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2012# GNU General Public License for more details.
2013#
2014# You should have received a copy of the GNU General Public License
2015# along with dllar; see the file COPYING. If not, write to the Free
2016# Software Foundation, 59 Temple Place - Suite 330, Boston, MA
2017# 02111-1307, USA.
2018
2019# To successfuly run this program you will need:
2020# - Current drive should have LFN support (HPFS, ext2, network, etc)
2021# (Sometimes dllar generates filenames which won't fit 8.3 scheme)
2022# - gcc
2023# (used to build the .dll)
2024# - emxexp
2025# (used to create .def file from .o files)
2026# - emximp
2027# (used to create .a file from .def file)
2028# - GNU text utilites (cat, sort, uniq)
2029# used to process emxexp output
2030# - GNU file utilities (mv, rm)
2031# - GNU sed
2032# - lxlite (optional, see flag below)
2033# (used for general .dll cleanup)
2034#
2035
2036flag_USE_LXLITE=1;
2037
2038#
2039# helper functions
2040# basnam, variant of basename, which does _not_ remove the path, _iff_
2041# second argument (suffix to remove) is given
2042basnam(){
2043 case ${D}# in
2044 1)
6ff53182 2045 echo ${D}1 | sed 's/.*\\///' | sed 's/.*\\\\//'
3fd9c298
DE
2046 ;;
2047 2)
2048 echo ${D}1 | sed 's/'${D}2'${D}//'
2049 ;;
2050 *)
2051 echo "error in basnam ${D}*"
2052 exit 8
2053 ;;
2054 esac
2055}
2056
2057# Cleanup temporary files and output
2058CleanUp() {
2059 cd ${D}curDir
2060 for i in ${D}inputFiles ; do
2061 case ${D}i in
2062 *!)
2063 rm -rf \`basnam ${D}i !\`
2064 ;;
2065 *)
2066 ;;
2067 esac
2068 done
2069
2070 # Kill result in case of failure as there is just to many stupid make/nmake
2071 # things out there which doesn't do this.
6ff53182 2072 if @<:@ ${D}# -eq 0 @:>@; then
3fd9c298
DE
2073 rm -f ${D}arcFile ${D}arcFile2 ${D}defFile ${D}dllFile
2074 fi
2075}
2076
2077# Print usage and exit script with rc=1.
2078PrintHelp() {
b1d22ded
DE
2079 echo 'Usage: dllar.sh @<:@-o@<:@utput@:>@ output_file@:>@ @<:@-i@<:@mport@:>@ importlib_name@:>@'
2080 echo ' @<:@-name-mangler-script script.sh@:>@'
2081 echo ' @<:@-d@<:@escription@:>@ "dll descrption"@:>@ @<:@-cc "CC"@:>@ @<:@-f@<:@lags@:>@ "CFLAGS"@:>@'
2082 echo ' @<:@-ord@<:@inals@:>@@:>@ -ex@<:@clude@:>@ "symbol(s)"'
2083 echo ' @<:@-libf@<:@lags@:>@ "{INIT|TERM}{GLOBAL|INSTANCE}"@:>@ @<:@-nocrt@<:@dll@:>@@:>@ @<:@-nolxl@<:@ite@:>@@:>@'
6ff53182 2084 echo ' @<:@*.o@:>@ @<:@*.a@:>@'
3fd9c298
DE
2085 echo '*> "output_file" should have no extension.'
2086 echo ' If it has the .o, .a or .dll extension, it is automatically removed.'
2087 echo ' The import library name is derived from this and is set to "name".a,'
2088 echo ' unless overridden by -import'
2089 echo '*> "importlib_name" should have no extension.'
2090 echo ' If it has the .o, or .a extension, it is automatically removed.'
2091 echo ' This name is used as the import library name and may be longer and'
2092 echo ' more descriptive than the DLL name which has to follow the old '
2093 echo ' 8.3 convention of FAT.'
b1d22ded
DE
2094 echo '*> "script.sh may be given to override the output_file name by a'
2095 echo ' different name. It is mainly useful if the regular make process'
2096 echo ' of some package does not take into account OS/2 restriction of'
2097 echo ' DLL name lengths. It takes the importlib name as input and is'
2098 echo ' supposed to procude a shorter name as output. The script should'
2099 echo ' expect to get importlib_name without extension and should produce'
2100 echo ' a (max.) 8 letter name without extension.'
3fd9c298
DE
2101 echo '*> "cc" is used to use another GCC executable. (default: gcc.exe)'
2102 echo '*> "flags" should be any set of valid GCC flags. (default: -s -Zcrtdll)'
2103 echo ' These flags will be put at the start of GCC command line.'
b1d22ded
DE
2104 echo '*> -ord@<:@inals@:>@ tells dllar to export entries by ordinals. Be careful.'
2105 echo '*> -ex@<:@clude@:>@ defines symbols which will not be exported. You can define'
3fd9c298
DE
2106 echo ' multiple symbols, for example -ex "myfunc yourfunc _GLOBAL*".'
2107 echo ' If the last character of a symbol is "*", all symbols beginning'
2108 echo ' with the prefix before "*" will be exclude, (see _GLOBAL* above).'
b1d22ded 2109 echo '*> -libf@<:@lags@:>@ can be used to add INITGLOBAL/INITINSTANCE and/or'
3fd9c298 2110 echo ' TERMGLOBAL/TERMINSTANCE flags to the dynamically-linked library.'
b1d22ded 2111 echo '*> -nocrt@<:@dll@:>@ switch will disable linking the library against emx''s'
3fd9c298 2112 echo ' C runtime DLLs.'
b1d22ded 2113 echo '*> -nolxl@<:@ite@:>@ switch will disable running lxlite on the resulting DLL.'
3fd9c298
DE
2114 echo '*> All other switches (for example -L./ or -lmylib) will be passed'
2115 echo ' unchanged to GCC at the end of command line.'
2116 echo '*> If you create a DLL from a library and you do not specify -o,'
2117 echo ' the basename for DLL and import library will be set to library name,'
2118 echo ' the initial library will be renamed to 'name'_s.a (_s for static)'
2119 echo ' i.e. "dllar gcc.a" will create gcc.dll and gcc.a, and the initial'
2120 echo ' library will be renamed into gcc_s.a.'
2121 echo '--------'
2122 echo 'Example:'
2123 echo ' dllar -o gcc290.dll libgcc.a -d "GNU C runtime library" -ord'
2124 echo ' -ex "__main __ctordtor*" -libf "INITINSTANCE TERMINSTANCE"'
2125 CleanUp
2126 exit 1
2127}
2128
2129# Execute a command.
2130# If exit code of the commnad <> 0 CleanUp() is called and we'll exit the script.
2131# @Uses Whatever CleanUp() uses.
2132doCommand() {
2133 echo "${D}*"
2134 eval ${D}*
2135 rcCmd=${D}?
2136
6ff53182 2137 if @<:@ ${D}rcCmd -ne 0 @:>@; then
3fd9c298
DE
2138 echo "command failed, exit code="${D}rcCmd
2139 CleanUp
2140 exit ${D}rcCmd
2141 fi
2142}
2143
2144# main routine
2145# setup globals
2146cmdLine=${D}*
2147outFile=""
2148outimpFile=""
2149inputFiles=""
b1d22ded 2150renameScript=""
3fd9c298
DE
2151description=""
2152CC=gcc.exe
2153CFLAGS="-s -Zcrtdll"
2154EXTRA_CFLAGS=""
2155EXPORT_BY_ORDINALS=0
2156exclude_symbols=""
2157library_flags=""
2158curDir=\`pwd\`
2159curDirS=curDir
2160case ${D}curDirS in
2161*/)
2162 ;;
2163*)
2164 curDirS=${D}{curDirS}"/"
2165 ;;
2166esac
2167# Parse commandline
2168libsToLink=0
b1d22ded 2169omfLinking=0
6ff53182 2170while @<:@ ${D}1 @:>@; do
3fd9c298
DE
2171 case ${D}1 in
2172 -ord*)
2173 EXPORT_BY_ORDINALS=1;
2174 ;;
2175 -o*)
2176 shift
2177 outFile=${D}1
2178 ;;
2179 -i*)
2180 shift
2181 outimpFile=${D}1
2182 ;;
b1d22ded
DE
2183 -name-mangler-script)
2184 shift
2185 renameScript=${D}1
2186 ;;
3fd9c298
DE
2187 -d*)
2188 shift
2189 description=${D}1
2190 ;;
2191 -f*)
2192 shift
2193 CFLAGS=${D}1
2194 ;;
2195 -c*)
2196 shift
2197 CC=${D}1
2198 ;;
2199 -h*)
2200 PrintHelp
2201 ;;
2202 -ex*)
2203 shift
2204 exclude_symbols=${D}{exclude_symbols}${D}1" "
2205 ;;
2206 -libf*)
2207 shift
2208 library_flags=${D}{library_flags}${D}1" "
2209 ;;
2210 -nocrt*)
2211 CFLAGS="-s"
2212 ;;
2213 -nolxl*)
2214 flag_USE_LXLITE=0
2215 ;;
2216 -* | /*)
2217 case ${D}1 in
2218 -L* | -l*)
2219 libsToLink=1
2220 ;;
b1d22ded
DE
2221 -Zomf)
2222 omfLinking=1
2223 ;;
3fd9c298
DE
2224 *)
2225 ;;
2226 esac
2227 EXTRA_CFLAGS=${D}{EXTRA_CFLAGS}" "${D}1
2228 ;;
b1d22ded
DE
2229 *.dll)
2230 EXTRA_CFLAGS="${D}{EXTRA_CFLAGS} \`basnam ${D}1 .dll\`"
2231 if @<:@ ${D}omfLinking -eq 1 @:>@; then
2232 EXTRA_CFLAGS="${D}{EXTRA_CFLAGS}.lib"
2233 else
2234 EXTRA_CFLAGS="${D}{EXTRA_CFLAGS}.a"
2235 fi
2236 ;;
3fd9c298
DE
2237 *)
2238 found=0;
6ff53182 2239 if @<:@ ${D}libsToLink -ne 0 @:>@; then
3fd9c298
DE
2240 EXTRA_CFLAGS=${D}{EXTRA_CFLAGS}" "${D}1
2241 else
2242 for file in ${D}1 ; do
6ff53182 2243 if @<:@ -f ${D}file @:>@; then
3fd9c298
DE
2244 inputFiles="${D}{inputFiles} ${D}file"
2245 found=1
2246 fi
2247 done
6ff53182 2248 if @<:@ ${D}found -eq 0 @:>@; then
3fd9c298
DE
2249 echo "ERROR: No file(s) found: "${D}1
2250 exit 8
2251 fi
2252 fi
2253 ;;
2254 esac
2255 shift
2256done # iterate cmdline words
2257
2258#
6ff53182 2259if @<:@ -z "${D}inputFiles" @:>@; then
3fd9c298
DE
2260 echo "dllar: no input files"
2261 PrintHelp
2262fi
2263
2264# Now extract all .o files from .a files
2265newInputFiles=""
2266for file in ${D}inputFiles ; do
2267 case ${D}file in
2268 *.a | *.lib)
2269 case ${D}file in
2270 *.a)
2271 suffix=".a"
2272 AR="ar"
2273 ;;
2274 *.lib)
2275 suffix=".lib"
2276 AR="emxomfar"
2277 EXTRA_CFLAGS="${D}EXTRA_CFLAGS -Zomf"
2278 ;;
2279 *)
2280 ;;
2281 esac
2282 dirname=\`basnam ${D}file ${D}suffix\`"_%"
2283 mkdir ${D}dirname
6ff53182 2284 if @<:@ ${D}? -ne 0 @:>@; then
3fd9c298
DE
2285 echo "Failed to create subdirectory ./${D}dirname"
2286 CleanUp
2287 exit 8;
2288 fi
2289 # Append '!' to indicate archive
2290 newInputFiles="${D}newInputFiles ${D}{dirname}!"
2291 doCommand "cd ${D}dirname; ${D}AR x ../${D}file"
2292 cd ${D}curDir
2293 found=0;
2294 for subfile in ${D}dirname/*.o* ; do
6ff53182 2295 if @<:@ -f ${D}subfile @:>@; then
3fd9c298 2296 found=1
6ff53182 2297 if @<:@ -s ${D}subfile @:>@; then
3fd9c298
DE
2298 # FIXME: This should be: is file size > 32 byte, _not_ > 0!
2299 newInputFiles="${D}newInputFiles ${D}subfile"
2300 fi
2301 fi
2302 done
6ff53182
DE
2303 if @<:@ ${D}found -eq 0 @:>@; then
2304 echo "WARNING: there are no files in archive \\'${D}file\\'"
3fd9c298
DE
2305 fi
2306 ;;
2307 *)
2308 newInputFiles="${D}{newInputFiles} ${D}file"
2309 ;;
2310 esac
2311done
2312inputFiles="${D}newInputFiles"
2313
2314# Output filename(s).
2315do_backup=0;
6ff53182 2316if @<:@ -z ${D}outFile @:>@; then
3fd9c298
DE
2317 do_backup=1;
2318 set outFile ${D}inputFiles; outFile=${D}2
2319fi
2320
2321# If it is an archive, remove the '!' and the '_%' suffixes
2322case ${D}outFile in
2323*_%!)
2324 outFile=\`basnam ${D}outFile _%!\`
2325 ;;
2326*)
2327 ;;
2328esac
2329case ${D}outFile in
2330*.dll)
2331 outFile=\`basnam ${D}outFile .dll\`
2332 ;;
2333*.DLL)
2334 outFile=\`basnam ${D}outFile .DLL\`
2335 ;;
2336*.o)
2337 outFile=\`basnam ${D}outFile .o\`
2338 ;;
2339*.obj)
2340 outFile=\`basnam ${D}outFile .obj\`
2341 ;;
2342*.a)
2343 outFile=\`basnam ${D}outFile .a\`
2344 ;;
2345*.lib)
2346 outFile=\`basnam ${D}outFile .lib\`
2347 ;;
2348*)
2349 ;;
2350esac
2351case ${D}outimpFile in
2352*.a)
2353 outimpFile=\`basnam ${D}outimpFile .a\`
2354 ;;
2355*.lib)
2356 outimpFile=\`basnam ${D}outimpFile .lib\`
2357 ;;
2358*)
2359 ;;
2360esac
6ff53182 2361if @<:@ -z ${D}outimpFile @:>@; then
3fd9c298
DE
2362 outimpFile=${D}outFile
2363fi
2364defFile="${D}{outFile}.def"
2365arcFile="${D}{outimpFile}.a"
2366arcFile2="${D}{outimpFile}.lib"
b1d22ded
DE
2367
2368#create ${D}dllFile as something matching 8.3 restrictions,
2369if @<:@ -z ${D}renameScript @:>@ ; then
2370 dllFile="${D}outFile"
2371else
2372 dllFile=\`${D}renameScript ${D}outimpFile\`
2373fi
3fd9c298 2374
6ff53182
DE
2375if @<:@ ${D}do_backup -ne 0 @:>@ ; then
2376 if @<:@ -f ${D}arcFile @:>@ ; then
3fd9c298
DE
2377 doCommand "mv ${D}arcFile ${D}{outFile}_s.a"
2378 fi
6ff53182 2379 if @<:@ -f ${D}arcFile2 @:>@ ; then
3fd9c298
DE
2380 doCommand "mv ${D}arcFile2 ${D}{outFile}_s.lib"
2381 fi
2382fi
2383
2384# Extract public symbols from all the object files.
2385tmpdefFile=${D}{defFile}_%
2386rm -f ${D}tmpdefFile
2387for file in ${D}inputFiles ; do
2388 case ${D}file in
2389 *!)
2390 ;;
2391 *)
2392 doCommand "emxexp -u ${D}file >> ${D}tmpdefFile"
2393 ;;
2394 esac
2395done
2396
2397# Create the def file.
2398rm -f ${D}defFile
2399echo "LIBRARY \`basnam ${D}dllFile\` ${D}library_flags" >> ${D}defFile
b1d22ded
DE
2400dllFile="${D}{dllFile}.dll"
2401if @<:@ ! -z ${D}description @:>@; then
6ff53182 2402 echo "DESCRIPTION \\"${D}{description}\\"" >> ${D}defFile
3fd9c298
DE
2403fi
2404echo "EXPORTS" >> ${D}defFile
2405
2406doCommand "cat ${D}tmpdefFile | sort.exe | uniq.exe > ${D}{tmpdefFile}%"
2407grep -v "^ *;" < ${D}{tmpdefFile}% | grep -v "^ *${D}" >${D}tmpdefFile
2408
2409# Checks if the export is ok or not.
2410for word in ${D}exclude_symbols; do
2411 grep -v ${D}word < ${D}tmpdefFile >${D}{tmpdefFile}%
2412 mv ${D}{tmpdefFile}% ${D}tmpdefFile
2413done
2414
2415
6ff53182
DE
2416if @<:@ ${D}EXPORT_BY_ORDINALS -ne 0 @:>@; then
2417 sed "=" < ${D}tmpdefFile | \\
3fd9c298
DE
2418 sed '
2419 N
2420 : loop
6ff53182 2421 s/^\\(@<:@0-9@:>@\\+\\)\\(@<:@^;@:>@*\\)\\(;.*\\)\\?/\\2 @\\1 NONAME/
3fd9c298
DE
2422 t loop
2423 ' > ${D}{tmpdefFile}%
2424 grep -v "^ *${D}" < ${D}{tmpdefFile}% > ${D}tmpdefFile
2425else
2426 rm -f ${D}{tmpdefFile}%
2427fi
2428cat ${D}tmpdefFile >> ${D}defFile
2429rm -f ${D}tmpdefFile
2430
2431# Do linking, create implib, and apply lxlite.
2432gccCmdl="";
2433for file in ${D}inputFiles ; do
2434 case ${D}file in
2435 *!)
2436 ;;
2437 *)
2438 gccCmdl="${D}gccCmdl ${D}file"
2439 ;;
2440 esac
2441done
2442doCommand "${D}CC ${D}CFLAGS -Zdll -o ${D}dllFile ${D}defFile ${D}gccCmdl ${D}EXTRA_CFLAGS"
2443touch "${D}{outFile}.dll"
2444
2445doCommand "emximp -o ${D}arcFile ${D}defFile"
6ff53182 2446if @<:@ ${D}flag_USE_LXLITE -ne 0 @:>@; then
3fd9c298 2447 add_flags="";
6ff53182 2448 if @<:@ ${D}EXPORT_BY_ORDINALS -ne 0 @:>@; then
3fd9c298
DE
2449 add_flags="-ynd"
2450 fi
2451 doCommand "lxlite -cs -t: -mrn -mln ${D}add_flags ${D}dllFile"
2452fi
2453doCommand "emxomf -s -l ${D}arcFile"
2454
2455# Successful exit.
2456CleanUp 1
2457exit 0
2458EOF
2459dnl ===================== dllar.sh ends here =====================
2460])
2461
af8ebe8a 2462AC_DEFUN([AC_BAKEFILE_CREATE_FILE_BK_DEPS],
3fd9c298
DE
2463[
2464dnl ===================== bk-deps begins here =====================
2465D='$'
2466cat <<EOF >bk-deps
2467#!/bin/sh
2468
2469# This script is part of Bakefile (http://bakefile.sourceforge.net) autoconf
2470# script. It is used to track C/C++ files dependencies in portable way.
2471#
2472# Permission is given to use this file in any way.
2473
2474DEPSMODE=${DEPSMODE}
2475DEPSDIR=.deps
2476DEPSFLAG_GCC="${DEPSFLAG_GCC}"
b1d22ded 2477DEPSFLAG_MWCC="${DEPSFLAG_MWCC}"
3fd9c298
DE
2478
2479mkdir -p ${D}DEPSDIR
2480
2481if test ${D}DEPSMODE = gcc ; then
2482 ${D}* ${D}{DEPSFLAG_GCC}
2483 status=${D}?
2484 if test ${D}{status} != 0 ; then
2485 exit ${D}{status}
2486 fi
2487 # move created file to the location we want it in:
2488 while test ${D}# -gt 0; do
2489 case "${D}1" in
2490 -o )
2491 shift
2492 objfile=${D}1
2493 ;;
2494 -* )
2495 ;;
2496 * )
2497 srcfile=${D}1
2498 ;;
2499 esac
2500 shift
2501 done
6ff53182
DE
2502 depfile=\`basename ${D}srcfile | sed -e 's/\\..*${D}/.d/g'\`
2503 depobjname=\`echo ${D}depfile |sed -e 's/\\.d/.o/g'\`
3fd9c298
DE
2504 if test -f ${D}depfile ; then
2505 sed -e "s,${D}depobjname:,${D}objfile:,g" ${D}depfile >${D}{DEPSDIR}/${D}{objfile}.d
2506 rm -f ${D}depfile
2507 else
6ff53182 2508 depfile=\`basename ${D}objfile | sed -e 's/\\..*${D}/.d/g'\`
3fd9c298
DE
2509 if test -f ${D}depfile ; then
2510 sed -e "/^${D}objfile/!s,${D}depobjname:,${D}objfile:,g" ${D}depfile >${D}{DEPSDIR}/${D}{objfile}.d
2511 rm -f ${D}depfile
2512 fi
2513 fi
2514 exit 0
b1d22ded
DE
2515elif test ${D}DEPSMODE = mwcc ; then
2516 ${D}*
2517 status=${D}?
2518 if test ${D}{status} != 0 ; then
2519 exit ${D}{status}
2520 fi
2521 # Run mwcc again with -MM and redirect into the dep file we want
2522 # NOTE: We can't use shift here because we need ${D}* to be valid
2523 prevarg=
2524 for arg in ${D}* ; do
2525 if test "${D}prevarg" = "-o"; then
2526 objfile=${D}arg
2527 else
2528 case "${D}arg" in
2529 -* )
2530 ;;
2531 * )
2532 srcfile=${D}arg
2533 ;;
2534 esac
2535 fi
2536 prevarg="${D}arg"
2537 done
2538 ${D}* ${D}DEPSFLAG_MWCC >${D}{DEPSDIR}/${D}{objfile}.d
2539 exit 0
3fd9c298
DE
2540else
2541 ${D}*
2542 exit ${D}?
2543fi
2544EOF
2545dnl ===================== bk-deps ends here =====================
2546])
2547
af8ebe8a 2548AC_DEFUN([AC_BAKEFILE_CREATE_FILE_SHARED_LD_SH],
3fd9c298
DE
2549[
2550dnl ===================== shared-ld-sh begins here =====================
2551D='$'
2552cat <<EOF >shared-ld-sh
2553#!/bin/sh
2554#-----------------------------------------------------------------------------
2555#-- Name: distrib/mac/shared-ld-sh
2556#-- Purpose: Link a mach-o dynamic shared library for Darwin / Mac OS X
2557#-- Author: Gilles Depeyrot
2558#-- Copyright: (c) 2002 Gilles Depeyrot
2559#-- Licence: any use permitted
2560#-----------------------------------------------------------------------------
2561
2562verbose=0
2563args=""
2564objects=""
2565linking_flag="-dynamiclib"
2566
2567while test ${D}# -gt 0; do
2568 case ${D}1 in
2569
2570 -v)
2571 verbose=1
2572 ;;
2573
2574 -o|-compatibility_version|-current_version|-framework|-undefined|-install_name)
2575 # collect these options and values
2576 args="${D}{args} ${D}1 ${D}2"
2577 shift
2578 ;;
2579
2580 -l*|-L*|-flat_namespace|-headerpad_max_install_names)
2581 # collect these options
2582 args="${D}{args} ${D}1"
2583 ;;
2584
2585 -dynamiclib|-bundle)
2586 linking_flag="${D}1"
2587 ;;
2588
2589 -*)
2590 echo "shared-ld: unhandled option '${D}1'"
2591 exit 1
2592 ;;
2593
2594 *.o | *.a | *.dylib)
2595 # collect object files
2596 objects="${D}{objects} ${D}1"
2597 ;;
2598
2599 *)
2600 echo "shared-ld: unhandled argument '${D}1'"
2601 exit 1
2602 ;;
2603
2604 esac
2605 shift
2606done
2607
2608#
2609# Link one module containing all the others
2610#
2611if test ${D}{verbose} = 1; then
2612 echo "c++ -r -keep_private_externs -nostdlib ${D}{objects} -o master.${D}${D}.o"
2613fi
2614c++ -r -keep_private_externs -nostdlib ${D}{objects} -o master.${D}${D}.o
2615status=${D}?
2616if test ${D}{status} != 0; then
2617 exit ${D}{status}
2618fi
2619
2620#
2621# Link the shared library from the single module created
2622#
2623if test ${D}{verbose} = 1; then
2624 echo "cc ${D}{linking_flag} master.${D}${D}.o ${D}{args}"
2625fi
2626c++ ${D}{linking_flag} master.${D}${D}.o ${D}{args}
2627status=${D}?
2628if test ${D}{status} != 0; then
2629 exit ${D}{status}
2630fi
2631
2632#
2633# Remove intermediate module
2634#
2635rm -f master.${D}${D}.o
2636
2637exit 0
2638EOF
2639dnl ===================== shared-ld-sh ends here =====================
2640])
fe0895cf 2641
6ff53182
DE
2642AC_DEFUN([AC_BAKEFILE_CREATE_FILE_BK_MAKE_PCH],
2643[
2644dnl ===================== bk-make-pch begins here =====================
2645D='$'
2646cat <<EOF >bk-make-pch
2647#!/bin/sh
2648
2649# This script is part of Bakefile (http://bakefile.sourceforge.net) autoconf
2650# script. It is used to generated precompiled headers.
2651#
2652# Permission is given to use this file in any way.
2653
2654outfile="${D}{1}"
2655header="${D}{2}"
2656shift
2657shift
2658
2659compiler=
2660headerfile=
2661while test ${D}{#} -gt 0; do
2662 case "${D}{1}" in
2663 -I* )
2664 incdir=\`echo ${D}{1} | sed -e 's/-I\\(.*\\)/\\1/g'\`
2665 if test "x${D}{headerfile}" = "x" -a -f "${D}{incdir}/${D}{header}" ; then
2666 headerfile="${D}{incdir}/${D}{header}"
2667 fi
2668 ;;
2669 esac
2670 compiler="${D}{compiler} ${D}{1}"
2671 shift
2672done
2673
2674if test "x${D}{headerfile}" = "x" ; then
2675 echo "error: can't find header ${D}{header} in include paths" >2
2676else
2677 if test -f ${D}{outfile} ; then
2678 rm -f ${D}{outfile}
2679 else
2680 mkdir -p \`dirname ${D}{outfile}\`
2681 fi
2682 depsfile=".deps/\`echo ${D}{outfile} | tr '/.' '__'\`.d"
2683 mkdir -p .deps
2684 # can do this because gcc is >= 3.4:
2685 ${D}{compiler} -o ${D}{outfile} -MMD -MF "${D}{depsfile}" "${D}{headerfile}"
2686 exit ${D}{?}
2687fi
2688EOF
2689dnl ===================== bk-make-pch ends here =====================
2690])
2691
670ec357 2692dnl
af8ebe8a 2693dnl AM_PATH_CPPUNIT(MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]])
670ec357
VS
2694dnl
2695AC_DEFUN(AM_PATH_CPPUNIT,
2696[
2697
2698AC_ARG_WITH(cppunit-prefix,[ --with-cppunit-prefix=PFX Prefix where CppUnit is installed (optional)],
2699 cppunit_config_prefix="$withval", cppunit_config_prefix="")
2700AC_ARG_WITH(cppunit-exec-prefix,[ --with-cppunit-exec-prefix=PFX Exec prefix where CppUnit is installed (optional)],
2701 cppunit_config_exec_prefix="$withval", cppunit_config_exec_prefix="")
2702
2703 if test x$cppunit_config_exec_prefix != x ; then
2704 cppunit_config_args="$cppunit_config_args --exec-prefix=$cppunit_config_exec_prefix"
2705 if test x${CPPUNIT_CONFIG+set} != xset ; then
2706 CPPUNIT_CONFIG=$cppunit_config_exec_prefix/bin/cppunit-config
2707 fi
2708 fi
2709 if test x$cppunit_config_prefix != x ; then
2710 cppunit_config_args="$cppunit_config_args --prefix=$cppunit_config_prefix"
2711 if test x${CPPUNIT_CONFIG+set} != xset ; then
2712 CPPUNIT_CONFIG=$cppunit_config_prefix/bin/cppunit-config
2713 fi
2714 fi
2715
2716 AC_PATH_PROG(CPPUNIT_CONFIG, cppunit-config, no)
2717 cppunit_version_min=$1
2718
2719 AC_MSG_CHECKING(for Cppunit - version >= $cppunit_version_min)
2720 no_cppunit=""
2721 if test "$CPPUNIT_CONFIG" = "no" ; then
2722 no_cppunit=yes
2723 else
2724 CPPUNIT_CFLAGS=`$CPPUNIT_CONFIG --cflags`
2725 CPPUNIT_LIBS=`$CPPUNIT_CONFIG --libs`
2726 cppunit_version=`$CPPUNIT_CONFIG --version`
2727
2728 cppunit_major_version=`echo $cppunit_version | \
2729 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
2730 cppunit_minor_version=`echo $cppunit_version | \
2731 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
2732 cppunit_micro_version=`echo $cppunit_version | \
2733 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
2734
2735 cppunit_major_min=`echo $cppunit_version_min | \
2736 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
2737 cppunit_minor_min=`echo $cppunit_version_min | \
2738 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
2739 cppunit_micro_min=`echo $cppunit_version_min | \
2740 sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
2741
2742 cppunit_version_proper=`expr \
2743 $cppunit_major_version \> $cppunit_major_min \| \
2744 $cppunit_major_version \= $cppunit_major_min \& \
2745 $cppunit_minor_version \> $cppunit_minor_min \| \
2746 $cppunit_major_version \= $cppunit_major_min \& \
2747 $cppunit_minor_version \= $cppunit_minor_min \& \
2748 $cppunit_micro_version \>= $cppunit_micro_min `
2749
2750 if test "$cppunit_version_proper" = "1" ; then
2751 AC_MSG_RESULT([$cppunit_major_version.$cppunit_minor_version.$cppunit_micro_version])
2752 else
2753 AC_MSG_RESULT(no)
2754 no_cppunit=yes
2755 fi
2756 fi
2757
2758 if test "x$no_cppunit" = x ; then
2759 ifelse([$2], , :, [$2])
2760 else
2761 CPPUNIT_CFLAGS=""
2762 CPPUNIT_LIBS=""
2763 ifelse([$3], , :, [$3])
2764 fi
2765
2766 AC_SUBST(CPPUNIT_CFLAGS)
2767 AC_SUBST(CPPUNIT_LIBS)
2768])
2769
2770
2771
2772