X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=configure.ac;h=561b39e3908a32eadf7b3fed3933035e70a336fd;hp=a14508d30e49c59230659740f66be1c03947048e;hb=6dd7ae54e742339cc49e640d1076a310a0f4eedd;hpb=96dd0815b98cf9459c8dd7a8009aabb6f8051e9e diff --git a/configure.ac b/configure.ac index a14508d..561b39e 100644 --- a/configure.ac +++ b/configure.ac @@ -21,13 +21,11 @@ AM_INIT_AUTOMAKE #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ AC_PROG_CXX -#AC_PROG_AWK AC_PROG_CC AC_PROG_CPP AC_PROG_INSTALL -#AC_PROG_LN_S -#AC_PROG_MAKE_SET -AC_PROG_LIBTOOL +AC_PROG_RANLIB +AM_PROG_CC_C_O # @@ -36,18 +34,29 @@ AC_PROG_LIBTOOL case "${host}" in *mingw32*) - MINGW32=yes - WIN32=yes + MINGW32=yes + WIN32=yes + AC_PATH_PROGS([WINDRES], [windres $host_alias-windres $host_os-windres]) + if test "x$WINDRES" = x + then + AC_MSG_ERROR([windres could not be found]) + fi + AC_SUBST(WINDRES) + AC_PATH_PROGS([MAKENSIS], [makensis]) + AC_SUBST(MAKENSIS) ;; *cygwin*) - CYGWIN=yes - WIN32=yes + CYGWIN=yes + WIN32=yes ;; *-apple-darwin*) - MACOSX=yes - LIBS="$LIBS -Wl,-framework" + MACOSX=yes + LIBS="$LIBS -Wl,-framework" + ;; esac +AM_CONDITIONAL([WIN32], test "$WIN32" = "yes") + # # Checks for configuration arguments. @@ -87,14 +96,15 @@ then if test x$WIN32 != xyes then +# i haven't had much success with gprof profiling on win32 profile=yes fi fi if test x$debug = xyes then - CFLAGS="$CFLAGS -Wall -O0 -gstabs -DDEBUG" - CXXFLAGS="$CXXFLAGS -Wall -O0 -gstabs -DDEBUG" + CFLAGS="$CFLAGS -Wall -O0 -DDEBUG" + CXXFLAGS="$CXXFLAGS -Wall -O0 -DDEBUG" else CFLAGS="$CFLAGS -O2 -DNDEBUG" CXXFLAGS="$CXXFLAGS -O2 -DNDEBUG" @@ -116,7 +126,6 @@ AC_DEFINE_UNQUOTED([YOINK_LOGLEVEL], [$log_level], [Define to detail level of logging.]) - if test "x$prefix" = xNONE then prefix="$ac_default_prefix" @@ -145,7 +154,33 @@ AC_DEFINE_UNQUOTED([YOINK_CONFIGFILES], ["$CONFIGFILES"], # -# Checks for typedefs, structures, and compiler characteristics. +# Split the version number into components. +#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +VERSION_MAJOR=$(echo $VERSION | cut -d. -f1) +VERSION_MINOR=$(echo $VERSION | cut -d. -f2) +VERSION_REVISION=$(echo $VERSION | cut -d. -f3) + +AC_DEFINE_UNQUOTED([VERSION_MAJOR], [${VERSION_MAJOR:-0}], + [Define to major version number component.]) + +AC_DEFINE_UNQUOTED([VERSION_MINOR], [${VERSION_MINOR:-0}], + [Define to minor version number component.]) + +AC_DEFINE_UNQUOTED([VERSION_REVISION], [${VERSION_REVISION:-0}], + [Define to revision version number component.]) + +if test x$WIN32 = xyes +then + PVERSION="${VERSION_MAJOR:-0}.${VERSION_MINOR:-0}.${VERSION_REVISION:-0}.0" + AC_SUBST([PVERSION]) +fi + +# these are used in src/yoink.rc + + +# +# Checks for system functions/headers and compiler characteristics. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ AC_C_STRINGIZE @@ -157,98 +192,91 @@ AC_TYPE_UINT32_T AC_TYPE_SIZE_T AC_TYPE_SSIZE_T - -# -# Checks for system functions. -#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - AC_FUNC_ERROR_AT_LINE AC_FUNC_STRTOD AC_CHECK_FUNCS([nanosleep strchr strcspn strrchr strstr]) - -# -# Checks for header files. -#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - AC_HEADER_STDBOOL AC_HEADER_STDC AC_CHECK_HEADERS([stddef.h stdint.h stdlib.h string.h unistd.h]) + +# +# Checks for build dependencies. +#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +##### boost ##### +website="http://www.boost.org/" BOOST_SMART_PTR BOOST_STRING_ALGO BOOST_BIND BOOST_FUNCTION +##### SDL ##### +website="http://www.libsdl.org/" AM_PATH_SDL([1.2.10], [CFLAGS="$CFLAGS $SDL_CFLAGS" CXXFLAGS="$CXXFLAGS $SDL_CFLAGS" LIBS="$LIBS $SDL_LIBS"]) +##### opengl, glu ##### +website="http://www.mesa3d.org/" AC_CHECK_HEADERS([GL/gl.h GL/glu.h],, - [missing="$missing OpenGL"]) - -AC_CHECK_HEADERS([AL/al.h AL/alut.h],, - [missing="$missing OpenAL"]) - -AC_CHECK_HEADERS([SDL/SDL_image.h],, - [missing="$missing SDL_image"]) - -AC_CHECK_HEADERS([SDL/SDL_sound.h],, - [missing="$missing SDL_sound"]) - -if test "x$missing" != x -then - echo "** Required header files from these libraries are missing:" - for header in $missing - do - echo "** $header" - done - AC_MSG_ERROR([please install missing dependencies]) -fi - - -# -# Checks for libraries. -#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - -AC_SEARCH_LIBS([IMG_Load], [SDL_image],, - [missing="$missing SDL_image"]) - -AC_SEARCH_LIBS([Sound_Init], [SDL_sound],, - [missing="$missing SDL_sound"]) - + [missing=yes + echo "***** Missing GL headers ($website) *****"]) if test x$WIN32 == xyes then # autoconf library search macro doesn't find opengl32 on windows because it uses # different name hashing, but it links fine; assume it's there LIBS="$LIBS -lglu32 -lopengl32" else - AC_SEARCH_LIBS([gluPerspective], [GLU MesaGLU],, - [missing="$missing GLU"]) - - AC_SEARCH_LIBS([glBegin], [GL MesaGL],, - [missing="$missing OpenGL"]) + AC_SEARCH_LIBS([glEnable], [GL MesaGL],, + [missing=yes + echo "***** Missing libGL ($website) *****"]) + AC_SEARCH_LIBS([gluDisk], [GLU MesaGLU],, + [missing=yes + echo "***** Missing libGLU ($website) *****"]) fi -AC_SEARCH_LIBS([alGenBuffers], [openal openal32],, - [missing="$missing OpenAL"]) - +##### openal, alut ##### +website="http://connect.creativelabs.com/openal/" +AC_CHECK_HEADERS([AL/al.h AL/alut.h],, + [missing=yes + echo "***** Missing OpenAL headers ($website) *****"]) +AC_SEARCH_LIBS([alEnable], [openal openal32],, + [missing=yes + echo "***** Missing libopenal ($website) *****"]) AC_SEARCH_LIBS([alutInit], [alut],, - [missing="$missing ALUT"]) + [missing=yes + echo "***** Missing libalut ($website) *****"]) +##### SDL_image ##### +website="http://www.libsdl.org/projects/SDL_image/" +AC_CHECK_HEADERS([SDL/SDL_image.h],, + [missing=yes + echo "***** Missing SDL_image header ($website) *****"]) +AC_SEARCH_LIBS([IMG_Load], [SDL_image],, + [missing=yes + echo "***** Missing libSDL_image ($website) *****"]) + +##### libvorbis ##### +website="http://www.xiph.org/downloads/" +AC_CHECK_HEADERS([vorbis/codec.h vorbis/vorbisfile.h],, + [missing=yes + echo "***** Missing vorbis headers ($website) *****"]) +AC_SEARCH_LIBS([ov_open], [vorbisfile],, + [missing=yes + echo "***** Missing libvorbisfile ($website) *****"]) + +##### librt (optional) ##### AC_SEARCH_LIBS([clock_gettime], [rt], [AC_DEFINE([HAVE_CLOCK_GETTIME], 1, [Define to 1 if you have the 'clock_gettime' function.])]) -if test "x$missing" != x + +if test x$missing == xyes then - echo "** One or more required libraries are missing:" - for library in $missing - do - echo "** $library" - done - AC_MSG_ERROR([please install missing dependencies]) + AC_MSG_ERROR([please install missing dependencies (see messages above)]) fi @@ -275,8 +303,8 @@ AC_CONFIG_FILES([Makefile doc/yoink.6 extra/Makefile extra/yoink.spec - src/Makefile - src/Moof/yajl/Makefile]) + make-win32-installer.sh + src/Makefile]) AC_CONFIG_HEADERS([src/config.h])