X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=configure.ac;h=0900a1ba8fa4be8b27af5d6a12f4f8472c1f6664;hb=fcb67de4f51ad4ee668f368807c434ad8ac953f2;hp=490ddecf8e85fb622fdcc9757363ca0a40b02e90;hpb=1bd99ddaf5d067e6f660393984a17b55194fd276;p=flightgear.git diff --git a/configure.ac b/configure.ac index 490ddecf8..0900a1ba8 100644 --- a/configure.ac +++ b/configure.ac @@ -10,7 +10,9 @@ dnl Require at least automake 2.52 AC_PREREQ(2.52) dnl Initialize the automake stuff -AM_INIT_AUTOMAKE(FlightGear, 0.9.3) +dnl set the $host variable based on local machine/os +AC_CANONICAL_TARGET +AM_INIT_AUTOMAKE(FlightGear, 0.9.6-pre1) dnl Checks for programs. AC_PROG_MAKE_SET @@ -29,9 +31,6 @@ if test "x$with_simgear" != "x" ; then EXTRA_DIRS="${EXTRA_DIRS} $with_simgear" fi -dnl set the $host variable based on local machine/os -AC_CANONICAL_HOST - case "${host}" in *-*-irix*) if test "$CXX" = "CC"; then @@ -59,42 +58,24 @@ fi # Specify if we want to build with Multiplayer support # default to with_network=yes -AC_ARG_WITH(multiplayer, [ --with-multiplayer Include default multiplayer support]) -AC_ARG_WITH(network_olk, [ --with-network-olk Include Oliver's multi-pilot networking support [default=no]]) +AC_ARG_WITH(multiplayer, [ --with-multiplayer Include multiplayer support [default=yes]]) -if test "x$with_multiplayer" = "xno" -a "x$with_network_olk" = "xno"; then +if test "x$with_multiplayer" = "xno"; then echo "Building without any kind of multiplayer support" - -elif test "x$with_multiplayer" = "xno"; then -# echo "Building without default multiplayer support" - echo "Building with Oliver's multi-pilot network support" - AC_DEFINE([FG_NETWORK_OLK], 1, [Define to build with Oliver's networking]) - else - echo "Building with default multiplayer support" -# echo "Building without Oliver's multi-pilot network support" - AC_DEFINE([FG_MPLAYER_AS], 1, [Define to build with default multiplayer support]) + echo "Building with multiplayer support" + AC_DEFINE([FG_MPLAYER_AS], 1, [Define to build with multiplayer support]) fi - -AM_CONDITIONAL(ENABLE_NETWORK_OLK, test "x$with_network_olk" != "xno" -a "x$with_multiplayer" = "xno") AM_CONDITIONAL(ENABLE_MPLAYER_AS, test "x$with_multiplayer" != "xno") -# Specify if we want to use WeatherCM instead of FGEnvironment. -# default to with_weathercm=no -AC_ARG_WITH(weathercm, [ --with-weathercm Use WeatherCM instead of FGEnvironment]) -if test "x$with_weathercm" = "xyes" ; then - echo "Building with WeatherCM" - AC_DEFINE([FG_WEATHERCM], 1, - [Define to build with Christian Mayer's weather code]) -else - echo "Building with FGEnvironment" -fi -AM_CONDITIONAL(ENABLE_WEATHERCM, test "x$with_weathercm" = "xyes") - dnl Thread related checks -AC_ARG_WITH(threads, [ --with-threads Include tile loading threads [default=no]]) -if test "x$with_threads" = "xyes"; then +# defaults to yes +with_threads=yes +AC_ARG_WITH(threads, [ --with-threads Include tile loading threads [default=yes]]) +if test "x$with_threads" != "xyes"; then + AC_DEFINE([ENABLE_THREADS], 0, [Define to enable threaded tile paging]) +else AC_DEFINE([ENABLE_THREADS], 1, [Define to enable threaded tile paging]) CXXFLAGS="$CXXFLAGS -D_REENTRANT" CFLAGS="$CFLAGS -D_REENTRANT" @@ -113,7 +94,7 @@ fi dnl Used by JSBSim to conditionally compile in fgfs interface code AC_DEFINE([FGFS], 1, [Define so that JSBSim compiles in 'library' mode]) -dnl Used to controll whether clouds3d should be compiled in or not +dnl Used to control whether clouds3d should be compiled in or not AC_DEFINE([FG_USE_CLOUDS_3D], 1, [Define to use 3D cloud support]) AM_CONDITIONAL(FG_USE_CLOUDS_3D, test "x" = "x") @@ -126,6 +107,12 @@ case "${host}" in echo no EXTRA_DIRS for $host ;; +*-*-cygwin*) + if test -d /usr/local ; then + EXTRA_DIRS="${EXTRA_DIRS} /usr/local" + fi + ;; + *) if test -d /usr/X11R6 ; then EXTRA_DIR1="/usr/X11R6" @@ -133,7 +120,7 @@ case "${host}" in if test -d /opt/X11R6 ; then EXTRA_DIR2="/opt/X11R6" fi - EXTRA_DIRS="${EXTRA_DIRS} $EXTRA_DIR1 $EXTRA_DIR2" + EXTRA_DIRS="${EXTRA_DIRS} $EXTRA_DIR1 $EXTRA_DIR2 /usr/local/" ;; esac @@ -231,6 +218,15 @@ AC_SEARCH_LIBS(dlclose, dl) base_LIBS="$LIBS" +dnl Check for SDL if enabled. +AC_ARG_ENABLE(sdl, [ --enable-sdl Configure to use SDL instead of GLUT], enable_sdl="yes", enable_sdl="") +AM_CONDITIONAL(USE_SDL, test "x$enable_sdl" = "xyes") +if test "x$enable_sdl" = "xyes"; then + AC_DEFINE([PU_USE_SDL], 1, [Define to use SDL]) +else + AC_DEFINE([PU_USE_GLUT], 1, [Define to use glut]) +fi + dnl check for glut location AC_CHECK_HEADER(GL/glut.h) if test "x$ac_cv_header_GL_glut_h" = "xyes"; then @@ -240,8 +236,10 @@ else if test "x$ac_cv_header_GLUT_glut_h" = "xyes"; then AC_DEFINE([FG_GLUT_H], , [Define as glut.h include location]) else - echo "Neither GL/glut.h nor GLUT/glut.h found. Cannot continue" - exit + if test "x$enable_sdl" != "xyes"; then + echo "Neither GL/glut.h nor GLUT/glut.h found. Cannot continue" + exit + fi fi fi @@ -254,8 +252,13 @@ case "${host}" in AC_DEFINE([WIN32], 1, [Define for Win32 platforms]) AC_DEFINE([NOMINMAX], 1, [Define for Win32 platforms]) - LIBS="$LIBS -lglut32 -lglu32 -lopengl32" - LIBS="$LIBS -luser32 -lgdi32" + if test "x$enable_sdl" = "xyes"; then + AC_SEARCH_LIBS(SDL_Init, SDL) + else + LIBS="$LIBS -lglut32" + fi + + LIBS="$LIBS -lglu32 -lopengl32 -luser32 -lgdi32" dnl add -lwsock32 for mingwin case "${host}" in @@ -272,7 +275,7 @@ case "${host}" in *-apple-darwin*) dnl Mac OS X - LIBS="$LIBS -framework GLUT -framework OpenGL -framework Carbon -lobjc" + LIBS="$LIBS -framework GLUT -framework OpenGL -framework AGL -framework Carbon -lobjc" ;; *) @@ -306,6 +309,9 @@ case "${host}" in AC_SEARCH_LIBS(gluLookAt, [ GLU MesaGLU ]) AC_SEARCH_LIBS(glutGetModifiers, [ glut freeglut ]) + if test "x$enable_sdl" = "xyes"; then + AC_SEARCH_LIBS(SDL_Init, SDL) + fi ;; esac @@ -313,7 +319,35 @@ esac opengl_LIBS="$LIBS" LIBS="$base_LIBS" +dnl check for OpenAL libraries +case "${host}" in +*-*-cygwin* | *-*-mingw32*) + dnl CygWin under Windoze. + + AC_SEARCH_LIBS(alGenBuffers, openal32) + AC_SEARCH_LIBS(alutInit, [ openal32 ALut ] ) + LIBS="$LIBS -lwinmm -ldsound -ldxguid -lole32" + ;; + +*-apple-darwin*) + dnl Mac OS X + + LIBS="$LIBS -framework IOKit -framework OpenAL" + ;; + +*) + dnl default unix style machines + + AC_SEARCH_LIBS(alGenBuffers, openal) + ;; + +esac + +openal_LIBS="$LIBS" +LIBS="$base_LIBS" + AC_SUBST(base_LIBS) +AC_SUBST(openal_LIBS) AC_SUBST(opengl_LIBS) AC_SUBST(thread_LIBS) AC_SUBST(network_LIBS) @@ -336,11 +370,11 @@ if test "x$ac_cv_header_plib_ul_h" != "xyes"; then exit fi -AC_MSG_CHECKING([for plib 1.6.0 or newer]) +AC_MSG_CHECKING([for plib 1.8.0 or newer]) AC_TRY_RUN([ #include -#define MIN_PLIB_VERSION 160 +#define MIN_PLIB_VERSION 170 int main() { int major, minor, micro; @@ -355,7 +389,7 @@ int main() { ], AC_MSG_RESULT(yes), [AC_MSG_RESULT(wrong version); - AC_MSG_ERROR([Install plib 1.6.0 or later first...])], + AC_MSG_ERROR([Install plib 1.8.0 or later first...])], AC_MSG_RESULT(yes) ) @@ -364,29 +398,6 @@ dnl joystick lib AC_DEFINE([ENABLE_PLIB_JOYSTICK], 1, [Define to enable plib joystick support]) -dnl Checking for PSL in plib -dnl version of plib, so check for it. -AC_MSG_CHECKING([for plib PSL scripting support]) -AC_COMPILE_IFELSE([ -#include - -int main() { - // not for running... - pslProgram program((pslExtension *)0); - program.compile("int main () {}", ""); - return 0; -} -], - [AC_MSG_RESULT(yes); - have_plib_psl=yes], - AC_MSG_RESULT(no) -) -AM_CONDITIONAL(HAVE_PLIB_PSL, test "x$have_plib_psl" = "xyes") -if test "x$have_plib_psl" = "xyes"; then - AC_DEFINE([HAVE_PLIB_PSL], 1, - [Define if plib version is new enough to provide "PSL"]) -fi - dnl Check for the presence of SimGear AC_CHECK_HEADER(simgear/version.h) if test "x$ac_cv_header_simgear_version_h" != "xyes"; then @@ -400,7 +411,7 @@ if test "x$ac_cv_header_simgear_version_h" != "xyes"; then exit fi -AC_MSG_CHECKING([for simgear 0.3.4 or newer]) +AC_MSG_CHECKING([for simgear 0.3.7 or newer]) AC_TRY_RUN([ #include @@ -411,20 +422,19 @@ AC_TRY_RUN([ #define MIN_MAJOR 0 #define MIN_MINOR 3 -#define MIN_MICRO 4 +#define MIN_MICRO 7 int main() { int major, minor, micro; - printf("%d.%d.%d or greater... ", MIN_MAJOR, MIN_MINOR, MIN_MICRO); + /* printf("%d.%d.%d or greater, ", MIN_MAJOR, MIN_MINOR, MIN_MICRO); */ + printf("[found %s] ... ", STRINGIFY(SIMGEAR_VERSION)); sscanf( STRINGIFY(SIMGEAR_VERSION), "%d.%d.%d", &major, &minor, µ ); - if ( major < MIN_MAJOR ) { - return -1; - } else if ( major == MIN_MAJOR && minor < MIN_MINOR ) { - return -1; - } else if ( major == MIN_MAJOR && minor == MIN_MINOR && micro < MIN_MICRO ){ + if ( (major < MIN_MAJOR) || + (major == MIN_MAJOR && minor < MIN_MINOR) || + (major == MIN_MAJOR && minor == MIN_MINOR && micro < MIN_MICRO) ) { return -1; } @@ -440,7 +450,7 @@ int main() { LIBS="$saved_LIBS" -dnl Check if SimGear was built with Norman JPEG factory support +dnl Check if SimGear was built with Norman's JPEG factory support AC_CHECK_HEADER(simgear/screen/jpgfactory.hxx) if test "x$ac_cv_header_simgear_screen_jpgfactory_hxx" = "xyes"; then AC_CHECK_LIB(jpeg, jpeg_start_compress) @@ -491,11 +501,15 @@ AC_HEADER_TIME AC_STRUCT_TM dnl Checks for library functions. +old_LIBS=$LIBS +LIBS="$base_LIBS $network_LIBS $opengl_LIBS" AC_TYPE_SIGNAL AC_FUNC_VPRINTF -AC_CHECK_FUNCS( \ +AC_CHECK_FUNCS( [ \ ftime gettimeofday timegm memcpy bcopy mktime strstr rand mkfifo \ - random drand48 setitimer getitimer signal GetLocalTime rint getrusage ) + random drand48 setitimer getitimer signal GetLocalTime rint getrusage \ + truncf ] ) +LIBS=$old_LIBS AM_CONFIG_HEADER(src/Include/config.h) @@ -510,6 +524,8 @@ AC_CONFIG_FILES([ \ man/pstest.1 \ scripts/Makefile \ scripts/debug/Makefile \ + scripts/perl/Makefile \ + scripts/perl/examples/Makefile \ scripts/python/Makefile \ src/Makefile \ src/Include/Makefile \ @@ -538,10 +554,10 @@ AC_CONFIG_FILES([ \ src/Main/runfgfs \ src/Main/runfgfs.bat \ src/Model/Makefile \ + src/AIModel/Makefile \ src/MultiPlayer/Makefile \ src/Navaids/Makefile \ src/Network/Makefile \ - src/NetworkOLK/Makefile \ src/Objects/Makefile \ src/Replay/Makefile \ src/Scenery/Makefile \ @@ -549,10 +565,12 @@ AC_CONFIG_FILES([ \ src/Sound/Makefile \ src/Systems/Makefile \ src/Time/Makefile \ - src/WeatherCM/Makefile \ + src/Traffic/Makefile \ tests/Makefile \ utils/Makefile \ utils/TerraSync/Makefile \ + utils/Modeller/Makefile \ + utils/js_server/Makefile \ ]) AC_OUTPUT @@ -564,16 +582,6 @@ echo "=================" echo "Prefix: $prefix" -if test "x$have_plib_psl" = "xyes"; then - echo "Plib PSL scripting: yes" -else - echo "Plib PSL scripting: $fg_psl_string_compile" - echo " You will not be able to run scripts written in PSL" - echo " and some advanced GUI and input features may not" - echo " work. Download and install the latest CVS version" - echo " of plib if you would like to enable PSL support." -fi - if test "x$with_logging" != "x"; then echo "Debug messages: $with_logging" else @@ -583,16 +591,8 @@ fi echo -n "Automake version: " automake --version | head -1 -if test "x$with_weathercm" != "x"; then - echo "WeatherCM instead of FGEnvironment: $with_weathercm" -else - echo "Using FGEnvironment" -fi - if test "x$with_multiplayer" != "xno"; then - echo "Using default multiplayer support" -elif test "x$with_network_olk" != "xno"; then - echo "Using Oliver's multi-pilot network support" + echo "Building with multiplayer support" fi if test "x$with_threads" = "xyes"; then