2015-06-21 15:33:46 +00:00
|
|
|
dnl Process this file with autoconf to produce a configure script.
|
2020-12-14 05:11:40 +00:00
|
|
|
AC_INIT
|
2021-01-23 00:41:02 +00:00
|
|
|
AC_CONFIG_SRCDIR([loopwave.c])
|
2015-06-21 15:33:46 +00:00
|
|
|
|
|
|
|
dnl Detect the canonical build and host environments
|
2021-09-06 09:40:23 +00:00
|
|
|
AC_CONFIG_AUX_DIR([../build-scripts])
|
2015-06-21 15:33:46 +00:00
|
|
|
AC_CANONICAL_HOST
|
|
|
|
|
|
|
|
dnl Check for tools
|
|
|
|
AC_PROG_CC
|
|
|
|
|
|
|
|
dnl Check for compiler environment
|
|
|
|
AC_C_CONST
|
|
|
|
|
|
|
|
dnl We only care about this for building testnative at the moment, so these
|
|
|
|
dnl values shouldn't be considered absolute truth.
|
|
|
|
dnl (Haiku, for example, sets none of these.)
|
|
|
|
ISUNIX="false"
|
|
|
|
ISWINDOWS="false"
|
|
|
|
ISMACOSX="false"
|
2021-11-30 22:55:56 +00:00
|
|
|
ISOS2="false"
|
2015-06-21 15:33:46 +00:00
|
|
|
|
|
|
|
dnl Figure out which math library to use
|
|
|
|
case "$host" in
|
2021-02-18 17:10:50 +00:00
|
|
|
*-*-cygwin* | *-*-mingw*)
|
2015-06-21 15:33:46 +00:00
|
|
|
ISWINDOWS="true"
|
|
|
|
EXE=".exe"
|
|
|
|
MATHLIB=""
|
|
|
|
SYS_GL_LIBS="-lopengl32"
|
|
|
|
;;
|
|
|
|
*-*-haiku*)
|
|
|
|
EXE=""
|
|
|
|
MATHLIB=""
|
|
|
|
SYS_GL_LIBS="-lGL"
|
|
|
|
;;
|
2021-11-30 22:55:56 +00:00
|
|
|
*-*-darwin*)
|
2015-06-21 15:33:46 +00:00
|
|
|
ISMACOSX="true"
|
|
|
|
EXE=""
|
|
|
|
MATHLIB=""
|
|
|
|
SYS_GL_LIBS="-Wl,-framework,OpenGL"
|
|
|
|
;;
|
|
|
|
*-*-aix*)
|
|
|
|
ISUNIX="true"
|
|
|
|
EXE=""
|
2020-12-14 05:11:40 +00:00
|
|
|
if test x$ac_cv_c_compiler_gnu = xyes; then
|
2015-06-21 15:33:46 +00:00
|
|
|
CFLAGS="-mthreads"
|
|
|
|
fi
|
|
|
|
SYS_GL_LIBS=""
|
|
|
|
;;
|
|
|
|
*-*-mint*)
|
|
|
|
EXE=""
|
|
|
|
MATHLIB=""
|
|
|
|
AC_PATH_PROG(OSMESA_CONFIG, osmesa-config, no)
|
|
|
|
if test "x$OSMESA_CONFIG" = "xyes"; then
|
|
|
|
OSMESA_CFLAGS=`$OSMESA_CONFIG --cflags`
|
|
|
|
OSMESA_LIBS=`$OSMESA_CONFIG --libs`
|
|
|
|
CFLAGS="$CFLAGS $OSMESA_CFLAGS"
|
|
|
|
SYS_GL_LIBS="$OSMESA_LIBS"
|
|
|
|
else
|
|
|
|
SYS_GL_LIBS="-lOSMesa"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
*-*-qnx*)
|
|
|
|
EXE=""
|
|
|
|
MATHLIB=""
|
|
|
|
SYS_GL_LIBS="-lGLES_CM"
|
|
|
|
;;
|
2021-11-30 22:55:56 +00:00
|
|
|
*-*-emscripten*)
|
2015-06-21 15:33:46 +00:00
|
|
|
dnl This should really be .js, but we need to specify extra flags when compiling to js
|
|
|
|
EXE=".bc"
|
|
|
|
MATHLIB=""
|
|
|
|
SYS_GL_LIBS=""
|
|
|
|
;;
|
2021-11-30 22:55:56 +00:00
|
|
|
*-*-riscos*)
|
2020-02-13 20:50:47 +00:00
|
|
|
EXE=",e1f"
|
|
|
|
MATHLIB=""
|
|
|
|
SYS_GL_LIBS=""
|
|
|
|
;;
|
2021-11-30 22:55:56 +00:00
|
|
|
*-*-os2*)
|
|
|
|
ISOS2="true"
|
|
|
|
EXE=".exe"
|
|
|
|
MATHLIB=""
|
|
|
|
SYS_GL_LIBS=""
|
|
|
|
;;
|
2015-06-21 15:33:46 +00:00
|
|
|
*)
|
|
|
|
dnl Oh well, call it Unix...
|
|
|
|
ISUNIX="true"
|
|
|
|
EXE=""
|
|
|
|
MATHLIB="-lm"
|
2021-03-17 19:10:31 +00:00
|
|
|
dnl Use the new libOpenGL if present.
|
|
|
|
AC_CHECK_LIB(OpenGL, glBegin,
|
2021-04-14 18:10:40 +00:00
|
|
|
[SYS_GL_LIBS="-lOpenGL"],[SYS_GL_LIBS="-lGL"])
|
2015-06-21 15:33:46 +00:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
AC_SUBST(EXE)
|
|
|
|
AC_SUBST(MATHLIB)
|
|
|
|
AC_SUBST(ISMACOSX)
|
|
|
|
AC_SUBST(ISWINDOWS)
|
|
|
|
AC_SUBST(ISUNIX)
|
2021-11-30 22:55:56 +00:00
|
|
|
AC_SUBST(ISOS2)
|
2015-06-21 15:33:46 +00:00
|
|
|
|
|
|
|
dnl Check for SDL
|
2021-11-28 16:56:25 +00:00
|
|
|
SDL_VERSION=2.0.18
|
2015-06-21 15:33:46 +00:00
|
|
|
AM_PATH_SDL2($SDL_VERSION,
|
|
|
|
:,
|
|
|
|
AC_MSG_ERROR([*** SDL version $SDL_VERSION not found!])
|
|
|
|
)
|
|
|
|
CFLAGS="$CFLAGS $SDL_CFLAGS"
|
|
|
|
LIBS="$LIBS -lSDL2_test $SDL_LIBS"
|
|
|
|
|
|
|
|
dnl Check for X11 path, needed for OpenGL on some systems
|
|
|
|
AC_PATH_X
|
|
|
|
if test x$have_x = xyes; then
|
|
|
|
if test x$ac_x_includes = xno || test "x$ac_x_includes" = xNone || test "x$ac_x_includes" = x; then
|
|
|
|
:
|
|
|
|
else
|
|
|
|
CFLAGS="$CFLAGS -I$ac_x_includes"
|
|
|
|
fi
|
|
|
|
if test x$ac_x_libraries = xno || test "x$ac_x_libraries" = xNone; then
|
|
|
|
:
|
|
|
|
else
|
|
|
|
if test "x$ac_x_libraries" = x; then
|
|
|
|
XPATH=""
|
|
|
|
XLIB="-lX11"
|
|
|
|
else
|
|
|
|
XPATH="-L$ac_x_libraries"
|
|
|
|
XLIB="-L$ac_x_libraries -lX11"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl Check for OpenGL
|
|
|
|
AC_MSG_CHECKING(for OpenGL support)
|
|
|
|
have_opengl=no
|
2021-04-14 18:10:40 +00:00
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
2015-06-21 15:33:46 +00:00
|
|
|
#include "SDL_opengl.h"
|
2020-02-08 19:34:51 +00:00
|
|
|
#ifndef SDL_VIDEO_OPENGL
|
|
|
|
#error SDL_VIDEO_OPENGL
|
|
|
|
#endif
|
2021-04-14 18:10:40 +00:00
|
|
|
]],[])], [have_opengl=yes],[])
|
2015-06-21 15:33:46 +00:00
|
|
|
AC_MSG_RESULT($have_opengl)
|
|
|
|
|
|
|
|
dnl Check for OpenGL ES
|
|
|
|
AC_MSG_CHECKING(for OpenGL ES support)
|
|
|
|
have_opengles=no
|
2021-04-14 18:10:40 +00:00
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
2020-02-08 19:34:51 +00:00
|
|
|
#include "SDL_opengles.h"
|
|
|
|
#ifndef SDL_VIDEO_OPENGL_ES
|
|
|
|
#error SDL_VIDEO_OPENGL_ES
|
|
|
|
#endif
|
2021-04-14 18:10:40 +00:00
|
|
|
]],[])] ,[have_opengles=yes],[])
|
2015-06-21 15:33:46 +00:00
|
|
|
AC_MSG_RESULT($have_opengles)
|
|
|
|
|
|
|
|
dnl Check for OpenGL ES2
|
|
|
|
AC_MSG_CHECKING(for OpenGL ES2 support)
|
|
|
|
have_opengles2=no
|
2021-04-14 18:10:40 +00:00
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
2020-02-08 19:34:51 +00:00
|
|
|
#include "SDL_opengles2.h"
|
|
|
|
#ifndef SDL_VIDEO_OPENGL_ES2
|
|
|
|
#error SDL_VIDEO_OPENGL_ES2
|
2015-06-21 15:33:46 +00:00
|
|
|
#endif
|
2021-04-14 18:10:40 +00:00
|
|
|
]],[])], [have_opengles2=yes],[])
|
2015-06-21 15:33:46 +00:00
|
|
|
AC_MSG_RESULT($have_opengles2)
|
|
|
|
|
|
|
|
GLLIB=""
|
|
|
|
GLESLIB=""
|
|
|
|
GLES2LIB=""
|
2019-05-19 03:47:57 +00:00
|
|
|
OPENGLES1_TARGETS="UNUSED"
|
|
|
|
OPENGLES2_TARGETS="UNUSED"
|
|
|
|
OPENGL_TARGETS="UNUSED"
|
2015-06-21 15:33:46 +00:00
|
|
|
if test x$have_opengles = xyes; then
|
|
|
|
CFLAGS="$CFLAGS -DHAVE_OPENGLES"
|
|
|
|
GLESLIB="$XPATH -lGLESv1_CM"
|
2019-05-19 03:47:57 +00:00
|
|
|
OPENGLES1_TARGETS="TARGETS"
|
2015-06-21 15:33:46 +00:00
|
|
|
fi
|
|
|
|
if test x$have_opengles2 = xyes; then
|
|
|
|
CFLAGS="$CFLAGS -DHAVE_OPENGLES2"
|
|
|
|
#GLES2LIB="$XPATH -lGLESv2"
|
2019-05-19 03:47:57 +00:00
|
|
|
OPENGLES2_TARGETS="TARGETS"
|
2015-06-21 15:33:46 +00:00
|
|
|
fi
|
|
|
|
if test x$have_opengl = xyes; then
|
|
|
|
CFLAGS="$CFLAGS -DHAVE_OPENGL"
|
|
|
|
GLLIB="$XPATH $SYS_GL_LIBS"
|
2019-05-19 03:47:57 +00:00
|
|
|
OPENGL_TARGETS="TARGETS"
|
2015-06-21 15:33:46 +00:00
|
|
|
fi
|
|
|
|
|
2019-05-19 03:47:57 +00:00
|
|
|
AC_SUBST(OPENGLES1_TARGETS)
|
|
|
|
AC_SUBST(OPENGLES2_TARGETS)
|
|
|
|
AC_SUBST(OPENGL_TARGETS)
|
2015-06-21 15:33:46 +00:00
|
|
|
AC_SUBST(GLLIB)
|
|
|
|
AC_SUBST(GLESLIB)
|
|
|
|
AC_SUBST(GLES2LIB)
|
|
|
|
AC_SUBST(XLIB)
|
|
|
|
|
|
|
|
dnl Check for SDL_ttf
|
|
|
|
AC_CHECK_LIB(SDL2_ttf, TTF_Init, have_SDL_ttf=yes)
|
|
|
|
if test x$have_SDL_ttf = xyes; then
|
|
|
|
CFLAGS="$CFLAGS -DHAVE_SDL_TTF"
|
|
|
|
SDL_TTF_LIB="-lSDL2_ttf"
|
|
|
|
fi
|
|
|
|
AC_SUBST(SDL_TTF_LIB)
|
|
|
|
|
test: Fix building with libunwind under autotools
There are two issues which are stopping the SDL tests from building on
my machine:
- libunwind is not being linked
- Even if it is, it is missing several symbols.
The first is fixed by having the test programs link against libunwind if
available. Technically, SDL2_test should be linking against it, as it's
used in SDL_test_memory.c, but as SDL2_test is a static library, it
can't itself import libunwind. We just assume that if it's present on
the system, we should link it directly to the test programs. This should
strictly be an improvement, as the only case where this'd fail is if
SDL2 was compiled when libunwind was present, but the tests are being
compiled without it, and that'd fail anyway.
The second is fixed by #define-ing UNW_LOCAL_ONLY before including
libunwind.h: this is required to make libunwind link to predicatable
symbols, in what can only be described as a bit of a farce. There are a
few more details in the libunwind man page, but the gist of it is that
it disables support for "remote unwinding": unwinding stack frames in a
different process (and possibly from a different architecture?):
http://www.nongnu.org/libunwind/man/libunwind(3).html
Note that I haven't tried this with CMake: I suspect that it'll work,
though, as the CMakeLists.txt seems to have SDL2 link against libunwind if
it's present. This adds an ugly extra dependency to SDL2, but does mean
that issue 1 isn't present. The UNW_LOCAL_ONLY change shouldn't be
build-system-specific.
2021-10-23 06:46:03 +00:00
|
|
|
dnl Really, SDL2_test should be linking against libunwind (if it found
|
|
|
|
dnl libunwind.h when configured), but SDL2_test is a static library, so
|
|
|
|
dnl there's no way for it to link against it. We could make SDL2 depend on
|
|
|
|
dnl it, but we don't want all SDL2 build to suddenly gain an extra dependency,
|
|
|
|
dnl so just assume that if it's here now, SDL2_test was probably built with it.
|
2021-10-31 05:25:24 +00:00
|
|
|
PKG_CHECK_MODULES(LIBUNWIND, libunwind, have_libunwind=yes, have_libunwind=no)
|
|
|
|
if test x$have_libunwind = xyes ; then
|
|
|
|
LIBS="$LIBS $LIBUNWIND_LIBS"
|
|
|
|
fi
|
test: Fix building with libunwind under autotools
There are two issues which are stopping the SDL tests from building on
my machine:
- libunwind is not being linked
- Even if it is, it is missing several symbols.
The first is fixed by having the test programs link against libunwind if
available. Technically, SDL2_test should be linking against it, as it's
used in SDL_test_memory.c, but as SDL2_test is a static library, it
can't itself import libunwind. We just assume that if it's present on
the system, we should link it directly to the test programs. This should
strictly be an improvement, as the only case where this'd fail is if
SDL2 was compiled when libunwind was present, but the tests are being
compiled without it, and that'd fail anyway.
The second is fixed by #define-ing UNW_LOCAL_ONLY before including
libunwind.h: this is required to make libunwind link to predicatable
symbols, in what can only be described as a bit of a farce. There are a
few more details in the libunwind man page, but the gist of it is that
it disables support for "remote unwinding": unwinding stack frames in a
different process (and possibly from a different architecture?):
http://www.nongnu.org/libunwind/man/libunwind(3).html
Note that I haven't tried this with CMake: I suspect that it'll work,
though, as the CMakeLists.txt seems to have SDL2 link against libunwind if
it's present. This adds an ugly extra dependency to SDL2, but does mean
that issue 1 isn't present. The UNW_LOCAL_ONLY change shouldn't be
build-system-specific.
2021-10-23 06:46:03 +00:00
|
|
|
|
2015-06-21 15:33:46 +00:00
|
|
|
dnl Finally create all the generated files
|
2020-12-14 05:11:40 +00:00
|
|
|
AC_CONFIG_FILES([Makefile])
|
|
|
|
AC_OUTPUT
|