diff options
Diffstat (limited to 'configure.ac')
-rw-r--r-- | configure.ac | 214 |
1 files changed, 214 insertions, 0 deletions
diff --git a/configure.ac b/configure.ac new file mode 100644 index 0000000..42de1b3 --- /dev/null +++ b/configure.ac @@ -0,0 +1,214 @@ +AC_INIT(pcsx, 1.9) + +AC_CANONICAL_HOST +AC_CANONICAL_TARGET +AM_INIT_AUTOMAKE(pcsx, 1.9) +AM_MAINTAINER_MODE + +AC_CONFIG_HEADERS([include/config.h:include/config.h.in]) + +AC_PROG_CC +AC_PROG_RANLIB +AC_DISABLE_STATIC +AC_PROG_LIBTOOL +AC_PROG_INSTALL +AC_STDC_HEADERS +AM_PROG_AS + +AM_GNU_GETTEXT([external]) + +GETTEXT_PACKAGE=pcsx +AC_SUBST(GETTEXT_PACKAGE) +AC_DEFINE_UNQUOTED([GETTEXT_PACKAGE], ["${GETTEXT_PACKAGE}"], [gettext domain]) + +PKG_CHECK_MODULES(GLIB2, glib-2.0, [], AC_MSG_ERROR([*** glib2 not found!])) +PKG_CHECK_MODULES(GTK2, gtk+-2.0, [], AC_MSG_ERROR([*** libgtk2 not found!])) +PKG_CHECK_MODULES(GLADE2, libglade-2.0, [], AC_MSG_ERROR([*** libglade2 not found!])) + +AM_PATH_SDL(1.2.0, :, AC_MSG_ERROR([*** SDL not found!])) + +AC_SUBST(GLIB2_CFLAGS) +AC_SUBST(GLIB2_LIBS) +AC_SUBST(GTK2_CFLAGS) +AC_SUBST(GTK2_LIBS) +AC_SUBST(GLADE2_CFLAGS) +AC_SUBST(GLADE2_LIBS) + +AC_CONFIG_FILES([Makefile data/Makefile doc/Makefile libpcsxcore/Makefile gui/Makefile plugins/dfinput/Makefile plugins/dfsound/Makefile plugins/dfxvideo/Makefile plugins/dfcdrom/Makefile plugins/dfnet/Makefile pixmaps/Makefile po/Makefile.in]) + +AC_CHECK_LIB(dl, dlsym, [LDFLAGS="$LDFLAGS -ldl"], []) +AC_CHECK_LIB(socket, socket, [LDFLAGS="$LDFLAGS -lsocket"], []) +AC_CHECK_LIB(nsl, gethostbyname, [LDFLAGS="$LDFLAGS -lnsl"], []) +AC_CHECK_LIB(umem, umem_alloc, [LDFLAGS="$LDFLAGS -lumem"], []) + +AM_CONDITIONAL(SOUND_OSS, false) +AM_CONDITIONAL(SOUND_SDL, false) +AM_CONDITIONAL(SOUND_NULL, false) + +dnl Check for ALSA 1.x, OSS, or PulseAudio + +AC_ARG_ENABLE(sound, [ --enable-sound=... force selection of sound backend (alsa/null/oss/pulseaudio/sdl) (default: sdl)], +[ SOUND="$enableval" ],[ SOUND="sdl" ]) + +if test "x$SOUND" = xalsa; then + PKG_CHECK_MODULES(ALSA, alsa >= 1.0.0, have_alsa=yes, have_alsa=no) +elif test "x$SOUND" = xpulseaudio; then + PKG_CHECK_MODULES(PULSEAUDIO, libpulse >= 0.9.16, have_pulseaudio=yes) +elif test "x$SOUND" = xoss; then + AC_CHECK_HEADER(sys/soundcard.h, have_oss=yes, have_oss=no) + if test "x$have_oss" = xno; then + AC_MSG_ERROR([sys/soundcard.h not found!]) + else + AM_CONDITIONAL(SOUND_OSS, true) + fi +elif test "x$SOUND" = xno; then + AM_CONDITIONAL(SOUND_NULL, true) +elif test "x$SOUND" = xnull; then + AM_CONDITIONAL(SOUND_NULL, true) +else + AM_CONDITIONAL(SOUND_SDL, true) +fi + +AM_CONDITIONAL(SOUND_ALSA, test "x$have_alsa" = xyes) +AC_SUBST(ALSA_LIBS) +AM_CONDITIONAL(SOUND_PULSEAUDIO, test "x$have_pulseaudio" = xyes) +AC_SUBST(PULSEAUDIO_CFLAGS) +AC_SUBST(PULSEAUDIO_LIBS) + +AC_CHECK_HEADER(zlib.h, have_zlib=yes, have_zlib=no) +if test "x$have_zlib" = xno; then + AC_MSG_ERROR([unable to find libz headers]) +fi +AC_CHECK_HEADER(X11/extensions/Xv.h, have_xv=yes, have_xv=no) +if test "x$have_xv" = xno; then + AC_MSG_ERROR([unable to find xv headers]) +fi +AC_CHECK_HEADER(X11/extensions/XTest.h, have_xtest=yes, have_xtest=no) +if test "x$have_xtest" = xno; then + AC_MSG_ERROR([unable to find xtest headers]) +fi + +AM_CONDITIONAL(USE_LIBCDIO, false) + +AC_ARG_ENABLE(libcdio, [ --enable-libcdio use GNU libcdio for CD-ROM support (default=no)], +[ BUILD_LIBCDIO="$enableval" ],[ BUILD_LIBCDIO="no" ]) + +if test "$BUILD_LIBCDIO" = "yes"; then + PKG_CHECK_MODULES(LIBCDIO, libcdio, [], AC_MSG_ERROR([*** libcdio not found!])) + AM_CONDITIONAL(USE_LIBCDIO, true) +fi + +AC_SUBST(LIBCDIO_CFLAGS) +AC_SUBST(LIBCDIO_LIBS) + +AC_ARG_ENABLE(opengl, [ --enable-opengl build OpenGL plugin (default=no)], +[ BUILD_OPENGL="$enableval" ],[ BUILD_OPENGL="no" ]) + +PEOPSXGL="" + +if test "$BUILD_OPENGL" = "yes"; then + AC_CHECK_HEADER(GL/gl.h, have_gl=yes, have_gl=no) + if test "x$have_gl" = xno; then + AC_MSG_ERROR([unable to find OpenGL headers]) + fi + AC_CHECK_HEADER(GL/glx.h, have_glx=yes, have_glx=no) + if test "x$have_glx" = xno; then + AC_MSG_ERROR([unable to find GLX headers]) + fi + AC_CHECK_HEADER(X11/extensions/xf86vmode.h, have_vmode=yes, have_vmode=no, + [[#include <GL/gl.h> + #include <GL/glx.h> + ]]) + if test "x$have_vmode" = xno; then + AC_MSG_ERROR([unable to find xf86vmode headers]) + fi + PEOPSXGL="plugins/peopsxgl" + AC_SUBST(PEOPSXGL) + AC_CONFIG_FILES([plugins/peopsxgl/Makefile]) +fi + +AM_CONDITIONAL(X86_NASM, false) + +if expr x"$target_cpu" : 'xi.86' > /dev/null; then + if expr x"$target_os" : 'x.*linux.*' > /dev/null; then + AC_PATH_PROG([NASM],[nasm],[missing]) + if test "$NASM" = "missing"; then + AC_MSG_WARN([unable to find nasm, needed to build dfx11video]) + AM_CONDITIONAL(X86_NASM, false) + else + AM_CONDITIONAL(X86_NASM, true) + fi + fi +fi + +AM_CONDITIONAL(ARCH_X86, false) +AM_CONDITIONAL(ARCH_X86_64, false) +AM_CONDITIONAL(ARCH_PPC, false) + +AC_ARG_ENABLE(dynarec, [ --enable-dynarec=... force selection of dynamic recompiler platform (auto/no/x86/x86_64/ppc) (default: auto)], +[ DYNAREC="$enableval" ],[ DYNAREC="auto" ]) + +if test "x$DYNAREC" = xauto; then + DYNARECSEL="auto" +else if test "x$DYNAREC" = xx86; then + DYNARECSEL="x86" +else if test "x$DYNAREC" = xx86_64; then + DYNARECSEL="x86_64" +else if test "x$DYNAREC" = xppc; then + DYNARECSEL="ppc" +else if test "x$DYNAREC" = xno; then + DYNARECSEL="no" +else + AC_MSG_WARN([Dynamic Recompiler "$DYNAREC" not found. Autodetecting...]) + DYNARECSEL="auto" +fi +fi +fi +fi +fi + +if test "x$DYNARECSEL" = xauto; then + if expr x"$target_cpu" : 'xi.86' > /dev/null; then + DYNARECSEL="x86" + fi + + if expr x"$target_cpu" : 'xx86_64' > /dev/null; then + DYNARECSEL="x86_64" + fi + + if expr x"$target_cpu" : 'xpowerpc' > /dev/null; then + DYNARECSEL="ppc" + fi +fi + +if test "x$DYNARECSEL" = xno; then + AC_DEFINE([NOPSXREC], [1], [Define if we are compiling without dynamic recompiler.]) +fi + +if test "x$DYNARECSEL" = xx86; then + AC_DEFINE([__i386__], [1], [Define if we are compiling for x86 architectures.]) + AM_CONDITIONAL(ARCH_X86, true) + + AC_MSG_RESULT([Dynamic Recompiler selected: x86]) +fi + +if test "x$DYNARECSEL" = xx86_64; then + AC_DEFINE([__x86_64__], [1], [Define if we are compiling for x86_64 architectures.]) + AM_CONDITIONAL(ARCH_X86_64, true) + dnl CFLAGS+=" -m64 " + dnl AC_COMPILE_IFELSE(AC_LANG_PROGRAM,,AC_MSG_ERROR([Cannot compile with -m64])) + AC_MSG_RESULT([Dynamic Recompiler selected: x86_64]) +fi + +if test "x$DYNARECSEL" = xppc; then + AC_DEFINE([__ppc__], [1], [Define if we are compiling for powerpc architectures.]) + AM_CONDITIONAL(ARCH_PPC, true) + AC_MSG_RESULT([Dynamic Recompiler selected: ppc]) +fi + +AC_C_BIGENDIAN(AC_DEFINE([__BIGENDIAN__],[],[define on a big endian system])) + +AC_DEFINE([__LINUX__], [1], [Define if building on a GNU/Linux system.]) +AC_DEFINE([MAXPATHLEN], [4096], [Define to the maximum length of any path.]) + +AC_OUTPUT |