]> Dogcows Code - chaz/yoink/blobdiff - configure.ac
beginning netbsd packaging script
[chaz/yoink] / configure.ac
index d78c666b3d0182dc1bec5102bea2710fe9252505..6ba6e540241085bee8606d56eec067f692d6e8e2 100644 (file)
@@ -10,7 +10,7 @@ AC_INIT([Yoink], [0.1], [chaz@dogcows.com], [yoink])
 
 AC_CANONICAL_TARGET
 
-AC_CONFIG_SRCDIR([src/GameLayer.cc])
+AC_CONFIG_SRCDIR([src/version.c])
 AC_CONFIG_MACRO_DIR([m4])
 
 AM_INIT_AUTOMAKE
@@ -18,7 +18,7 @@ AM_INIT_AUTOMAKE
 
 #
 # Checks for programs.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
 AC_PROG_CXX
 AC_PROG_CC
@@ -34,41 +34,35 @@ AC_SUBST(DOXYGEN)
 
 #
 # Configure platform-specific stuff.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
 case "${host}" in
        *mingw32*)
-               MINGW32=yes
                WIN32=yes
-               AC_PATH_PROGS([WINDRES], [windres $host_alias-windres $host_os-windres])
+               AC_PATH_PROGS([MAKENSIS], [makensis])
+               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
        ;;
        *-apple-darwin*)
                MACOSX=yes
-               LIBS="$LIBS -Wl,-framework"
        ;;
-       *-linux-gnu*)
-               LINUX=yes
+       *netbsd*)
+               NETBSD=yes
+               AC_PATH_PROGS([PKGLINT], [pkglint])
        ;;
 esac
 
-AM_CONDITIONAL([LINUX], test "$LINUX" = "yes")
-AM_CONDITIONAL([WIN32], test "$WIN32" = "yes")
+AM_CONDITIONAL([WIN32],  test "$WIN32" = "yes")
+AM_CONDITIONAL([NETBSD], test "$NETBSD" = "yes")
 
 
 #
 # Checks for configuration arguments.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
 AC_ARG_ENABLE([debug],
                          [  --enable-debug          include debugging symbols and features],
@@ -76,12 +70,12 @@ AC_ARG_ENABLE([debug],
                          [debug=no])
 
 AC_ARG_ENABLE([double-precision],
-                         [  --enable-double-precision      use double-precision numbers],
+                         [  --enable-double-precision      use doubles instead of floats],
                          [double_precision=$enableval],
                          [double_precision=no])
 
 AC_ARG_ENABLE([profile],
-                         [  --enable-profile        make a binary for use with gprof profiler],
+                         [  --enable-profile        make a binary with code profiling instructions],
                          [profile=$enableval],
                          [profile=no])
 
@@ -90,32 +84,31 @@ AC_ARG_ENABLE([extra-warnings],
                          [extra_warnings=$enableval],
                          [extra_warnings=no])
 
+AC_ARG_ENABLE([clock_gettime],
+                         [  --enable-clock_gettime  use clock_gettime() instead of SDL_GetTicks()],
+                         [clock_gettime=$enableval],
+                         [clock_gettime=no])
+
 AC_ARG_ENABLE([threads],
-                         [  --enable-threads        use threads for some parallel tasks],
+                         [  --enable-threads        use threads for concurrency where appropriate],
                          [threads=$enableval],
                          [threads=no])
 
 AC_ARG_ENABLE([gtk],
-                         [  --enable-gtk            enable GTK+ info/warning dialogs],
+                         [  --enable-gtk            enable GTK+ modal dialogs],
                          [gtk=$enableval],
                          [gtk=no])
 
 AC_ARG_ENABLE([qt4],
-                         [  --enable-qt4            enable QT info/warning dialogs],
+                         [  --enable-qt4            enable QT modal dialogs],
                          [qt4=$enableval],
                          [qt4=no])
 
-AC_ARG_WITH([log-level],
-                       [AS_HELP_STRING([--with-log-level=NUM],
-                                                       [0, none... 1, errors... 4, everything (default: 3)])],
-                       [log_level=$withval],
-                       [log_level=3])
-
 
 if test x$debug = xyes
 then
-       CFLAGS="$CFLAGS -DDEBUG -Wall -Wno-uninitialized"
-       CXXFLAGS="$CXXFLAGS -DDEBUG -Wall -Wno-uninitialized"
+       CFLAGS="$CFLAGS -DDEBUG -ggdb -O0 -Wall -Wno-uninitialized"
+       CXXFLAGS="$CXXFLAGS -DDEBUG -ggdb -O0 -Wall -Wno-uninitialized"
 else
        CFLAGS="$CFLAGS -DNDEBUG"
        CXXFLAGS="$CXXFLAGS -DNDEBUG"
@@ -144,24 +137,19 @@ fi
 if test x$threads = xyes
 then
        AC_DEFINE([USE_THREADS], 1,
-                         [Define to 1 if you want to use threads for parallel tasks.])
+                         [Define to 1 if you want to use threads when applicable.])
 fi
 
 if test x$gtk = xyes
 then
        AC_DEFINE([USE_GTK], 1,
-                         [Define to 1 if you want to use GTK+ info/error dialogs.])
-else
-if test x$qt4 = xyes
+                         [Define to 1 if you want to use GTK+ modal dialogs.])
+elif test x$qt4 = xyes
 then
        AC_DEFINE([USE_QT4], 1,
-                         [Define to 1 if you want to use QT info/error dialogs.])
-fi
+                         [Define to 1 if you want to use QT4 modal dialogs.])
 fi
 
-AC_DEFINE_UNQUOTED([YOINK_LOGLEVEL], [$log_level],
-                                  [Define to detail level of logging.])
-
 
 if test "x$prefix" = xNONE
 then
@@ -182,7 +170,7 @@ AC_DEFINE_UNQUOTED([YOINK_DATADIR], ["$DATADIR"],
 
 #
 # Split the version number into components.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
 VERSION_MAJOR=$(echo $VERSION | cut -d. -f1)
 VERSION_MINOR=$(echo $VERSION | cut -d. -f2)
@@ -208,7 +196,7 @@ fi
 
 #
 # Checks for system functions/headers and compiler characteristics.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
 AC_C_STRINGIZE
 AC_C_INLINE
@@ -227,10 +215,20 @@ AC_HEADER_STDBOOL
 AC_HEADER_STDC
 AC_CHECK_HEADERS([stddef.h stdint.h stdlib.h string.h unistd.h])
 
+##### clock_gettime #####
+if test x$clock_gettime = xyes
+then
+       AC_SEARCH_LIBS([clock_gettime], [rt],
+                                  [AC_DEFINE([HAVE_CLOCK_GETTIME], 1,
+                                                         [Define to 1 if you have the 'clock_gettime' function.])])
+fi
+
 
 #
 # Checks for build dependencies.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+echo "checking for dependencies..."
 
 ##### boost #####
 website="http://www.boost.org/"
@@ -241,69 +239,61 @@ 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"])
+PKG_CHECK_MODULES([SDL], [sdl],
+                                 [LIBS="$LIBS $SDL_LIBS"
+                                  CFLAGS="$CFLAGS $SDL_CFLAGS"
+                                  CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"],
+                                 [missing=yes
+                                  echo "***** Missing SDL ($website) *****"])
 
 ##### opengl, glu #####
 website="http://www.mesa3d.org/"
-AC_CHECK_HEADERS([GL/gl.h GL/glu.h],,
-                                [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([glEnable], [GL MesaGL],,
-                                  [missing=yes
-                                       echo "***** Missing libGL ($website) *****"])
-       AC_SEARCH_LIBS([gluDisk], [GLU MesaGLU],,
-                                  [missing=yes
-                                       echo "***** Missing libGLU ($website) *****"])
-fi
+PKG_CHECK_MODULES([OPENGL], [gl glu],
+                                 [LIBS="$LIBS $OPENGL_LIBS"
+                                  CFLAGS="$CFLAGS $OPENGL_CFLAGS"
+                                  CXXFLAGS="$CXXFLAGS $GLU_CFLAGS"],
+                                 [missing=yes
+                                  echo "***** Missing OpenGL ($website) *****"])
+
+##### liblua #####
+website="http://www.lua.org/"
+PKG_CHECK_MODULES([LUA], [lua],
+                                 [LIBS="$LIBS $LUA_LIBS"
+                                  CFLAGS="$CFLAGS $LUA_CFLAGS"
+                                  CXXFLAGS="$CXXFLAGS $LUA_CFLAGS"],
+                                 [missing=yes
+                                  echo "***** Missing liblua ($website) *****"])
+
+##### libpng #####
+website="http://www.libpng.org/pub/png/libpng.html"
+PKG_CHECK_MODULES([PNG], [libpng],
+                                 [LIBS="$LIBS $PNG_LIBS"
+                                  CFLAGS="$CFLAGS $PNG_CFLAGS"
+                                  CXXFLAGS="$CXXFLAGS $PNG_CFLAGS"],
+                                 [missing=yes
+                                  echo "***** Missing libpng ($website) *****"])
 
 ##### openal #####
 website="http://connect.creativelabs.com/openal/"
-AC_CHECK_HEADERS([AL/al.h AL/alc.h],,
-                                [missing=yes
-                                 echo "***** Missing OpenAL headers ($website) *****"])
-AC_SEARCH_LIBS([alEnable], [openal OpenAL32],,
-                          [missing=yes
-                               echo "***** Missing libopenal ($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) *****"])
+PKG_CHECK_MODULES([OPENAL], [openal],
+                                 [LIBS="$LIBS $OPENAL_LIBS"
+                                  CFLAGS="$CFLAGS $OPENAL_CFLAGS"
+                                  CXXFLAGS="$CXXFLAGS $OPENAL_CFLAGS"],
+                                 [missing=yes
+                                  echo "***** Missing OpenAL ($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) *****"])
-
+PKG_CHECK_MODULES([VORBIS], [vorbisfile],
+                                 [LIBS="$LIBS $VORBIS_LIBS"
+                                  CFLAGS="$CFLAGS $VORBIS_CFLAGS"
+                                  CXXFLAGS="$CXXFLAGS $VORBIS_CFLAGS"],
+                                 [missing=yes
+                                  echo "***** Missing libvorbisfile ($website) *****"])
+
+##### GTK+ 2.0 #####
 if test x$gtk = xyes
 then
-       ##### GTK+ 2.0 #####
        website="http://www.gtk.org/"
        PKG_CHECK_MODULES([GTK], [gtk+-2.0],
                                          [LIBS="$LIBS $GTK_LIBS"
@@ -313,9 +303,9 @@ then
                                           echo "***** Missing GTK+-2.0 ($website) *****"])
 fi
 
+##### QT4 #####
 if test x$qt4 = xyes
 then
-       ##### QT4 #####
        website="http://qt.nokia.com/"
        PKG_CHECK_MODULES([QT], [QtGui],
                                          [LIBS="$LIBS $QT_LIBS"
@@ -325,39 +315,33 @@ then
                                           echo "***** Missing QT ($website) *****"])
 fi
 
-##### 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 == xyes
+if test x$missing = xyes
 then
-       AC_MSG_ERROR([please install missing dependencies (see messages above)])
+       AC_MSG_ERROR([Please resolve the missing dependencies, and try again.])
 fi
 
 
 #
-# Find the data files to install.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-DATA_FILES=$(echo $(cd data; \
-                                       find . -name "*.lua" \
-                                               -o -name "*.ogg" \
-                                               -o -name "*.png" \
-                                               -o -name "yoinkrc"))
+# Find the game resources to install.
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+DATA_FILES=$(echo $(cd data && find . -name "*.lua" \
+                                                                  -o -name "*.ogg" \
+                                                                  -o -name "*.png" \
+                                                                  -o -name "yoinkrc"))
 AC_SUBST([DATA_FILES])
 
 
 #
 # Create the build files.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
 AC_CONFIG_FILES([Makefile
                                 data/Makefile
-                                src/Makefile
-                                doc/Makefile doc/yoink.6
-                                win32/Makefile win32/build-installer.sh])
+                                doc/Makefile
+                                doc/yoink.6
+                                src/Makefile])
 
 AC_CONFIG_HEADERS([src/config.h])
 
@@ -366,19 +350,18 @@ AC_OUTPUT
 
 #
 # Print a friendly little message.
-#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 
 echo ""
 echo " Configuration complete! :-)"
 echo ""
-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 "      Host: $target"
+echo "    Prefix: $prefix"
+echo "      Data: $DATADIR"
+echo ""
+echo "       CXX: $CXX"
+echo "  CXXFLAGS: $(echo $CXXFLAGS)"
+echo "      LIBS: $(echo $LIBS)"
 echo ""
 echo " To finish the installation, execute:"
 echo "  make"
This page took 0.026939 seconds and 4 git commands to generate.