X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=configure.ac;h=997a7f23b14d6228c12ad4fd7d3017dd90abbe1d;hp=a14508d30e49c59230659740f66be1c03947048e;hb=592c83141aef55c6e3a17c516e2f09441f29c267;hpb=96dd0815b98cf9459c8dd7a8009aabb6f8051e9e diff --git a/configure.ac b/configure.ac index a14508d..997a7f2 100644 --- a/configure.ac +++ b/configure.ac @@ -10,7 +10,7 @@ AC_INIT([Yoink], [0.1], [chaz@dogcows.com], [yoink]) AC_CANONICAL_TARGET -AC_CONFIG_SRCDIR([src/YoinkApp.cc]) +AC_CONFIG_SRCDIR([src/GameLayer.cc]) AC_CONFIG_MACRO_DIR([m4]) AM_INIT_AUTOMAKE @@ -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,33 +34,50 @@ 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" + ;; + *-linux-gnu*) + LINUX=yes + AC_PATH_PROGS([RPMBUILD], [rpmbuild]) + AC_SUBST(RPMBUILD) + ;; esac +AM_CONDITIONAL([LINUX], test "$LINUX" = "yes") +AM_CONDITIONAL([WIN32], test "$WIN32" = "yes") + # # Checks for configuration arguments. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -AC_ARG_ENABLE([developer], - [ --enable-developer use all compiler flags developers need], - [developer=$enableval], - [developer=no]) - AC_ARG_ENABLE([debug], [ --enable-debug include debugging symbols and features], [debug=$enableval], [debug=no]) +AC_ARG_ENABLE([double-precision], + [ --enable-double-precision use double-precision numbers], + [double_precision=$enableval], + [double_precision=no]) + AC_ARG_ENABLE([profile], [ --enable-profile make a binary for use with gprof profiler], [profile=$enableval], @@ -73,6 +88,11 @@ AC_ARG_ENABLE([extra-warnings], [extra_warnings=$enableval], [extra_warnings=no]) +AC_ARG_ENABLE([threads], + [ --enable-threads use threads for some parallel tasks], + [threads=$enableval], + [threads=no]) + AC_ARG_WITH([log-level], [AS_HELP_STRING([--with-log-level=NUM], [0, none... 1, errors... 4, everything (default: 3)])], @@ -80,30 +100,27 @@ AC_ARG_WITH([log-level], [log_level=3]) -if test x$developer = xyes +if test x$debug = xyes then - debug=yes - log_level=4 - - if test x$WIN32 != xyes - then - profile=yes - fi + CFLAGS="$CFLAGS -Wall -g -DDEBUG" + CXXFLAGS="$CXXFLAGS -Wall -g -DDEBUG" +else + CFLAGS="$CFLAGS -DNDEBUG" + CXXFLAGS="$CXXFLAGS -DNDEBUG" fi -if test x$debug = xyes +if test x$double_precision = xyes then - CFLAGS="$CFLAGS -Wall -O0 -gstabs -DDEBUG" - CXXFLAGS="$CXXFLAGS -Wall -O0 -gstabs -DDEBUG" -else - CFLAGS="$CFLAGS -O2 -DNDEBUG" - CXXFLAGS="$CXXFLAGS -O2 -DNDEBUG" + AC_DEFINE([USE_DOUBLE_PRECISION], 1, + [Define to 1 if you want to use doubles instead of floats.]) fi if test x$profile = xyes then CFLAGS="$CFLAGS -pg" CXXFLAGS="$CXXFLAGS -pg" + AC_DEFINE([PROFILING_ENABLED], 1, + [Define to 1 if profiling is built in.]) fi if test x$extra_warnings = xyes @@ -112,25 +129,26 @@ then CXXFLAGS="$CXXFLAGS -Wextra -Wno-unused-parameter" fi +if test x$threads = xyes +then + AC_DEFINE([USE_THREADS], 1, + [Define to 1 if you want to use threads for parallel tasks.]) +fi + AC_DEFINE_UNQUOTED([YOINK_LOGLEVEL], [$log_level], [Define to detail level of logging.]) - if test "x$prefix" = xNONE then prefix="$ac_default_prefix" fi -AC_ARG_WITH([assetdir], - [AS_HELP_STRING([--with-assetdir=DIR], - [real path to assets (default: $datarootdir/yoink)])], - [DATADIR="$withval"], - [eval DATADIR="$datarootdir/yoink"]) - if test x$WIN32 = xyes then DATADIR="data" +else + eval eval DATADIR="${datadir}/yoink" fi AC_SUBST([DATADIR]) @@ -138,14 +156,34 @@ AC_DEFINE_UNQUOTED([YOINK_DATADIR], ["$DATADIR"], [Define to path of game asset directory.]) -CONFIGFILES="\$HOME/.yoinkrc:/etc/yoinkrc" +# +# 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([YOINK_CONFIGFILES], ["$CONFIGFILES"], - [Define to colon-delimited configuration file paths.]) +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 typedefs, structures, and compiler characteristics. +# Checks for system functions/headers and compiler characteristics. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ AC_C_STRINGIZE @@ -157,98 +195,100 @@ 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) *****"]) + +##### liblua ##### +website="http://www.lua.org/" +AC_CHECK_HEADERS([lua.h],, + [missing=yes + echo "***** Missing lua headers ($website) *****"]) +AC_SEARCH_LIBS([lua_load], [lua],, + [missing=yes + echo "***** Missing liblua ($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 @@ -257,10 +297,9 @@ fi #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ DATA_FILES=$(echo $(cd data; \ - find . -name "*.json" \ + find . -name "*.lua" \ -o -name "*.ogg" \ -o -name "*.png" \ - -o -name "*.xm" \ -o -name "yoinkrc")) AC_SUBST([DATA_FILES]) @@ -275,8 +314,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]) @@ -290,13 +329,14 @@ AC_OUTPUT echo "" echo " Configuration complete! :-)" echo "" -echo " Target: $target" -echo " Prefix: $prefix" -echo " Data Directory: $DATADIR" -echo " Log Level: $log_level" -echo " Debug: $debug" -echo " Profile: $profile" -echo " Extra Warnings: $extra_warnings" +echo " Target: $target" +echo " Prefix: $prefix" +echo " Data Directory: $DATADIR" +echo " Log Level: $log_level" +echo " Debug: $debug" +echo " Double Precision: $double_precision" +echo " Profile: $profile" +echo " Extra Warnings: $extra_warnings" echo "" echo " To finish the installation, execute:" echo " make"